Невозможно повторно объявить ошибку класса при создании отчета о покрытии кода PHPUnit - PullRequest
24 голосов
/ 12 мая 2010

Запуск проекта с Zend Framework 1.10 и Doctrine 2 (Beta1). Я использую пространства имен в своем коде библиотеки.

При создании отчетов о покрытии кода я получаю фатальную ошибку при повторном выделении класса. Чтобы получить больше информации, я прокомментировал вызов xdebug_disable () в моем исполняемом файле phpunit, чтобы вы могли увидеть трассировку функции (отключил вывод локальных переменных, поскольку было слишком много выходных данных).

Вот мой вывод терминала:

$ phpunit
PHPUnit 3.4.12 by Sebastian Bergmann.

........

Time: 4 seconds, Memory: 16.50Mb

OK (8 tests, 14 assertions)

Generating code coverage report, this may take a moment.PHP Fatal error:  Cannot redeclare class Cob\Application\Resource\HelperBroker in /Users/Cobby/Sites/project/trunk/code/library/Cob/Application/Resource/HelperBroker.php on line 93
PHP Stack trace:
PHP   1. {main}() /usr/local/zend/bin/phpunit:0
PHP   2. PHPUnit_TextUI_Command::main() /usr/local/zend/bin/phpunit:54
PHP   3. PHPUnit_TextUI_Command->run() /usr/local/zend/share/pear/PHPUnit/TextUI/Command.php:146
PHP   4. PHPUnit_TextUI_TestRunner->doRun() /usr/local/zend/share/pear/PHPUnit/TextUI/Command.php:213
PHP   5. PHPUnit_Util_Report::render() /usr/local/zend/share/pear/PHPUnit/TextUI/TestRunner.php:478
PHP   6. PHPUnit_Framework_TestResult->getCodeCoverageInformation() /usr/local/zend/share/pear/PHPUnit/Util/Report.php:97
PHP   7. PHPUnit_Util_Filter::getFilteredCodeCoverage() /usr/local/zend/share/pear/PHPUnit/Framework/TestResult.php:623

Fatal error: Cannot redeclare class Cob\Application\Resource\HelperBroker in /Users/Cobby/Sites/project/trunk/code/library/Cob/Application/Resource/HelperBroker.php on line 93

Call Stack:
    0.0004     322888   1. {main}() /usr/local/zend/bin/phpunit:0
    0.0816    4114628   2. PHPUnit_TextUI_Command::main() /usr/local/zend/bin/phpunit:54
    0.0817    4114964   3. PHPUnit_TextUI_Command->run() /usr/local/zend/share/pear/PHPUnit/TextUI/Command.php:146
    0.1151    5435528   4. PHPUnit_TextUI_TestRunner->doRun() /usr/local/zend/share/pear/PHPUnit/TextUI/Command.php:213
    4.2931   16690760   5. PHPUnit_Util_Report::render() /usr/local/zend/share/pear/PHPUnit/TextUI/TestRunner.php:478
    4.2931   16691120   6. PHPUnit_Framework_TestResult->getCodeCoverageInformation() /usr/local/zend/share/pear/PHPUnit/Util/Report.php:97
    4.2931   16691148   7. PHPUnit_Util_Filter::getFilteredCodeCoverage() /usr/local/zend/share/pear/PHPUnit/Framework/TestResult.php:623

(Понятия не имею, почему он показывает ошибку дважды ...?)

А вот мой phpunit.xml:

<phpunit bootstrap="./code/tests/application/bootstrap.php" colors="true">
    <!-- bootstrap.php changes directory to trunk/code/tests,
    all paths below are relative to this directory. -->

    <testsuite name="My Promotions">
        <directory>./</directory>
    </testsuite>

    <filter>
        <whitelist>
            <directory suffix=".php">../application</directory>
            <directory suffix=".php">../library/Cob</directory>
            <exclude>
                    <!-- By adding the below line I can remove the error -->
                <file>../library/Cob/Application/Resource/HelperBroker.php</file>
                <directory suffix=".phtml">../application</directory>
                <directory suffix=".php">../application/doctrine</directory>
                <file>../application/Bootstrap.php</file>
                <directory suffix=".php">../library/Cob/Tools</directory>
            </exclude>
        </whitelist>
    </filter>

    <logging>
        <log type="junit" target="../../build/reports/tests/report.xml" />
        <log type="coverage-html" target="../../build/reports/coverage" charset="UTF-8"
            yui="true" highlight="true" lowUpperBound="50" highLowerBound="80" />
    </logging>
</phpunit>

Я добавил тег внутри швов, чтобы скрыть эту проблему. У меня есть другой ресурс приложения, но у меня нет проблем (другой - ресурс Doctrine 2). Я не уверен, почему он специфичен для этого класса, вся моя библиотека загружается автоматически, поэтому их нельзя нигде включать / требовать. Думаю, следует отметить, что HelperBroker - это первый файл в файловой системе, созданный на основе библиотеки / Cob

Я работаю на Snow Leopard с последними / последними версиями всего программного обеспечения (Zend Server, Zend Framework, Doctrine 2 Beta1, Phing, PHPUnit, PEAR).

Ответы [ 5 ]

33 голосов
/ 23 ноября 2011

Общий ответ для решения этой проблемы:

Это сообщение об ошибке обычно указывает на проблему с автоматической загрузкой и требует операторов.

Во время генерации отчета о покрытии кода phpunit равен require каждый *.php, который находится в <whitelist>. Это можно отключить, используя addUncoveredFilesFromWhitelist=false как параметр, но рекомендуется оставить его включенным.

Возможные причины

В этих случаях обычно происходит то, что в одном из файлов есть оператор require, который снова требует уже загруженный класс (так как он не является require_once).

Другие причины могут быть

  • дублирующее определение классов (одно для отладки, одно для производства, должно быть решено наследованием, а не загрузкой нужного php-файла)
  • Несоответствующая заглавная буква, приводящая к ошибкам в коде php как:

    if( !$classesLoaded['ThIsClass']) require_once(...); в нескольких местах с разными заглавными буквами.

  • Класс вообще не загружается в тестах, но создается фиктивный объект с именем загруженного класса. Они могут столкнуться и привести к этой ошибке тоже
1 голос
/ 28 августа 2013

Еще одна вещь, которую нужно проверить (особенно если вы работаете с виртуальной машиной), - переименован ли файл, но все еще существует в исходном виде. например. Файл fooMapper.php переименован в FooMapper.php (например, через обновление SVN), ваша IDE обнаружит новый файл и отправит его на виртуальную машину. Теперь у вас есть обе версии на вашей виртуальной машине, даже если ваша IDE локально показывает только одну. Осторожно.

1 голос
/ 24 ноября 2011

Быстрый обходной путь может заключаться в добавлении оператора if в начале объявления вашего класса, чтобы избежать повторного объявления при запуске phpunit (если и только если, это единственный класс, с которым у вас возникают проблемы)

if (!class_exists("class_name")) {
    // declare the class
    class class_name
    {
        //...
    }
}
0 голосов
/ 02 августа 2017

Я обнаружил, что получил эту ошибку, когда была использована неверная @coversDefaultClass (то же самое относится и к @covers). В моем случае это был \Path\To\\Class (с двойным '\'), который связывался с вызовами require.

0 голосов
/ 07 апреля 2017

Это случилось со мной, потому что в моей декларации @covers была опечатка. Обратите внимание на лишние \ в первой строке.

App\Controller\\Account\UsersController::forgotPassword()

VS

App\Controller\Account\UsersController::forgotPassword()
...