PHP 函数单元测试中常见的陷阱和最佳实践
在 php 单元测试中,避免使用全局变量(陷阱 1)、测试函数副作用(陷阱 2)和处理输入(陷阱 3)至关重要。最佳实践包括使用伪造对象(实践 1)、断言(实践 2)和数据提供者(实践 3)。通过解决陷阱和应用最佳实践,可以编写出更可靠的测试。
PHP 函数单元测试中的陷阱和最佳实践
陷阱
1. 使用全局变量
避免使用全局变量,因为这会使测试难以隔离。使用依赖注入或函数式编程等技术在其函数中传递所需的数据。
2. 测试代码中的副作用
立即学习“PHP免费学习笔记(深入)”;
单元测试应该只测试被测函数,而不是其副作用。例如,如果一个函数修改了全局变量或向数据库写入数据,那么测试应该模拟或隔离这些副作用。
3. 缺乏输入处理
没有正确处理输入的函数测试可能会导致失败。确保函数接收预期的输入类型,并且处理非法或意外输入。
最佳实践
1. 使用伪造对象 (Stub)
使用伪造对象来模拟函数的依赖项。这使你可以隔离函数并测试其与依赖项的交互。
2. 使用断言
使用断言如 assertEquals() 和 assertEmpty() 来明确测试输出的期望值。这使错误消息更清晰,并且可以发现模糊的输出差异。
3. 使用数据提供者
使用数据提供者来为函数提供多个输入。这简化了测试不同输入组合,并可以快速识别边缘情况。
实战案例
考虑以下 sum() 函数:
function sum(int $a, int $b) { return $a + $b;}
以下单元测试将带来我们讨论过的陷阱:
class SumTest extends PHPUnitFrameworkTestCase { public function testSum() { $result = sum(1, 2); $this->assertEquals(3, $result); }}
通过修复陷阱并应用最佳实践,我们可以编写出更好的测试:
class SumTest extends PHPUnitFrameworkTestCase { public function sumData() { return [ [1, 2, 3], [-1, 0, -1], [0.1, 0.2, 0.3] ]; } /** * @dataProvider sumData */ public function testSum(int $a, int $b, int $expected) { $result = sum($a, $b); $this->assertEquals($expected, $result); }}