Pest 是基于 PHPUnit 的现代测试框架,专为 Laravel 项目优化,提供更简洁的 BDD语法。1. 安装:运行 composer require --dev pestphp/pest pestphp/pest-plugin-laravel 引入依赖。2. 初始化:执行 ./vendor/bin/pest --init 自动生成入口文件、备份原 TestCase 并创建示例测试。3. 编写测试:使用 describe 和 it 函数编写可读性强的测试,如测试首页响应。4. 兼容性:旧 PHPUnit 测试可并行运行,实现零成本迁移。5. 自动发现:所有以 Pest.php 结尾的文件会被自动识别执行。
想在Laravel项目中把PHPUnit测试升级为更简洁、更具可读性的写法?Pest 是一个基于 PHPUnit 构建的现代测试框架,专为简化测试语法而设计。它保留了 PHPUnit 的全部功能,同时引入了更接近自然语言的 BDD 风格语法,特别适合 Laravel 项目。下面带你一步步从 PHPUnit 转向 Pest。
Pest 的优势在于:
在已有 Laravel 项目中启用 Pest 很简单:
composer require --dev pestphp/pest pestphp/pest-plugin-laravel
./vendor/bin/pest --init
这个命令会:
比如你想测试首页是否正常返回:
// tests/Feature/HomeTest.php assertStatus(200); });
对比 PHPUnit 写法:
get('/')->assertStatus(200);
}
}
Pest 版本少了类定义、命名空间和方法声明,逻辑更聚焦。
当测试变多时,可以用 describe 组织逻辑:
assertStatus(200);
});
it('contains welcome text', function () {
get('/')->assertSee('Welcome');
});
});
这种结构让测试像文档一样清晰,团队成员更容易理解。
Pest for Laravel 提供了一系列全局函数:
例如测试需要登录的页面:
assertRedirect('/login');
});
it('allows authenticated users to access dashboard', function () {
$user = User::factory()->create();
actingAs($user)
->get('/dashboard')
->assertOk();
});
运行方式和 PHPUnit 一样:
./vendor/bin/pest
常用选项:
不必一次性重写所有测试。Pest 可以和 PHPUnit 测试文件并存:
基本上就这些。Pest 让 Laravel 测试变得更轻快、更愉悦。语法简洁但不牺牲功能,是现代 PHP 项目的理想选择。从下一个测试开始尝试吧,你会发现写测试不再是负担。