laravel 测试简介
测试是软件开发的一个重要方面,可确保您的应用程序按预期工作。 laravel 通过 phpunit(一种流行的 php 测试框架)提供了一个强大的开箱即用的测试套件。本指南将引导您在 laravel 中设置和运行测试,解释单元测试和功能测试之间的差异,并提供各种测试场景的示例。
文件夹结构:单元测试与功能测试
在 laravel 中,测试通常被组织到两个主要目录中:unit 和 feature。
单元测试:这些测试旨在测试应用程序的小型、独立部分,例如单个方法或类。它们通常位于tests/unit 目录中。每个测试函数都应该以单词 test 开头。
示例:
public function testexamplefunction() {
$this->asserttrue(true);
}
功能测试:这些测试处理更复杂的交互,通常测试多个组件一起工作。它们位于测试/功能目录中。功能测试通常涉及发出 http 请求和检查响应。
在 laravel 中运行测试
要在 laravel 应用程序中运行所有测试,请使用以下命令:
./vendor/bin/phpunit
配置测试环境
在运行测试之前,配置测试环境非常重要。修改 phpunit.xml 文件以设置用于测试的环境变量。例如,要使用 sqlite 内存数据库进行更快的测试:
<php><env name="app_env" value="testing"></env><env name="app_maintenance_driver" value="file"></env><env name="bcrypt_rounds" value="4"></env><env name="cache_store" value="array"></env><env name="db_connection" value="sqlite"></env><env name="db_database" value=":memory:"></env><env name="mail_mailer" value="array"></env><env name="pulse_enabled" value="false"></env><env name="queue_connection" value="sync"></env><env name="session_driver" value="array"></env><env name="telescope_enabled" value="false"></env></php>
启用 sqlite 作为测试环境后,清除配置缓存:
php artisan config:clear
*示例:测试配置文件路由是否存在并正常工作
*
为配置文件路由创建测试:
php artisan make:test profiletest
添加测试方法来检查个人资料页面是否显示特定文本:
public function testprofilepage(){
$response = $this->get('/profile');
$response->assertseetext('your profile');
}
测试数据库交互
设置测试数据库
立即学习“PHP免费学习笔记(深入)”;
在测试数据库交互之前,在 config/database.php 中创建一个测试数据库配置:
'mysqltesting' => [
'driver' => 'mysql',
'url' => env('db_url'),
'host' => env('db_host', '127.0.0.1'),
'port' => env('db_port', '3306'),
'database' => 'laravel_testing',
'username' => env('db_username', 'root'),
'password' => env('db_password', ''),
'unix_socket' => env('db_socket', ''),
'charset' => 'utf8mb4',
'collation' => 'utf8mb4_unicode_ci',
'prefix' => '',
'prefix_indexes' => true,
'strict' => true,
'engine' => null,
'options' => extension_loaded('pdo_mysql') ? array_filter([
pdo::mysql_attr_ssl_ca => env('mysql_attr_ssl_ca'),
]) : [],
],
运行数据库测试
运行 phpunit 命令以确保测试数据库已创建并正常工作:
./vendor/bin/phpunit
示例:测试用户注册
创建用户注册测试:
php artisan make:test usertest
添加测试方法来验证用户是否可以创建并保存到数据库:
public function test_registration(): void
{
$user = new user();
$user->name = 'test user';
$user->email = 'email@example.com';
$user->password = bcrypt('password');
$user->save();
$this->assertdatabasehas('users', ['email' => 'email@example.com']);
}
测试商店操作
在 posttest 类中创建存储操作的测试:
public function testpoststorevalid()
{
$data = [
'title'=> 'test post',
'slug' => 'test-post',
'content' => 'content of the post',
'active' => true,
];
$this->post('/posts', $data)
->assertstatus(302)
->assertsessionhas('status');
$this->assertequals(session('status'), 'post was created!');
}
故障测试
添加测试方法来检查验证错误:
public function testpostfail()
{
$data = [
'title'=> '',
'content' => '',
];
$this->post('/posts', $data)
->assertstatus(302)
->assertsessionhas('errors');
$messages = session('errors')->getmessages();
$this->assertequals($messages['title'][0], 'the title must be at least 4 characters.');
$this->assertequals($messages['title'][1], 'the title field is required.');
$this->assertequals($messages['content'][0], 'the content field is required.');
}
*测试更新操作
*
添加更新帖子的测试方法:
public function testpostupdate()
{
$post = new post();
$post->title = "initial title";
$post->slug = str::slug($post->title, '-');
$post->content = "initial content";
$post->active = true;
$post->save();
$this->assertdatabasehas('posts', $post->toarray());
$data = [
'title' => 'updated title',
'slug' => 'updated-title',
'content' => 'updated content',
'active' => false,
];
$this->put("/posts/{$post->id}", $data)
->assertstatus(302)
->assertsessionhas('status');
$this->assertdatabasehas('posts', ['title' => $data['title']]);
$this->assertdatabasemissing('posts', ['title' => $post->title]);
}
测试删除操作
添加删除帖子的测试方法:
public function testpostdelete()
{
$post = new post();
$post->title = "title to delete";
$post->slug = str::slug($post->title, '-');
$post->content = "content to delete";
$post->active = true;
$post->save();
$this->assertdatabasehas('posts', $post->toarray());
$this->delete("/posts/{$post->id}")
->assertstatus(302)
->assertsessionhas('status');
$this->assertdatabasemissing('posts', $post->toarray());
}
**
使用 phpunit 运行特定测试
**
要运行特定的测试方法或类,请在 phpunit 中使用 --filter 选项。以下是一些例子:
运行特定的测试方法
./vendor/bin/phpunit --filter posttest::testpostdelete
运行特定类中的所有测试
./vendor/bin/phpunit --filter posttest
在特定文件中运行测试
./vendor/bin/phpunit tests/feature/posttest.php
详细输出
想要更详细的输出,请添加 -v 选项:
./vendor/bin/phpunit --filter PostTest::testPostDelete -v