首页 > 解决方案 > 用于测试和实际数据库的 PHP Laravel SQLite

问题描述

我想将 Sqlite 驱动程序用于测试数据库和实际数据库。我的.env文件是:

DB_CONNECTION=sqlite

没关系,我可以将 sqlite 用于实际数据库并进行测试,我在config/database.php的连接数组下定义了类似的内容:

'testing' => [
    'driver' => 'sqlite',
    'url' => env('DATABASE_URL'),
    'database' => env('DB_DATABASE', database_path('test.sqlite')),
    'prefix' => '',
    'foreign_key_constraints' => env('DB_FOREIGN_KEYS', true),
],

'sqlite' => [
    'driver' => 'sqlite',
    'url' => env('DATABASE_URL'),
    'database' => env('DB_DATABASE', database_path('database.sqlite')),
    'prefix' => '',
    'foreign_key_constraints' => env('DB_FOREIGN_KEYS', true),
],

我的phpunit.xml配置也像:

<php>
      <server name="APP_ENV" value="testing"/>
      <server name="BCRYPT_ROUNDS" value="4"/>
      <server name="CACHE_DRIVER" value="array"/>
      <server name="DB_CONNECTION" value="testing"/>
      <server name="DB_DATABASE" value=":memory:"/>
      <server name="MAIL_MAILER" value="array"/>
      <server name="QUEUE_CONNECTION" value="sync"/>
      <server name="SESSION_DRIVER" value="array"/>
      <server name="TELESCOPE_ENABLED" value="false"/>
</php>

然而它仍然使用我的实际数据库进行测试,我尝试在互联网上用不同的方式配置 database.php 和 phpunit.xml,但它仍然无法正常工作。

示例就像使用 mysql 作为实际,使用 sqlite 进行测试,但我想对它们都使用 sqlite。

标签: phplaravelsqlitetesting

解决方案


如果要testing.sqlite用于测试,请注释掉<server name="DB_DATABASE" value=":memory:"/>

因此,您甚至可以使用内存数据库进行测试。

我刚刚测试了两个:

<server name="DB_DATABASE" value=":memory:"/>它在内存中运行

注释掉<server name="DB_DATABASE" value=":memory:"/>它使用database_path('testing.sqlite')

即使使用也没有遇到错误RefreshDatabase

我的 .env 文件的数据库相关条目如下

DB_CONNECTION=sqlite
# DB_DATABASE=database.sqlite
# DB_CONNECTION=mysql
# DB_HOST=127.0.0.1
# DB_PORT=3306
# DB_DATABASE=l8x
# DB_USERNAME=root
# DB_PASSWORD=

phpunit.xml

<php>
    <server name="APP_ENV" value="testing"/>
    <server name="BCRYPT_ROUNDS" value="4"/>
    <server name="CACHE_DRIVER" value="array"/>
    <server name="DB_CONNECTION" value="testing"/>
    <!-- <server name="DB_DATABASE" value=":memory:"/> -->
    <server name="MAIL_MAILER" value="array"/>
    <server name="QUEUE_CONNECTION" value="sync"/>
    <server name="SESSION_DRIVER" value="array"/>
    <server name="TELESCOPE_ENABLED" value="false"/>
</php>

推荐阅读