wiki.techinc.nl/tests/phpunit/MediaWikiPHPUnitResultPrinter.php
Erik Bernhardson 56ffbc2a4e Print logs generated during unit test when test fails
When a unit test fails it is possible, perhaps even likely in some
cases, that some code that was run logged useful information about
how that failure came to be.

Help people out, tell them what happened!

Change-Id: I30bbc31799a65024868678d052fec9aafacc1aff
2019-02-06 14:43:32 -08:00

18 lines
546 B
PHP

<?php
class MediaWikiPHPUnitResultPrinter extends PHPUnit_TextUI_ResultPrinter {
/** @var MediaWikiLoggerPHPUnitTestListener */
private static $logListener;
public static function setLogListener( MediaWikiLoggerPHPUnitTestListener $logListener ) {
self::$logListener = $logListener;
}
protected function printDefectTrace( PHPUnit_Framework_TestFailure $defect ) {
$log = self::$logListener->getLog();
if ( $log ) {
$this->write( "=== Logs generated by test case\n{$log}\n===\n" );
}
parent::printDefectTrace( $defect );
}
}