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 assertStatus(200); });
对比 PHPUnit 写法:
get('/')->assertStatus(200);
}
}
Pest 版本少了类定义、命名空间和方法声明,逻辑更聚焦。
使用 describe 分组测试
当测试变多时,可以用 describe 组织逻辑:
assertStatus(200);
});
it('contains welcome text', function () {
get('/')->assertSee('Welcome');
});
});
这种结构让测试像文档一样清晰,团队成员更容易理解。
使用 Laravel 提供的辅助函数
Pest for Laravel 提供了一系列全局函数:
- get, post, put, delete:发起 HTTP 请求
- actingAs($user):模拟用户登录
- assertDatabaseHas:断言数据库记录
- seed:运行 Seeder
例如测试需要登录的页面:
assertRedirect('/login');
});
it('allows authenticated users to access dashboard', function () {
$user = User::factory()->create();
actingAs($user)
->get('/dashboard')
->assertOk();
});
运行测试
运行方式和 PHPUnit 一样:
./vendor/bin/pest
常用选项:
- --watch:监听文件变化自动重跑(需安装 watch 插件)
- --parallel:并行执行测试
- --coverage:生成代码覆盖率报告
与现有 PHPUnit 测试共存
不必一次性重写所有测试。Pest 可以和 PHPUnit 测试文件并存:
- 新测试用 *.test.php 或 *Pest.php 命名
- 旧的 TestCase.php 类仍可用
- 逐步迁移,风险可控
提升体验的小技巧
- 安装 pest-plugin-parallel 加速测试
- 使用 pest-plugin-laravel 提供的 setup/cleanup 钩子
- 在 tests/Helpers.php 中定义共享逻辑
- 利用 uses() 函数批量应用 Trait
基本上就这些。Pest 让 Laravel 测试变得更轻快、更愉悦。语法简洁但不牺牲功能,是现代 PHP 项目的理想选择。从下一个测试开始尝试吧,你会发现写测试不再是负担。











