如何使用PHPUnit插入特定于测试用例的数据库行

前端之家收集整理的这篇文章主要介绍了如何使用PHPUnit插入特定于测试用例的数据库行前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
当使用 PHPUnit测试依赖于数据库的类时,getDataSet()方法提供数据作为整个测试套件的测试夹具.这很好,但是如何为特定测试提供数据?特别是在使用最小化数据集时,每个测试需要在所有测试使用的公共数据之上使用不同的数据库数据,这并不罕见.我知道PDO对象是可用的,在我们的例子中,应用程序的本机数据库对象也可用(意思是,我们可以在应用程序中运行原始查询或使用其他功能),但是有一种方法可以插入数据这是由PHPUnit的DataSet容器驱动的,因此所有测试数据都以相同的方式处理,以提高清晰度并简化维护.

有没有办法实现这个目标?

这是一个迟到的答案,但它对某些人来说仍然有用我想…

您可以通过调用IDatabaSEOperation的execute方法来完成此操作,您可以从PHPUnit_Extensions_Database_Operation_Factory获取方法.你基本上会使用CLEAN_INSERT或INSERT.

作为zerkms’ second approach,您可以在每个需要特定数据的测试开始时调用它.例如:

public function testA() {
  PHPUnit_Extensions_Database_Operation_Factory::INSERT()
    ->execute($this->getConnection(),$this->createXMLDataSet(__DIR__.'/fixtureA.xml'));

  // Test code
}

但是,此解决方案的优点是整个测试用例的数据集保持不变,因此:

>测试方法保持彼此独立(而在zerkms方法中,如果您没有/忘记在另一个测试方法中指定数据集,它将重用更改数据集的先前(随机?)方法的数据集,是非常丑陋和非常容易出错的恕我直言.在这里,任何其他没有这种调用的测试都会像往常一样使用测试用例数据集.>您可以在公共(测试用例)数据集之上构建测试数据集.如果使用INSERT操作(不是CLEAN_INSERT),它将在公共数据集的所有行之后插入特定于测试的行.您还可以使用DELETE操作从该公共数据集中删除一些不需要的行.> BTW,即使测试用例的设置操作已经改变,也不会调用onSetUp()使其工作.

猜你在找的PHP相关文章