来自PHPUnit的奇怪输出

时间:2013-06-20 15:56:45

标签: windows unit-testing phpunit

我已经通过PEAR安装了PHPUnit,并且我已经安装了WordPress插件测试(https://github.com/tierra/wordpress-plugin-tests)来测试正在开发的WordPress插件。

当测试运行正常时,我得到以下输出:

Running as single site... To run multisite, use -c multisite.xml
Not running ajax tests... To execute these, use --group ajax.
PHPUnit 3.7.21 by Sebastian Bergmann.

Configuration read from E:\LocalWebServer\dch\c\my-wp-installtion.dch\wordpress-test\wordpress\wp-content\plugins\myplugin\phpunit.xml

[41;37mF[0m.[36;1mS[0m

Time : 1 second, Memory: 30.50Mb

There was 1 failure:

1) CDOAjax_Tests::test_tests
Failed asserting that false is true.

E:\LocalWebServer\dch\c\my-wp-installtion.dch\wordpress-test\wordpress\wp-content\plugins\myplugin\Tests\test_CDOAjax_tests.php:7

[37;41m[2KFAILURES!
[0m[37;41m[2KTests: 3, Assertions: 2, Failures: 1, Skipped: 1.
[0m[2K

我不知道这是否有帮助,但phpunit.xml包含以下内容:

<phpunit
bootstrap="bootstrap_tests.php"
backupGlobals="false"
colors="true"
>
    <testsuites>
        <!-- Default test suite to run all tests -->
        <testsuite name="cabdriver">
            <directory prefix="test_" suffix=".php">tests</directory>
        </testsuite>
    </testsuites>
</phpunit>

正如您所看到的,PHPUnit输出有一些奇怪的字符,比如包含[0m [2k。

>的最后一行

我的系统是Windows 7,我运行XAMPP,并通过PEAR安装了PHPUnit

那么,我能否以某种方式修复该问题,因为输出不太清楚。

亲切的问候

1 个答案:

答案 0 :(得分:13)

这些是unix控制台的颜色代码,它们在phpunit框架中进行了硬编码,如下所示:https://github.com/sebastianbergmann/phpunit/blob/master/PHPUnit/TextUI/ResultPrinter.php

示例:第500至509行。

public function addError(PHPUnit_Framework_Test $test, Exception $e, $time)
    {
        if ($this->colors) {
            $this->writeProgress("\x1b[31;1mE\x1b[0m");
        } else {
            $this->writeProgress('E');
        }

        $this->lastTestFailed = TRUE;
    }

我相信你可以隐藏设置属性颜色的颜色=&#34; false&#34;在你的phpunit.xml文件中:

<phpunit colors="false">
  <!-- ... -->
</phpunit>

您可以在此处阅读更多内容:http://phpunit.de/manual/3.7/en/appendixes.configuration.html