【发布时间】:2019-02-08 19:05:51
【问题描述】:
每次我运行测试时,我的所有数据库表(迁移表除外)都会被删除,我必须再次运行迁移。例如,如果我有以下表格:
migrations
users
tableA
tableB
运行后:
phpunit --filter user_can_view_a_record ViewRecordTest 测试/功能/ViewRecordTest.php
我的表被删除了,最后我只得到了迁移表。
我使用 MySQL 作为数据库,根据我设置的配置,测试正在内存中运行:
数据库.php
'connections' => [
'sqlite' => [
'driver' => 'sqlite',
//'database' => env('DB_DATABASE', database_path('database.sqlite')),
'database' => ':memory:',
'prefix' => '',
],
'mysql' => [
'driver' => 'mysql',
'host' => env('DB_HOST', '127.0.0.1'),
'port' => env('DB_PORT', '3306'),
'database' => env('DB_DATABASE', 'forge'),
'username' => env('DB_USERNAME', 'forge'),
'password' => env('DB_PASSWORD', ''),
'unix_socket' => env('DB_SOCKET', ''),
'charset' => 'utf8mb4',
'collation' => 'utf8mb4_unicode_ci',
'prefix' => '',
'strict' => false,
'engine' => null,
'sticky' => true
],
]
phpunit.xml
<?xml version="1.0" encoding="UTF-8"?>
<phpunit backupGlobals="false"
backupStaticAttributes="false"
bootstrap="vendor/autoload.php"
colors="true"
convertErrorsToExceptions="true"
convertNoticesToExceptions="true"
convertWarningsToExceptions="true"
processIsolation="false"
stopOnFailure="false">
<testsuites>
<testsuite name="Feature">
<directory suffix="Test.php">./tests/Feature</directory>
</testsuite>
<testsuite name="Unit">
<directory suffix="Test.php">./tests/Unit</directory>
</testsuite>
</testsuites>
<filter>
<whitelist processUncoveredFilesFromWhitelist="true">
<directory suffix=".php">./app</directory>
</whitelist>
</filter>
<php>
<env name="APP_ENV" value="testing"/>
<env name="CACHE_DRIVER" value="array"/>
<env name="SESSION_DRIVER" value="array"/>
<env name="QUEUE_DRIVER" value="sync"/>
<env name="DB_CONNECTION" value="sqlite" />
<env name="DB_DATABASE" value=":memory:" />
</php>
</phpunit>
谢谢
【问题讨论】:
-
这是什么 Laravel 版本?
-
Laravel 版本:5.5
-
不能升级到5.6吗?还是更好地掌握? (5.7 很快就会发布)。你用
Illuminate\Foundation\Testing\RefreshDatabase;吗?如文件所述? laravel.com/docs/5.5/… -
另外写一个只显示当前环境的测试是
testing吗?我认为 phpunit.xml 没有被使用。您可以通过dd(app()->environment());进行操作。 -
对不起,我刚刚查过了。不是5.5而是5.6。我跑了 dd(app()->environment());正如你所建议的那样,我得到了“本地”