【问题标题】:Does phpunit use a different php.ini file than the one configured in MAMP?phpunit 是否使用与 MAMP 中配置的不同的 php.ini 文件?
【发布时间】: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


    【解决方案1】:

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

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

    【讨论】:

      【解决方案2】:

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

      【讨论】:

      • 感谢您的建议。我更改了我的 config_test.yml 文件,覆盖了 config.yml 中的教义:dbal:设置。我将“主机”更改为 127.0.0.1。这给了我一个不同的错误(进度) - PDOException:SQLSTATE [28000] [1045] 用户'tdptk'@'localhost'的访问被拒绝(使用密码:YES)。我需要检查我的数据库以确保可以通过 TCP 访问它吗?
      • 现在似乎工作正常,只是数据库不接受您的凭据。如果您的用户名和密码正确,请检查用户是否可以从 % 访问,而不仅仅是从 localhost
      • 我将 % 主机添加到我的用户(使用 phpmyadmin)。我仍然得到同样的错误。为什么错误会显示用户'tdptk'@'localhost'的访问被拒绝而不是用户'tdptk'@'127.0.0.1'的访问被拒绝?我仍然不清楚为什么我的应用程序通过 phpunit 访问我的数据库的方式与我在浏览器中的应用程序不同..
      猜你喜欢
      • 2010-10-15
      • 1970-01-01
      • 1970-01-01
      • 2012-05-29
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-08-16
      • 2018-12-16
      相关资源
      最近更新 更多