首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PHPUnit复用PDO连接

PHPUnit复用PDO连接
EN

Stack Overflow用户
提问于 2013-09-17 06:53:58
回答 1查看 1.1K关注 0票数 2

我已经挖了几个小时了,但是我找不到在多个单元测试中回收单个PDO连接(MySQL)的方法。有这样的动物吗?

似乎我应该在引导程序中声明它,但是PDO连接不能序列化,所以测试中断。

我希望在很多表中针对模式测试数据集,所以我不希望每次都访问数据库以获得新的连接。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-09-17 07:10:18

我的简短回答是:不要,只需在测试您的DB相关代码的类中创建一个连接。

另一个选项是创建一个静态setUpBeforeClass,它将连接分配给另一个静态属性:

代码语言:javascript
复制
public static function setUpBeforeClass()
{
    self::$connection = new \PDO($dsn, $usr, $pwd, array());
}

这是一种有效的方法,您在使用文献资料时应该会遇到这种情况。当然,由于连接是静态的,所以可以从全局范围访问它,并且最好是按顺序关闭。这是使用tearDownAfterClass方法完成的(同样,public static是必需的):

代码语言:javascript
复制
public static function tearDownAfterClass()
{
    self::$connection->rollBack();//? if required
    self::$connection = null;
}

将这些方法看作是构造函数和析构函数。它们的签名必须是public static,因为它们是通过反射调用的。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18843129

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档