我想知道什么"严格模式在PHPUnit" ?
例如:
phpunit --strict
或在phpunit.xml中
<phpunit strict="true">
我打开它只是为了尝试它,我的测试开始失败
PHP_Invoker_TimeoutException: Execution aborted after 1 second
答案 0 :(得分:32)
请注意,PHPUnit会吞下执行测试期间发出的所有输出。在严格模式下,发出输出的测试将失败。
这就是我在文档中找到的所有内容,但我也查看了源代码,我发现在严格模式下:
每个测试可能会按照执行时间限制运行,具体取决于它的大小以及pcntl extension和PHP_Invoker library的存在。有三个超时值:
timeoutForSmallTests
(默认值:1)timeoutForMediumTests
(默认值:10)timeoutForLargeTests
(默认值:60)测试大小(小,中或大)由PHPUnit_Util_Test::getSize()
方法确定:
PHPUnit_Extensions_Database_TestCase
或PHPUnit_Extensions_SeleniumTestCase
的测试用例很大。严格的模式似乎只做了以上三种变化,但我并不完全确定。我以前从未研究过PHPUnit的源代码,也没有使用严格模式。
答案 1 :(得分:20)
简答: 对于长时间运行的测试,使用注释来增加允许的运行时间:
@large // 10 seconds
@medium // 5 seconds
@small // 1 second max <-- Default, so no point using
长答案:
这是在@Crozin的帮助下派生的一组更新信息。
在我的情况下,错误是测试耗时太长(> 1秒。)(Doctrine ORM架构丢弃+创建可以减慢速度,see this ZendCast for what I was doing)。这导致了PHP_Invoker的问题(和一些输出)。严格模式不允许任何输出。
通过阅读/反向工程/usr/share/php/pear/share/pear/PHPUnit/Util/Test.php::getSize()(以及同一类的getGroups())..我发现有我们可以使用3个未记录的注释:
@large // 10 seconds
@medium // 5 seconds
@small // 1 second max run time
可以在类级别或方法级别指定它们。 Issue #490 on the PHPUnit github暗示提供类级别和方法级别的问题,如果你混合使用YMMV。正如克罗辛所说,分配的时间分别为10,5,1秒。
另一种解决方案是增加允许调用的函数运行的时间(在我的慢速计算机上)。
sudo vi /usr/share/php/pear/share/pear/PHP/Invoker.php
Increase line 1 "declare(ticks = 1);" to
"declare(ticks = 10);" // or any higher int that meets your needs
以下是一些有关严格模式的信息,帮助我找到解决方案:
PHP_Invoker
用于通过超时调用callables的实用程序类。此程序包需要在严格模式下强制执行测试超时。 [PHPUnit Install Instructions]严格模式 没有声明任何内容的测试标记为不完整 不完整(或跳过)的测试不会产生代码覆盖Slideshare by Sebastian Bergmann (slide 10)
注意事项 请注意,PHPUnit会吞下执行测试期间发出的所有输出。在严格模式下,发出输出的测试将失败。 Testing output section of PHPUnit Manual