2

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

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

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 数据库中的证明。

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

4

0 回答 0