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

时间:2013-10-24 14:20:41

标签: php mysql symfony phpunit mamp

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

还有其他有用的提示吗?

2 个答案:

答案 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