我现在一直在挖掘几个小时,但我找不到通过多个单元测试回收单个PDO连接(MySQL)的方法。有这样的动物吗?
似乎我应该在引导程序中以某种方式声明它,但PDO连接无法序列化,因此测试会中断。
我想在很多表中针对模式测试数据集,所以我不想每次都在数据库中查找新连接。
答案 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
,因为他们是通过反思来调用的。