PHP前端开发

PHP 函数单元测试中常见的陷阱和最佳实践

百变鹏仔 1天前 #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);  }}