答案:使用 phpUnit 编写 PHP 单元测试需先通过composer 安装并创建测试类 继承 TestCase,以 test 开头的方法作为测试用例,利用 assertEquals 等断言验证结果,配置 phpunit.xml 后可简化执行命令,支持异常、条件等多种断言场景。

编写 PHP 单元测试用例主要依赖于 PHPUnit,这是 PHP 最流行的单元测试框架。它能帮助开发者验证代码的正确性,提升代码质量,尤其是在持续集成环境中非常关键。下面介绍如何使用 PHPUnit 编写和运行测试用例。
安装 PHPUnit
推荐通过 Composer 进行安装,确保项目根目录下有composer.json 文件:
composer require –dev phpunit/phpunit
安装完成后,可以通过以下命令运行测试:
./vendor/bin/phpunit
编写第一个测试用例
假设你有一个简单的类 MathHelper,包含一个加法方法:
立即学习“PHP 免费学习笔记(深入)”;
class MathHelper {
public Static function add($a, $b) {
return $a + $b;
}
}
在 tests 目录下创建对应的测试文件 MathHelperTest.php:
use PHPUnitFrameworkTestCase;
class MathHelperTest extends TestCase
{
public function testAddReturnsSumOfTwoNumbers(): void
{
$result = MathHelper::add(2, 3);
$this->assertEquals(5, $result);
}
}
测试类需继承 TestCase,每个测试方法以 test 开头或使用 @test 注解。assertEquals 用于断言实际值与期望值相等。
运行测试并查看结果
执行以下命令运行测试:
./vendor/bin/phpunit —bootstrap vendor/autoload.php tests/MathHelperTest.php
若测试通过,会显示绿色的“OK”;如果失败,则显示错误信息和具体哪一行出错。可配置 phpunit.xml 来简化命令:
<?xml version=”1.0″ encoding=”UTF-8″?>
<phpunit bootstrap=”vendor/autoload.php”>
<testsuites>
<testsuite name=”application Test Suite”>
<Directory>tests</directory>
</testsuite>
</testsuites>
</phpunit>
之后只需运行。/vendor/bin/phpunit 即可自动发现并执行所有测试。
常用断言方法
PHPUnit 提供丰富的断言方法来验证各种场景:
- $this->assertEquals($expected, $actual):检查两个值是否相等
- $this->assertTrue($condition):判断条件为真
- $this->assertFalse($condition):判断条件为假
- $this->assertNULL($value):检查值是否为 null
- $this->assertContains(‘needle’, $haystack):检查数组或 字符串 是否包含某值
- $this->expectException(Exception::class):验证方法抛出异常
例如测试异常情况:
public function testDivideThrowsExceptionWhenDividingByZero(): void
{
$this->expectException(InvalidArgumentException::class);
MathHelper::divide(5, 0);
}
基本上就这些。掌握 PHPUnit 的基本用法后,可以逐步引入数据提供者、模拟 对象(mock)、覆盖率分析等高级功能,让测试更全面可靠。


