Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程

26次阅读

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 Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程

想在Laravel项目中把PHPUnit测试升级为更简洁、更具可读性的写法?Pest 是一个基于 PHPUnit 构建的现代测试框架,专为简化测试语法而设计。它保留了 PHPUnit 的全部功能,同时引入了更接近自然语言的 BDD 风格语法,特别适合 Laravel 项目。下面带你一步步从 PHPUnit 转向 Pest。

为什么选择 Pest?

Pest 的优势在于:

  • 语法更简洁:无需写类和方法,用 describe/it 就能组织测试
  • 与 Laravel 深度集成:官方支持 laravel/pest 插件
  • 零成本迁移:旧的 PHPUnit 测试仍可共存
  • 自动发现测试文件:所有以 Pest.php 结尾的文件都会被识别

安装 Pest 到 Laravel 项目

在已有 Laravel 项目中启用 Pest 很简单:

  1. 通过 Composer 安装 Pest 和 Laravel 适配插件:
composer require --dev pestphp/pest pestphp/pest-plugin-laravel
  1. 初始化 Pest:
./vendor/bin/pest --init

这个命令会:

立即学习PHP免费学习笔记(深入)”;

  • 创建 tests/Pest.php 入口文件
  • 重命名原有的 TestCase.phpTestCase.php.bak
  • 生成示例测试文件

编写第一个 Pest 测试

比如你想测试首页是否正常返回:

// tests/Feature/HomeTest.php <?php  use function PestLaravelget;  it('returns a successful response', function () {     get('/')->assertStatus(200); });

对比 PHPUnit 写法:

<?php  namespace TestsFeature;  use TestsTestCase;  class HomeTest extends TestCase {     public function test_returns_successful_response()     {         $this->get('/')->assertStatus(200);     } }

Pest 版本少了类定义、命名空间和方法声明,逻辑更聚焦。

使用 describe 分组测试

当测试变多时,可以用 describe 组织逻辑:

Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程

趣问问AI

免费可用的国内版chat,AI写作和AI对话

Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程 97

查看详情 Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程

<?php  use function PestLaravelget;  describe('Home Page', function () {     it('loads successfully', function () {         get('/')->assertStatus(200);     });      it('contains welcome text', function () {         get('/')->assertSee('Welcome');     }); });

这种结构让测试像文档一样清晰,团队成员更容易理解。

使用 Laravel 提供的辅助函数

Pest for Laravel 提供了一系列全局函数:

  • get, post, put, delete:发起 http 请求
  • actingAs($user):模拟用户登录
  • assertDatabaseHas:断言数据库记录
  • seed:运行 Seeder

例如测试需要登录的页面:

<?php  use function PestLaravel{get, actingAs}; use AppModelsUser;  it('requires authentication', function () {     get('/dashboard')->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 项目的理想选择。从下一个测试开始尝试吧,你会发现写测试不再是负担。

以上就是Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程的详细内容,更多请关注

text=ZqhQzanResources