我正在尝试在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]没有这样的文件或目录”错误。
更新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。而现在我做不到。奇怪的是 - 网络应用程序仍可通过网络浏览器正常连接。
这让我回到原始问题的核心。为什么我的应用程序通过Web浏览器成功连接到数据库,而不是通过phpunit?
还有其他有用的提示吗?
答案 0 :(得分:3)
phpunit是否使用与MAMP中配置的文件不同的php.ini文件?
是的,PHP的命令行版本通常有自己的php.ini
版本。运行php -i
以获取phpinfo并查看在那里使用的INI。
答案 1 :(得分:1)
要在本地计算机上使用TCP,您必须在new PDO("mysql:host=127.0.0.1;.....");
中使用127.0.0.1作为主机名而不是localhost