【发布时间】:2013-11-03 07:35:10
【问题描述】:
我正在尝试使用 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 重新安装它~Installing PHPUnit on MAMP 2.1.3 (Mountain Lion).
所以现在我用 bin/phpunit 运行我的 phpunit 命令。
仍然 - 结果没有变化。我仍然收到“PDO::__construct(): [2002] No such file or directory”错误。
更新 II
正如我在下面提到的 - 响应 @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。而现在我不能。奇怪的是 - 网络应用仍然可以通过网络浏览器正常连接。
这让我回到了最初问题的核心。为什么我的应用程序通过网络浏览器成功连接到数据库,而不是通过phpunit?
还有其他有用的提示吗?
【问题讨论】:
标签: php mysql symfony phpunit mamp