作为开拓职员,我们花费了大量韶光编写测试。虽然 PHPUnit 一贯是 PHP 测试的首选框架,但它并不总是最令人愉快的选择。现在有了 PestPHP —— 一个当代、简洁的测试框架,它供应了更直不雅观、更具表现力的语法,同时在底层仍由 PHPUnit 驱动。
在这篇文章中,我们将深入磋商 PestPHP,并通过构建一个轻微繁芜的示例,展示如何测试一个 Web 运用程序的小功能。
什么是 PestPHP? PestPHP 的设计理念是简洁。它抛弃了 PHPUnit 繁重的类构造,采取了一种基于函数的语法,更易于阅读和编写。只管 PestPHP 封装了 PHPUnit,但它觉得更加轻量化和专注,使编写测试变得更加愉快。

无论你是履历丰富的 PHPUnit 用户还是测试新手,PestPHP 供应了相同的测试能力,但减少了大量的样板代码。
安装 要开始利用 PestPHP,请在项目根目录运行以下命令:
composer require pestphp/pest --dev
然后初始化 PestPHP:
./vendor/bin/pest --init
这将创建必要的 tests 目录,并包含一个基本的测试文件。
现在,让我们深入理解一个更详细的示例。
利用 PestPHP 构建和测试一个功能 假设你正在开拓一个任务管理运用程序。一个功能许可用户创建、查看和管理任务。我们将利用 PestPHP 编写测试来验证此功能。
步骤 1:创建 Task 模型 我们假设你利用的是像 Laravel 这样的 MVC 框架,但此示例可以轻松适用于其他任何框架。
<?phpclass Task{ public $name; public $completed; public function __construct($name, $completed = false) { $this->name = $name; $this->completed = $completed; } public function markAsCompleted() { $this->completed = true; } public function isCompleted() { return $this->completed; }}
在此示例中,我们的 Task 模型表示一个带有名称和完成状态的待办任务。它有一个 markAsCompleted 方法来完成任务,isCompleted 方法来检讨任务是否已完成。
步骤 2:为 Task 模型编写 PestPHP 测试 现在,让我们利用 PestPHP 测试这个模型。创建一个新的测试文件 tests/Feature/TaskTest.php。
<?phpuse PHPUnit\Framework\TestCase;it('can create a task', function () { $task = new Task('Buy groceries'); expect($task->name)->toBe('Buy groceries'); expect($task->isCompleted())->toBeFalse();});it('can mark a task as completed', function () { $task = new Task('Finish homework'); $task->markAsCompleted(); expect($task->isCompleted())->toBeTrue();});
分解:
it():这是 PestPHP 的核心函数,用于定义测试。它后面随着一个描述和包含测试逻辑的闭包。expect():一个强大的 PestPHP 函数,用于进行断言。它供应了一种流畅的 API 来验证测试的结果。运行这些测试,确保我们的 Task 类按预期事情:
./vendor/bin/pest
输出:
✓ can create a task✓ can mark a task as completed
太棒了!
两个测试都通过了。但让我们通过添加验证和测试边界情形使其更加繁芜。
步骤 3:添加验证和边界情形 在任何真实天下的运用程序中,你都必须处理无效输入。对付我们的 Task 模型,我们将确保任务名称不为空,并且任务初始化时状态是有效的。
添加验证的 Task 模型
<?phpclass Task{ public $name; public $completed; public function __construct($name, $completed = false) { if (empty($name)) { throw new InvalidArgumentException("Task name cannot be empty."); } $this->name = $name; $this->completed = $completed; } public function markAsCompleted() { $this->completed = true; } public function isCompleted() { return $this->completed; }}
现在,布局函数会在任务名称为空时抛出 InvalidArgumentException。让我们为此场景编写一个测试。
步骤 4:为验证编写测试 将以下内容添加到 TaskTest.php:
<?phpit('throws an exception if the task name is empty', function () { $this->expectException(InvalidArgumentException::class); new Task('');});it('can handle a task with initial completed status', function () { $task = new Task('Wash the car', true); expect($task->isCompleted())->toBeTrue();});
分解:
$this->expectException():只管 PestPHP 简化了语法,你仍旧可以在测试中利用 PHPUnit 的功能,比如非常处理。测试不同的初始状态:我们添加了一个测试来处理任务初始化时 completed 状态为 true 的情形。再次运行测试:
./vendor/bin/pest
输出:
✓ can create a task✓ can mark a task as completed✓ throws an exception if the task name is empty✓ can handle a task with initial completed status
所有测试都成功通过。我们现在已经测试了 Task 类的各个部分,包括正常路径和边界情形。
步骤 5:利用测试组组织测试 随着测试套件的增长,将干系测试分组会很有帮助。PestPHP 通过测试组让这变得很随意马虎。
你可以通过在测试定义末端添加标签来将测试分配到特定组:
<?phpit('can create a task', function () { $task = new Task('Buy groceries'); expect($task->name)->toBe('Buy groceries'); expect($task->isCompleted())->toBeFalse();})->group('task-creation');it('throws an exception if the task name is empty', function () { $this->expectException(InvalidArgumentException::class); new Task('');})->group('validation');
现在,你可以只运行 validation 组中的测试:
./vendor/bin/pest --group=validation
这在大型项目中运行部分测试时特殊有用。
步骤 6:并行测试 如果你有大量测试,PestPHP 可以并走运行它们,以加快测试过程。只需添加 --parallel 标志:
./vendor/bin/pest --parallel
并行测试可以显著减少运行测试套件的韶光,尤其是在 CI 环境中。
结论PestPHP 不仅仅是 PHPUnit 的一个更俊秀版本。它通过让你的测试更加简洁和表达清晰,供应了一种更愉快的测试体验。在这篇文章中,我们探索了:
为 Task 类编写大略测试。处理边界情形和验证。利用测试组更好地组织测试。利用并行测试加快测试实行。如果你还没有考试测验过 PestPHP,现在是个很好的机遇。无论你是在编写单元测试还是功能测试,PestPHP 都可以帮助你更快、更清晰地编写它们。