gpt4 book ai didi

php - Laradock 单元测试数据库错误 PDOException

转载 作者:行者123 更新时间:2023-11-29 07:29:01 25 4
gpt4 key购买 nike

所以我正在尝试为这样的 Laravel 应用程序编写单元测试:

protected function setUp()
{
parent::setUp();
$this->disableMiddlewareForAllTests();
$this->withoutExceptionHandling();
}

public function test_login_badRequest()
{
$response = $this->call('post', '/login');
$response->assertOk();
$response->assertJson(['status' => 400]);
}

上面的工作正常,并给出了这个输出:

Test 'Tests\Unit\LoginTest::test_login_badRequest' started
Test 'Tests\Unit\LoginTest::test_login_badRequest' ended
Time: 69 ms, Memory: 12.00MB
OK (1 test, 2 assertions)

但是接下来的测试就是另外一回事了:

public function test_login_goodRequest()
{
$response = $this->call('post', '/login', [
'email' => 'email@email.com',
'password' => 'P4ssw0rd'
]);

$response->assertOk();
$response->assertJson(['status' => 200]);
}

一旦测试命中应用程序中的这行代码:

/* Retrieve User associated with posted email address */
$user = $this->userModel
->where('email', $request->post('email'))
->get();
die('here');// <-- Happens in browser, does not happen in tests.

这是错误:

1) Tests\Unit\LoginTest::test_login_goodRequest
PDOException: SQLSTATE[HY000] [2002] php_network_getaddresses: getaddrinfo failed: Name or service not known
/var/www/html/projects/laravel-template/vendor/laravel/framework/src/Illuminate/Database/Connectors/Connector.php:68 ...

几天来我一直在努力解决这个问题,知道这里发生了什么,以及如何在测试中打印该模具吗?干杯。

-- Laradock, Docker, nginx, mysql,PHP 7.2.4-1+ubuntu16.04.1+deb.sury.org+1 (cli)(内置:2018 年 4 月 5 日 08:53:57)(NTS)版权所有 (c) 1997-2018 The PHP GroupZend Engine v3.2.0,版权所有 (c) 1998-2018 Zend Technologies 使用 Zend OPcache v7.2.4-1+ubuntu16.04.1+deb.sury.org+1,版权所有 (c) 1999-2018,Zend Technologies

编辑:

.环境:

APP_NAME=Laravel
APP_ENV=local
APP_KEY=base64:Z+p6uA3G2DyCCFBXOPgrWwls1U6z/vi8Zi2r4eKHxEY=
APP_DEBUG=true
DEBUGBAR_ENABLED=true
APP_URL=http://localhost

LOG_CHANNEL=stack

DB_CONNECTION=mysql
DB_HOST=mysql
DB_PORT=3306
DB_DATABASE=sample_database
DB_USERNAME=root
DB_PASSWORD=root

BROADCAST_DRIVER=log
CACHE_DRIVER=file
SESSION_DRIVER=file
SESSION_LIFETIME=120
QUEUE_DRIVER=sync

REDIS_HOST=127.0.0.1
REDIS_PASSWORD=null
REDIS_PORT=6379

MAIL_DRIVER=smtp
MAIL_HOST=smtp.gmail.com
MAIL_PORT=587
MAIL_USERNAME=
MAIL_PASSWORD=
MAIL_ENCRYPTION=tls

PUSHER_APP_ID=
PUSHER_APP_KEY=
PUSHER_APP_SECRET=
PUSHER_APP_CLUSTER=mt1

MIX_PUSHER_APP_KEY="${PUSHER_APP_KEY}"
MIX_PUSHER_APP_CLUSTER="${PUSHER_APP_CLUSTER}"

最佳答案

在聊天中我们发现您正在从您的主机运行测试。可以从主机运行测试,但您必须将端口暴露给主机。我认为 laradock 可以做到这一点,但我不确定你是否在你的设置中有它(github 版本有)。虽然,这是一个 docker 反模式。

容器旨在包含它们之间以及来自主机的所有通信,您应该只进行updown

因此,最好的解决方案是使用 docker exec -it workspace bashdocker-compose exec workspace bash 进入你的 workspace 容器,然后从那里运行测试。

关于php - Laradock 单元测试数据库错误 PDOException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52455914/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com