我正在尝试在LAravel 5中运行 PHPunit 测试以访问(' /'),但是它失败并显示以下消息: (我的应用程序在docker container http://www.spiralout.eu/2015/12/dockervel-laravel-development.html 中运行)
class MyTest extends TestCase
{
/**
* A basic test example.
*
* @return void
*/
public function testExample()
{
$this->assertTrue(true);
}
public function providerAllUrisWithResponseCode()
{
return [
['/', 200],
['/thank', 200],
['/non-existing', 404],
];
}
public function testDisplayThankYou($value='')
{
$this->visit('/thankyou')
->see('Thank you!');
}
public function testPageControllerGet()
{
$this->call('GET', '/');
}
public function testDisplayWelcome($value='')
{
$this->visit('/')
->see('Welcome');
}
}
我收到此错误。
$vendor/bin/phpunit
PHPUnit 4.8.26 by Sebastian Bergmann and contributors.
...F
Time: 24.01 seconds, Memory: 16.00MB
There was 1 failure:
1) MyTest::testDisplayWelcome
A request to [http://localhost] failed. Received status code [500].
..vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithPages.php:196
..vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithPages.php:80
..vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithPages.php:61
.../www/tests/ExampleTest.php:16
Caused by
exception 'PDOException' with message 'SQLSTATE[HY000] [2005] Unknown MySQL server host 'mysql' (2)'
in ../vendor/laravel/framework/src/Illuminate/Database/Connectors/Connector.php:55
我的behat功能通过了! 我的.env。*文件看起来像:
.env
DB_CONNECTION=mysql
DB_HOST=mysql
DB_PORT=3306
DB_DATABASE=homestead
DB_USERNAME=homestead
DB_PASSWORD=secret
.env.behat
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=homestead
DB_USERNAME=homestead
DB_PASSWORD=secret
另外:如果我删除或更改.env.behat中的DB_HOST = 127.0.0.1并运行behat它会返回错误!
Connector.php 中的第50行说:
public function createConnection($dsn, array $config, array $options)
{
**here it breaks**--> $username = Arr::get($config, 'username');
$password = Arr::get($config, 'password');
try {
$pdo = new PDO($dsn, $username, $password, $options);
} catch (Exception $e) {
$pdo = $this->tryAgainIfCausedByLostConnection(
$e, $dsn, $username, $password, $options
);
}
return $pdo;
}
例如,当我运行DB :: table('某些') - > get();它工作正常。
有人看到了这个问题吗?
答案 0 :(得分:1)
在.env.behat
上,您应该使用mysql
作为主机名。它是通过码头工具链接,名称不是127.0.0.1
.env.behat
DB_CONNECTION=mysql
DB_HOST=mysql
DB_PORT=3306
DB_DATABASE=homestead
DB_USERNAME=homestead
DB_PASSWORD=secret