我正在尝试使用 Symfony2 中的 phpunit 运行一些功能测试。当我运行我的测试时,我得到这个错误:
PDO::__construct(): [2002] No such file or directory (trying to connect via unix:///var/mysql/mysql.sock)
我假设 phpunit 找不到我的 mysql 套接字,尽管我已经在我的 php.ini 文件(在 MAMP 中)中设置了它。我的 Web 应用程序在我的浏览器中运行良好并成功连接到数据库。
我尝试将此设置添加到我的 phpunit.xml.dist 文件中,但得到相同的结果:
<php>
<ini name="mysql.default_socket" value="/Applications/MAMP/tmp/mysql/mysql.sock"/>
<!--<server name="KERNEL_DIR" value="/path/to/your/app/" />-->
</php>
有没有办法验证/更改 phpunit 正在使用的 php.ini 文件?
如果这不是问题,那么让我们回到第一方。这是我运行的测试:
class VBMTest extends WebTestCase
{
var $container;
public function setUp()
{
$client = static::createClient();
$client->getKernel()->boot();
$this->container = $client->getContainer();
}
public function testNameNotFound()
{
$form = array('lastname'=>'Jones','sex'=>'F','day'=>'5','month'=>'5','year'=>'2005');
$vbm = $this->container->get('tk.vbm');
$vbm->init($form, 'process_app');
$step = $vbm->getStep();
$this->assertEquals(
'register',
$step
);
}
}
我添加了这一行,以防测试应用程序没有加载我的所有参数。(我是 Symfony2 测试的新手。)
$client->getKernel()->boot();
config_test.yml 导入 config_dev.yml,所以我不明白为什么我的数据库设置不会包含在我的测试配置中。
更新
我尝试卸载 phpunit 并使用 Composer 重新安装它,如此处所述〜在 MAMP 2.1.3 (Mountain Lion) 上安装 PHPUnit。
所以现在我用 bin/phpunit 运行我的 phpunit 命令。
仍然 - 结果没有变化。我仍然收到“PDO::__construct(): [2002] No such file or directory”错误。
更新二
正如我在下面提到的 - 响应 @Udan 的建议 - 我更改了 config_test.yml 文件中的配置设置,将主机更改为 127.0.0.1:
doctrine:
dbal:
driver: pdo_mysql
host: 127.0.0.1
port: 3306
dbname: test_tk
user: test_tk
password: ############
charset: UTF8
我什至添加了一个新用户和一个用于测试的新数据库(test_tk)。错误发生了变化,但我仍然无法测试我的应用程序。
ERROR 1045 (28000): Access denied for user 'test_tk'@'localhost' (using password: YES)
这是 phpmyadmin 中我的用户权限的概要:
User: test_tk
Host: %
Type: global
Privileges: All Privileges
Grant: Yes
我的 mysql 安装发生了一些奇怪的事情。我以前可以通过命令行连接到mysql。而现在我不能。奇怪的是 - 网络应用程序仍然可以通过网络浏览器正常连接。
这让我回到了最初问题的核心。为什么我的应用程序通过 Web 浏览器成功连接到数据库,而不是通过 phpunit?
还有其他有用的提示吗?