[英]While running laravel phpunit testcase , i'm getting an error "Call to a member function connection() on null" in Model.php line 1249
I'm running laravel phpunit testcase, getting error in DB connection.我正在运行 laravel phpunit 测试用例,在数据库连接中出错。 DB connected successfully.数据库连接成功。 But,但,
"Call to a member function connection() on null" - Could not open to database connection server. “在 null 上调用成员函数 connection()”- 无法打开数据库连接服务器。 Please update the configuration settings.请更新配置设置。
I did all those things properly.我正确地做了所有这些事情。 Find below details:查找以下详细信息:
"php" : ">=7.1.3",
"laravel/lumen-framework": "5.8.*",
"phpunit/phpunit" : "^7.0",
"phpunit/php-invoker" : "*",
"phpunit/dbunit" : "^4.0",
This would be a bit of a guess without seeing your phpunit.xml
configuration but I suspect you need to specify a connection for testing.如果没有看到您的phpunit.xml
配置,这可能有点猜测,但我怀疑您需要指定一个连接进行测试。
If you check your php unit file you should have some values like below in your php
property.如果你检查你的 php 单元文件,你应该在你的php
属性中有如下一些值。 Setting the DB_CONNECTION to sqlite
and DB_DATABASE to :memory:
is a fast and light-weight way to configure your testing DB.将 DB_CONNECTION 设置为sqlite
并将 DB_DATABASE 设置为:memory:
是配置测试数据库的一种快速且轻量级的方法。
<php>
<server name="APP_ENV" value="testing"/>
<server name="BCRYPT_ROUNDS" value="4"/>
<env name="DB_CONNECTION" value="sqlite"/>
<env name="DB_DATABASE" value=":memory:"/>
<server name="CACHE_DRIVER" value="array"/>
<server name="MAIL_DRIVER" value="array"/>
<server name="QUEUE_CONNECTION" value="sync"/>
<server name="SESSION_DRIVER" value="array"/>
</php>
If you do have similar values in your phpunit.xml
file then you will need to check your config/database.php
file and ensure the connection matching your DB_CONNECTION has a sensible configuration.如果您的phpunit.xml
文件中确实有类似的值,那么您将需要检查您的config/database.php
文件并确保与您的 DB_CONNECTION 匹配的连接具有合理的配置。
The default values for sqlite
should work fine and are as follows: sqlite
的默认值应该可以正常工作,如下所示:
'sqlite' => [
'driver' => 'sqlite',
'database' => env('DB_DATABASE', database_path('database.sqlite')),
'prefix' => '',
'foreign_key_constraints' => env('DB_FOREIGN_KEYS', true),
],
Hope this helps.希望这可以帮助。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.