我已经挖了几个小时了,但是我找不到在多个单元测试中回收单个PDO连接(MySQL)的方法。有这样的动物吗?
似乎我应该在引导程序中声明它,但是PDO连接不能序列化,所以测试中断。
我希望在很多表中针对模式测试数据集,所以我不希望每次都访问数据库以获得新的连接。
发布于 2013-09-17 07:10:18
我的简短回答是:不要,只需在测试您的DB相关代码的类中创建一个连接。
另一个选项是创建一个静态setUpBeforeClass,它将连接分配给另一个静态属性:
public static function setUpBeforeClass()
{
self::$connection = new \PDO($dsn, $usr, $pwd, array());
}这是一种有效的方法,您在使用文献资料时应该会遇到这种情况。当然,由于连接是静态的,所以可以从全局范围访问它,并且最好是按顺序关闭。这是使用tearDownAfterClass方法完成的(同样,public static是必需的):
public static function tearDownAfterClass()
{
self::$connection->rollBack();//? if required
self::$connection = null;
}将这些方法看作是构造函数和析构函数。它们的签名必须是public static,因为它们是通过反射调用的。
https://stackoverflow.com/questions/18843129
复制相似问题