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?
Pest 的优势在于:
- 语法更简洁:无需写类和方法,用 describe/it 就能组织测试
- 与 Laravel 深度集成:官方支持 laravel/pest 插件
- 零成本迁移:旧的 PHPUnit 测试仍可共存
- 自动发现测试文件:所有以 Pest.php 结尾的文件都会被识别
安装 Pest 到 Laravel 项目
在已有 Laravel 项目中启用 Pest 很简单:
- 通过 Composer 安装 Pest 和 Laravel 适配插件:
composer require --dev pestphp/pest pestphp/pest-plugin-laravel
登录后复制
- 初始化 Pest:
./vendor/bin/pest --init
登录后复制
这个命令会:
立即学习“PHP免费学习笔记(深入)”;
- 创建 tests/Pest.php 入口文件
- 重命名原有的 TestCase.php 为 TestCase.php.bak
- 生成示例测试文件
编写第一个 Pest 测试
比如你想测试首页是否正常返回:
// tests/Feature/HomeTest.php
<?php
use function Pest\Laravel\get;
it('returns a successful response', function () {
get('/')->assertStatus(200);
});登录后复制
对比 PHPUnit 写法:
<?php
namespace Tests\Feature;
use Tests\TestCase;
class HomeTest extends TestCase
{
public function test_returns_successful_response()
{
$this->get('/')->assertStatus(200);
}
}登录后复制
Pest 版本少了类定义、命名空间和方法声明,逻辑更聚焦。
使用 describe 分组测试
当测试变多时,可以用 describe 组织逻辑:
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~