我正在修改我们的 build.xml 以使用并行任务,主要是为了加快我们在 CI 服务器上的构建速度。
我遇到的一个小问题是阻止输出(stdout)变得混乱。
<target name="build">
<antcall target="clean"/>
<antcall target="prepare"/>
<antcall target="externals"/>
<antcall target="migrate"/>
<parallel>
<antcall target="phpunit"/>
<antcall target="jshint"/>
<antcall target="phploc"/>
<antcall target="phpcpd"/>
<antcall target="pdepend"/>
<antcall target="phpcs"/>
<antcall target="phpmd"/>
<antcall target="php-lint"/>
</parallel>
</target>
输出的片段(来自 php-lint 和 phpunit 任务):
[apply] No syntax errors detected in /home/bhafichuk/workspace/icarus/source/library/Icarus/Model/DbTable/User.php
[exec] ............................................................
[exec]
[exec] Time: 02:11, Memory: 24.75Mb
[exec]
OK (123 tests, 433 assertions)
[apply] No syntax errors detected in /home/bhafichuk/workspace/icarus/source/library/Icarus/Model/DbTable/User/Contact.php
我希望有一种方法可以缓冲任务的输出,直到任务完成,然后写入标准输出。
请注意,我真的不关心输出相对于任务的顺序,只关心一个任务输出与另一个任务输出的交错。
有人对如何做到这一点有任何建议吗?是否有更好的方法来提高不会导致此问题的构建速度?