Запуск проекта с помощью Zend Framework 1.10 и Doctrine 2 (Beta1). Я использую пространства имен в своем собственном библиотечном коде.
При генерации отчетов о покрытии кода я получаю Fatal Error об обновлении класса. Чтобы предоставить дополнительную информацию, я прокомментировал вызов xdebug_disable () в моем исполняемом файле phpunit, чтобы вы могли увидеть трассировку функции (отключены локальные переменные, потому что было слишком много вывода).
Вот мой вывод терминала:
$ phpunit PHPUnit 3.4.12 от Себастьяна Бергмана. ........ Время: 4 секунды, Память: 16.50Mb OK (8 тестов, 14 утверждений) Создавая отчет о покрытии кода, это может занять некоторое время. PHP Неустранимая ошибка: не удается переопределить класс Cob \ Application \ Resource \ HelperBroker в /Users/Cobby/Sites/project/trunk/code/library/Cob/Application/Resource/HelperBroker.php в строке 93 Трассировка стека PHP: 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 Неустранимая ошибка: не удается переопределить класс Cob \ Application \ Resource \ HelperBroker в /Users/Cobby/Sites/project/trunk/code/library/Cob/Application/Resource/HelperBroker.php в строке 93 Стек вызовов: 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).
Общий ответ для решения этой проблемы:
Во время создания отчета о покрытии кода phpunit require
каждый *.php
который находится в <whitelist>
. Это можно отключить с помощью addUncoveredFilesFromWhitelist=false
в качестве параметра, но рекомендуется сохранить это.
То, что имеет тенденцию происходить в этих случаях, состоит в том, что в одном из файлов есть инструкция require
которая требует уже загруженного класса (так как это не require_once).
Другие причины могут быть
Непоследовательная капитализация, приводящая к ошибкам в php-коде, например:
if( !$classesLoaded['ThIsClass']) require_once(...);
в разных местах с различной капитализацией.
Еще одна вещь для проверки (особенно, если вы работаете с виртуальной машиной) заключается в том, был ли файл переименован, но все еще существует в исходной форме. например. fooMapper.php переименован в FooMapper.php (например, через обновление SVN), ваша среда IDE обнаруживает новый файл и отправляет его на виртуальную машину. Теперь у вас есть обе версии на вашей виртуальной машине, даже если ваша локальная сеть локально только показывает один. Осторожно.
Быстрое обходное решение может заключаться в том, чтобы добавить инструкцию if в начале объявления вашего класса, чтобы избежать повторной записи при запуске phpunit (если и только если это единственный класс, с которым у вас возникают проблемы)
if (!class_exists("class_name")) { // declare the class class class_name { //... } }
Это произошло со мной, потому что у меня была опечатка в моей декларации @covers. Обратите внимание на дополнительную \ в первой строке.
App\Controller\\Account\UsersController::forgotPassword()
В.С.
App\Controller\Account\UsersController::forgotPassword()
Я обнаружил, что я получил эту ошибку, когда была использована некорректная @coversDefaultClass
( @coversDefaultClass
же, вероятно, относится и к @covers
) аннотации. В моем случае это был \Path\To\\Class
(с двойным «\»), который возился с требуемыми вызовами.