3

我正在尝试使用 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?

还有其他有用的提示吗?

4

2 回答 2

4

phpunit 是否使用与 MAMP 中配置的不同的 php.ini 文件?

是的,PHP 的命令行版本通常有它自己的php.ini. 运行php -i以获取 phpinfo 并查看其中使用了哪个 INI。

于 2013-10-24T23:44:59.077 回答
1

要在本地计算机上使用 TCP,您必须使用 127.0.0.1 作为主机名,而不是 localhostnew PDO("mysql:host=127.0.0.1;.....");

于 2013-10-24T16:31:17.320 回答