在我的应用程序中,我有使用Sqlite和种子进行测试以涵盖我的功能的测试。因此,我的phpunit env值设置为:
<env name="DB_DEFAULT" value="sqlite" />
但是,我还希望一小部分测试可以查看当前的数据库数据。因此,在1个测试文件中,连接到我的MySQL连接。
这样做的原因是我想检查我的一个表中是否有所有记录的图像,因此测试需要访问最新数据,在这种情况下伪数据将无济于事。
我想我可以使用以下方法进行连接:
$pdo = DB::connection('mysql')->getPdo();
但是,仅当我在此处指定“ sqlite”(即sqlite连接的名称)时,测试才会连接。
我想做的测试不是基于模型的,所以我不想在我的模型文件中内置解决方案,如果可能的话,我想只在这1个测试文件中切换数据库。>
如何配置少量测试以使用其他数据库连接(现有的MySQL连接)?
答案 0 :(得分:1)
所以,我无法连接的原因是因为.env.testing文件中没有DB_值。然后,mysql连接使用的是Laravel配置默认值,因此连接没有出错。
.env.testing
DB_DEFAULT=mysql
DB_HOST=database
DB_NAME=my_database_name
DB_USER=root
DB_PASS=root
添加上面的行即可使所有工作正常,现在我的测试文件可以访问当前的本地数据库。
public function __construct()
{
$this->imgPath = dirname(__FILE__, 3) . '/public/images/';
}
public function testImages()
{
$items = DB::connection('mysql')
->select(DB::raw('SELECT image_filename FROM items')
);
foreach ($items as $item) {
$this->assertFileExists($this->imgPath . $item->image_filename . '.jpg');
}
}