使用phpunit在Laravel中测试多个数据库

时间:2019-12-17 21:46:57

标签: laravel testing phpunit database-connection

在我的应用程序中,我有使用Sqlite和种子进行测试以涵盖我的功能的测试。因此,我的phpunit env值设置为:

<env name="DB_DEFAULT" value="sqlite" />

但是,我还希望一小部分测试可以查看当前的数据库数据。因此,在1个测试文件中,连接到我的MySQL连接。

这样做的原因是我想检查我的一个表中是否有所有记录的图像,因此测试需要访问最新数据,在这种情况下伪数据将无济于事。

我想我可以使用以下方法进行连接:

$pdo = DB::connection('mysql')->getPdo();

但是,仅当我在此处指定“ sqlite”(即sqlite连接的名称)时,测试才会连接。

我想做的测试不是基于模型的,所以我不想在我的模型文件中内置解决方案,如果可能的话,我想只在这1个测试文件中切换数据库。

如何配置少量测试以使用其他数据库连接(现有的MySQL连接)?

1 个答案:

答案 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');
    }
}