PHP 单元测试:如何避免代码重复?

wufei1232024-06-10PHP47

避免单元测试代码重复的策略:使用助手函数提取重复任务,例如检查数组是否存在特定值。提取共用逻辑到父类,例如初始化和清理资源。使用数据提供者自动执行对多个输入的测试。

PHP 单元测试:如何避免代码重复?

PHP 单元测试:避免代码重复的实用指南

在编写单元测试时,代码重复是一个常见的陷阱。以下是避免这种情况的一些策略:

使用助手函数

助手函数可以将重复的任务提取到独立的模块中,例如:

function assertArrayContains($array, $value)
{
    if (!in_array($value, $array)) {
        throw new \PHPUnit\Framework\AssertionFailedError('Array does not contain value');
    }
}

实战案例

假设我们有一个函数 calculateTotal(), 它需要一个包含价格的数组。创建一个助手函数来确保数组不为空:

class OrderTest extends \PHPUnit\Framework\TestCase
{
    public function testCalculateTotal()
    {
        $prices = [];

        // 断言数组不为空的简化方法
        assertArrayContains($prices);
    }
}

提取共用逻辑到父类

当多个测试用例具有相似的设置和清理逻辑时,可以将它们提取到父类中,例如:

class BaseTestCase extends \PHPUnit\Framework\TestCase
{
    public function setUp(): void
    {
        // 设置共同的资源
    }

    public function tearDown(): void
    {
        // 清除共同的资源
    }
}

实战案例

如果我们的测试用例都需要访问数据库,我们可以创建一个父类来管理连接:

class DatabaseTestCase extends BaseTestCase
{
    protected $connection;

    public function setUp(): void
    {
        // 建立数据库连接
        $this->connection = new \PDO(DSN, USER, PASSWORD);
    }

    public function tearDown(): void
    {
        // 关闭数据库连接
        $this->connection = null;
    }
}

使用数据提供者

数据提供者允许为多个输入设置自动化测试,例如:

/**
 * @dataProvider additionProvider
 */
public function testAdd(int $a, int $b, int $expected)
{
    // 测试加法函数
}

public function additionProvider(): array
{
    return [
        [0, 0, 0],
        [1, 1, 2],
        [-1, -1, -2],
    ];
}

实战案例

假设我们有一个函数 verifyEmail(),需要验证有效的和无效的电子邮件地址:

/**
 * @dataProvider emailDataProvider
 */
public function testVerifyEmail(string $email, bool $expected)
{
    // 断言电子邮件地址的有效性
}

public function emailDataProvider(): array
{
    return [
        ['john@example.com', true],
        ['invalid@example', false],
    ];
}

通过应用这些策略,您可以减少代码重复,提高单元测试的维护性和可读性。

以上就是PHP 单元测试:如何避免代码重复?的详细内容,更多请关注知识资源分享宝库其它相关文章!

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。