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

标签 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] 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的。现在我不能。奇怪的是 - 网络应用程序仍然可以通过网络浏览器正常连接。

这让我回到了最初问题的核心。为什么我的应用程序通过网络浏览器成功连接到数据库,而不是通过 phpunit?

还有其他有用的提示吗?

最佳答案

Does phpunit use a different php.ini file than the one configured in MAMP?

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

关于php - phpunit 是否使用与 MAMP 中配置的不同的 php.ini 文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19568569/

相关文章:

php - 如何从 laravel 的菜单中获取餐厅的平均价格?

php - PDO 代码不起作用

Mysql - 如何获取varchar列的最大值

php - Symfony2 + Doctrine 关联错误 : Class Game has no association named home

javascript - Symfony:通过 GET 将变量从 Ajax 发送到处理程序

javascript - Response 的数据部分是一个长脚本而不是所需的 json 对象

javascript - 根据查询设置html按钮状态

php - 使用 Polylang 插件在 WordPress 网站上切换不同语言的页脚

mysql查询;重命名单列中的 2 个值

php - Firebase SDK 管理 Symfony - 服务帐户无效 : The file at does not exist