当前位置:首页 > AI技术 > 正文内容

Laravel 单元测试中为更新操作传递参数的正确方法完全指南|Duuu笔记

admin2个月前 (04-01)AI技术51

在 Laravel 单元测试中调用 PUT 请求更新资源时,需通过请求体(JSON 或表单数据)传递待修改字段,而非拼接在 URL 中;本文详解如何在 TestCase 中构造含参数的 HTTP 请求,并结合数据提供器实现多场景覆盖测试。

在 laravel 单元测试中调用 `put` 请求更新资源时,需通过请求体(json 或表单数据)传递待修改字段,而非拼接在 url 中;本文详解如何在 `testcase` 中构造含参数的 http 请求,并结合数据提供器实现多场景覆盖测试。

在 Laravel 的 API 测试中,$this->put() 方法用于模拟 HTTP PUT 请求,其

第二个参数即为请求体(payload)

,用于向控制器传递更新所需的数据。你当前的测试代码:

$response = $this->put('api/constituencies/'.$constituency_id);

未传入任何数据,因此控制器中的 $request->name 为空,导致更新无效——这正是测试“看似通过”实则未验证业务逻辑的根本原因。

✅ 正确做法:通过 payload 传递更新参数

假设你的路由已正确定义(推荐使用命名路由):

// routes/api.php

Route::put('/constituencies/{constituency}', [ConstituencyController::class, 'update'])

->name('api.constituencies.update');

则测试应明确构造包含 name 字段的数组作为 payload:

白瓜AI

白瓜AI,一个免费图文AI创作工具,支持 AI 仿写,图文生成,敏感词检测,图片去水印等等。

下载

public function test_a_constituency_can_be_modified()

{

// Arrange

$constituency = Constituency::factory()->create(['name' => 'Old Name']);

// Act: 传递新名称到请求体

$response = $this->put(

route('api.constituencies.update', $constituency),

['name' => 'New Name'] // ← 关键:更新参数在此处

);

// Assert: 验证数据库已变更

$this->assertDatabaseHas('constituencies', [

'id' => $constituency->id,

'name' => 'New Name', // ← 检查是否更新成功

]);

// 可选:验证响应结构与状态

$response->assertStatus(200)

->assertJson(['name' => 'New Name']);

}

?

提示

:使用 route() 辅助函数替代硬编码 URL,既提升可维护性,又自动支持路由模型绑定(如 Constituency $constituency),避免手动解析 ID。

? 进阶技巧:使用 Data Provider 实现多值批量测试

当需验证不同名称、空值、特殊字符等多组输入时,PHPUnit 的 @dataProvider 是最佳实践。它将测试逻辑与数据分离,增强可读性与覆盖率:

/**

* @test

* @dataProvider validConstituencyNamesProvider

*/

public function it_updates_constituency_name_with_various_inputs(string $newName)

{

$constituency = Constituency::factory()->create();

$response = $this->put(

route('api.constituencies.update', $constituency),

['name' => $newName]

);

$response->assertOk()

->assertJson(['name' => $newName]);

$this->assertDatabaseHas('constituencies', [

'id' => $constituency->id,

'name' => $newName,

]);

}

public function validConstituencyNamesProvider(): array

{

return [

['Northshire'],

['St. Elmo\'s Bay'], // 含撇号

['West 12th District'], // 含数字与空格

['Élysée'], // 含重音字符

];

}

⚠️ 注意事项与最佳实践

不要直接使用 $request->all() 在生产代码中更新模型

当前示例为简化演示使用了 $constituency->update($request->all()),但实际项目中

必须显式指定可填充字段或使用表单请求验证

(如 StoreConstituencyRequest),防止 Mass Assignment 漏洞。

控制器应校验输入

建议在 update 方法中引入验证逻辑:

public function update(Request $request, Constituency $constituency)

{

$validated = $request->validate(['name' => 'required|string|max:255']);

$constituency->update($validated);

return new ConstituencyResource($constituency);

}

测试失败场景

补充验证非法输入(如空 name)是否返回 422 错误:

$this->put(route('api.constituencies.update', $constituency), ['name' => ''])

->assertStatus(422);

数据库事务隔离

确保测试类使用 RefreshDatabase trait,保证每次测试运行在干净数据库状态下。

通过以上方式,你不仅能准确传递更新参数,还能构建健壮、可维护、高覆盖的 Laravel CRUD 测试套件。记住:

真正的测试不是“调用接口”,而是“驱动行为并断言结果”

相关文章

Unity 机器学习 基础

ML-Agents 资产导入 Unity 场景创建 Unity 代码部分 Anaconda 执行 rollerball_config.yaml 机器学习逻辑处理...

几种主要的神经网络

卷积神经网络的输入为二维的像素整阵列,输出为这个图片的属性,当网络训练学习后,所输入的图片或许经过稍微的变换,但卷积神经网络还是可以通过识别图片局部的特征而将整个图片识别出来。 :该层...

AI实战详解:Perplexity 怎么做市场调研 Perplexity 市场分析实操教程【商业】最佳实践|Duuu笔记

掌握Perplexity AI市场调研需五步:一、结构化提问嵌入地域/时间/主体/指标四要素;二、限定PDF等原始信源提升可信度;三、分步提问生成制表符分隔文本以自动导入Excel;四、启用Pro S...

深入理解前端开发:Minimax 视频生成中负面提示词(Negative Prompt)写法完全指南|Duuu笔记

Minimax视频生成中负面提示词需用英文、逗号分隔,支持权重调节(如(blurry:1.3)),按构图/主体/画质/风格四类精简选取,禁用not/no/中文及违规词,须通过A/B测试验证有效性。...

深入理解前端开发:Minimax视频生成黑科技:复杂动作模拟完全指南|Duuu笔记

为精准模拟复杂动作,需采用分帧提示词构建、骨骼关键点引导注入和多阶段动作蒸馏三法:一、将动作拆解为带空间姿态的关键帧序列并加物理约束;二、注入2D/3D关键点坐标锚定关节位置;三、通过粗生成→特征提取...

深入理解前端开发:零基础教程:怎么用 Gemini 自动生成短视频脚本与拍摄大纲完全指南|Duuu笔记

需明确输入指令、理解输出逻辑并合理拆解内容:一、构建含角色/任务/格式等要素的提示词;二、追加分镜与时间轴约束优化专业性;三、转译为带道具编号与颜色标记的执行清单;四、用Gemini校验注意力断点并迭...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。