使用PHPUnit对PHP函数进行单元测试,需先通过Composer安装并创建被测函数,如Calculator类的add方法;接着在tests目录下编写测试类CalculatorTest,利用setUp初始化对象,通过testAdd等方法结合assertEquals断言验证正常、边界及负数情况;可使用expectException检测异常,结合@dataProvider提供多组输入数据以提高覆盖率;最后运行./vendor/bin/phpunit执行测试,确保代码行为符合预期,提升代码质量与重构信心。

对PHP函数做单元测试,核心是使用测试框架验证函数在各种输入下的行为是否符合预期。最常用的是PHPUnit,它是PHP社区事实上的标准测试工具。下面从环境搭建到实战一步步说明如何为PHP函数写单元测试。
安装PHPUnit
推荐通过Composer安装PHPUnit,确保项目根目录有composer.json文件:
composer require --dev phpunit/phpunit
安装完成后,可以通过以下命令运行测试:
./vendor/bin/phpunit
编写被测函数
假设我们有一个简单的数学函数,用于计算两个数的和:
立即学习“PHP免费学习笔记(深入)”;
// src/Calculator.php<?phpclass Calculator{ public function add($a, $b) { return $a + $b; }}
编写对应的测试类
在tests目录下创建测试文件:
// tests/CalculatorTest.php<?phpuse PHPUnitFrameworkTestCase;class CalculatorTest extends TestCase{private $calculator;
protected function setUp(): void{ $this->calculator = new Calculator();}public function testAddReturnsSumOfTwoNumbers(){ $result = $this->calculator->add(2, 3); $this->assertEquals(5, $result);}public function testAddHandlesNegativeNumbers(){ $result = $this->calculator->add(-1, 1); $this->assertEquals(0, $result);}public function testAddWithZero(){ $result = $this->calculator->add(0, 0); $this->assertEquals(0, $result);}
}
每个测试方法都以test开头,使用断言(如assertEquals)来验证输出是否符合预期。
运行测试并查看结果
执行命令:
./vendor/bin/phpunit tests/CalculatorTest.php
如果所有断言通过,你会看到绿色的OK提示;如果有失败,会显示具体哪一行出错以及期望值与实际值的差异。
测试异常情况
如果函数可能抛出异常,可以用expectException指定预期异常类型:
public function testDivideByZeroThrowsException(){ $this->expectException(InvalidArgumentException::class); $this->calculator->divide(10, 0);}
数据提供者(DataProvider)
当需要对同一函数用多组数据测试时,可用@dataProvider注解:
/** * @dataProvider additionProvider */public function testAddWithMultipleData($a, $b, $expected){ $this->assertEquals($expected, $this->calculator->add($a, $b));}public function additionProvider(){return [[2, 3, 5],[-1, 1, 0],[0, 0, 0],[100, 200, 300]];}
基本上就这些。写好单元测试能帮你尽早发现bug,重构代码时更有信心。关键是保持测试独立、可重复,并覆盖正常、边界和异常情况。
以上就是PHP函数单元测试怎么做_PHP函数单元测试实战的详细内容,更多请关注php中文网其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1322930.html
微信扫一扫
支付宝扫一扫