在内存中使用sqlite进行功能测试

时间:2012-09-17 17:55:41

标签: php sqlite symfony1 doctrine phpunit

我知道已经存在一些关于此问题的主题,但我无法得到任何具体答案。

我已经在单元测试的内存数据库中使用:

Doctrine_Core::createTablesFromModels(sfConfig::get('sf_lib_dir').'/model');
Doctrine_Core::loadData(sfConfig::get('sf_test_dir').'/phpunit/fixtures');

但这不适用于功能测试。 总是说:no such table: user.

但如果使用此StepUp运行测试:

    Doctrine_Core::createTablesFromModels(sfConfig::get('sf_lib_dir').'/model');
    Doctrine_Core::loadData(sfConfig::get('sf_test_dir').'/phpunit/fixtures');
    Doctrine_Core::loadData(sfConfig::get('sf_test_dir').'/phpunit/fixtures');

将提供异常:“Doctrine_Connection_Sqlite_Exception:完整性约束违规:19列用户名不是唯一的”,这是有道理的,因为用户名必须是唯一的,并且是将数据加载到内存中的sqlite数据库的证据。 / p>

我怀疑当浏览器发出请求时,它会在内存中为SQLite数据库创建一个新连接,而不是使用当前打开的CLI。

0 个答案:

没有答案