PHPUnit重用PDO连接

时间:2013-09-17 06:53:58

标签: php mysql pdo phpunit persistent-connection

我现在一直在挖掘几个小时,但我找不到通过多个单元测试回收单个PDO连接(MySQL)的方法。有这样的动物吗?

似乎我应该在引导程序中以某种方式声明它,但PDO连接无法序列化,因此测试会中断。

我想在很多表中针对模式测试数据集,所以我不想每次都在数据库中查找新连接。

1 个答案:

答案 0 :(得分:3)

我的简短回答是:不要,只需在类中创建一个测试与数据库相关的代码的连接。
另一种选择是创建一个静态setUpBeforeClass,将连接分配给另一个静态属性:

public static function setUpBeforeClass()
{
    self::$connection = new \PDO($dsn, $usr, $pwd, array());
}

这是一种有效的方法,您应该在挖掘the documentation时遇到这种方法。当然,由于连接是 static ,因此可以从全局范围访问它,并且最好是manully关闭。这是使用tearDownAfterClass方法完成的(同样需要public static):

public static function tearDownAfterClass()
{
    self::$connection->rollBack();//? if required
    self::$connection = null;
}

将这些方法视为构造函数和析构函数。他们的签名 public static,因为他们是通过反思来调用的。