大规模代码审查存在缺陷。Augment Code 正在解决这个问题。

使用 Laravel 的 requestException() 方法改进 HTTP 错误测试

发布日期 经过

使用 Laravel 的 requestException() 方法改进 HTTP 错误测试(图片)

Laravel 通过添加 requestException() 来增强开发人员的测试能力,这是一个便捷的方法,可以简化创建 HTTP 客户端异常的过程,从而实现更有效的错误测试。

测试外部 API 交互需要模拟各种错误响应,以验证异常处理是否正确。以前,创建 RequestException 需要编写冗长且多步骤的代码。新的 requestException() 方法提供了一种简洁优雅的替代方案:

使用 照亮\支持\立面\HTTP ;
// 创建一个具有特定响应正文和状态码的请求异常
$异常 = Http :: requestException ([ '错误' => '无效令牌' ], 401 (英文):
// 创建一个仅包含状态码的请求异常
$异常 = Http :: requestException 地位 : 500 (英文):
// 创建带有请求头的请求异常
$异常 = Http :: requestException
[ '信息' => “请求太多了” ],
429 ,
[ 'X-RateLimit-Reset' => ‘30’ ]
(英文):

可读性提升显著:

// 之前:冗长、多步骤的过程
$异常 = 新的 请求异常
新的 回复
Http :: 回复 ([ '代码' => '无效令牌' ], 401 -> 等待 ()
(英文):
// 之后:简洁的单行方法
$异常 = Http :: requestException ([ '代码' => '无效令牌' ], 401 (英文):

这种方法尤其适用于测试与外部 API 交互的服务:

班级 支付网关测试 延伸 测试用例
{
民众 功能 test_it_handles_api_authentication_errors ()
{
Http :: 伪造的 ([
'api.payment.com/*' => Http :: 回复 ([ '错误' => “无效的 API 密钥” ], 401 ),
]);
// 测试服务对 401 错误的处理
$gateway = 新的 支付网关 ();
$结果 = $gateway -> 处理付款 (支付数据)
$this -> 断言错误 (结果) -> 成功);
$this -> 断言等于 'authentication_failed' ,$result -> 错误);
// 使用 throw-catch 方法测试异常处理
尝试 {
// 模拟 HTTP 客户端抛出异常
Http :: 伪造的 功能 (){
Http :: requestException ([ '错误' => “无效的 API 密钥” ], 401 (英文):
});
$gateway -> processPaymentOrFail (支付数据)
$this -> 失败 未抛出异常 (英文):
} 抓住 PaymentAuthenticationException $e) {
$this -> 断言等于 401 ,$e -> 获取状态码 ());
$this -> 断言等于 “无效的 API 密钥” ,$e -> 获取错误消息 ());
}
}
}

requestException() 方法为 HTTP 交互错误处理创建了更简洁、更易于维护的测试,提高了代码质量,同时降低了测试的复杂性。

哈里斯·拉夫托普洛斯摄

高级软件工程师 • Laravel News 员工及讲师 • Laravel Greece Meetup 联合组织者

归档于:
立方体

Laravel 时事通讯

加入超过 4 万名开发者的行列,不错过任何新的技巧、教程等内容。

图像
Jump24 - 英国 Laravel 代理机构

Laravel 开发人员,精通技术,绝不外包,绝不离岸外包,始终卓越。

访问 Jump24 - 英国 Laravel 代理机构
Tinkerwell 徽标

廷克威尔

Laravel 开发者必备的代码运行器。可在本地和生产环境中体验 AI、自动补全和即时反馈功能。

廷克威尔
几天内即可获得 Laravel 代码审查徽标的专家指导

几天内即可获得 Laravel 代码审查方面的专家指导

专家级代码审查!两位拥有 10 年以上 Laravel 开发经验的开发者将为您提供清晰、实用的反馈,帮助团队构建更优质的应用程序。

几天内即可获得 Laravel 代码审查方面的专家指导
PhpStorm 标志

PhpStorm

首选的 PHP IDE,对 Laravel 及其生态系统提供广泛的开箱即用支持。

PhpStorm
Laravel Cloud 标志

Laravel 云

轻松创建和管理服务器,并在几秒钟内部署 Laravel 应用程序。

Laravel 云
了解 Softtech 的标志

了解软科技

Acquaint Softtech 提供 AI 就绪的 Laravel 开发人员,48 小时内即可上手,每月费用为 3000 美元,没有冗长的销售流程,并提供 100% 退款保证。

了解软科技
Kirschbaum 标志

樱桃树

提供创新和稳定性,确保您的Web应用程序取得成功。

樱桃树
Shift 标志

转移

还在运行旧版本的 Laravel?立即实现 Laravel 自动升级和代码现代化,让您的应用程序保持最新状态。

转移
鱼叉:新一代时间跟踪和发票标志

Harpoon:新一代时间跟踪和发票系统

新一代时间跟踪和计费软件,帮助您的机构规划和预测盈利的未来。

Harpoon:新一代时间跟踪和发票系统
Lucky Media 标志

幸运传媒

Get Lucky Now——拥有十余年经验的 Laravel 开发理想之选!

幸运传媒
SaaSykit:Laravel SaaS 入门套件徽标

SaaSykit:Laravel SaaS 入门套件

SaaSykit 是一个多租户 Laravel SaaS 入门套件,包含运行现代 SaaS 所需的所有功能,例如支付、美观的结账界面、管理面板、用户仪表盘、身份验证、现成组件、统计数据、博客、文档等等。

SaaSykit:Laravel SaaS 入门套件
Log User Activity in Your Laravel App with Activity Log v5  image

Log User Activity in Your Laravel App with Activity Log v5

阅读文章
使用新的 Cloud CLI 镜像从终端管理 Laravel Cloud

使用新的 Cloud CLI 从终端管理 Laravel Cloud

阅读文章
Laravel 13.3.0 图片中的单元测试属性及其他功能

Laravel 13.3.0 中的单元测试属性及更多功能

阅读文章
PAO:PHP 测试工具的代理优化输出图像

PAO:PHP 测试工具的代理优化输出

阅读文章
PhpStorm 2026.1 发布镜像

PhpStorm 2026.1 发布

阅读文章
使用 Laravel 构建 AI:智能工单分类及结构化输出图像

使用 Laravel 构建 AI:基于结构化输出的智能工单分诊

阅读文章