Laravel 8 上的 HTTP RESTful API 功能测试
Posted
技术标签:
【中文标题】Laravel 8 上的 HTTP RESTful API 功能测试【英文标题】:Feature test for HTTP RESTful API on Laravel 8 【发布时间】:2021-06-08 14:14:42 【问题描述】:我正在尝试使用我在 laravel 8 中创建的 RESTful API 编写功能测试。
我有ChatController
通过getUserChats
方法获取用户聊天:
// get chats for user
public function getUserChats()
$chats = $this->chats->getUserChats();
return ChatShowResource::collection($chats);
这条路线调用的:
Route::get('chats', [
App\Http\Controllers\Chats\ChatController::class, 'getUserChats'
]);
这是我在这条路线上的功能测试:
public function test_get_user_chats()
// creates the fake user
$user = User::factory()->create();
$this->actingAs($user, 'api');
// adds the chat to new fake user that created
$response_create_chat = $this->json('POST', '/api/chats', [
'recipient' => $user->username,
'body' => 'some chat text',
]
);
$response_create_chat
->assertStatus(201)
->assertJsonPath('data.body', 'some chat text');
$response_get_chats = $this->json('get', '/api/chats');
$response_get_chats->assertStatus(200);
此绿色输出OK (1 test, 3 assertions)
成功运行测试,但我不知道这是实现它的最佳方式。
所以问题是我在测试中还需要做什么?我在做正确的功能测试吗?
【问题讨论】:
【参考方案1】:通常,您希望测试的范围尽可能小。您提供的测试用例目前正在测试两个单独的 api 端点:
创建聊天 聊天这样做的问题是,如果与创建聊天相关的代码中断,那么与获取聊天相关的测试用例将失败。
我建议将它们分成两个单独的测试用例。这将让您相信,如果您获取聊天的测试用例失败,那是因为与获取聊天相关的代码失败,而不是与此端点无关的代码。
我还建议使用setUp
和tearDown
方法来确保您的测试用例使数据库处于与找到它时相同的状态。这确保了其他测试用例不必关心来自该测试的数据。这意味着setUp
方法应该执行以下操作:
tearDown
方法将负责删除用户和聊天。
此外,您应该测试端点输出的格式和数据。目前,您只检查 200 响应代码。如果您的 api 更新为返回用户列表而不是聊天记录,则与获取聊天记录相关的测试用例仍将通过,因为它实际上并未验证返回的数据。
前:
class GetChatsTest extends TestCase
private User $user;
public function testGetChats(): void
$chat = $this->json('get', '/api/chats');
// Check the chat's returned value
$this->assertSame('Some parameters', $chat);
protected function setUp(): void
parent::setUp();
// Create the user in the setup. This is run before each test method is run.
$this->user = User::factory()->create();
// Create the chat for the user (Pseudo code because I don't know how your code works)
$this->user->createChat('Some parameters');
protected function tearDown(): void
parent::tearDown();
// Delete the user and chats here, pseudocode again. This runs after every test method is run
$this->user->deleteChats();
$this->user->delete();
关于示例代码需要注意的一点是,它不使用 rest api 来创建用户或聊天,而是使用伪代码控制器方法来确保它不依赖于聊天 api 的功能进行测试.
【讨论】:
您能否编辑您的答案并添加一些有关使用 setUp 和 tearDown 的代码? 那么我们在哪里为新用户分配(创建)聊天? 这将在setUp
方法中完成,因为您正在准备环境以测试获取聊天列表的代码。以上是关于Laravel 8 上的 HTTP RESTful API 功能测试的主要内容,如果未能解决你的问题,请参考以下文章
如何在 Laravel 5 中验证 RESTful API?