2008-08-13 03:47:05 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test reporter optimised for CLI (ie, plain-text) output
|
|
|
|
*/
|
|
|
|
class CliTestReporter extends SapphireTestReporter {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Display error bar if it exists
|
|
|
|
*/
|
|
|
|
public function writeResults() {
|
|
|
|
$passCount = 0;
|
|
|
|
$failCount = 0;
|
|
|
|
$testCount = 0;
|
|
|
|
$errorCount = 0;
|
|
|
|
|
|
|
|
foreach($this->suiteResults['suites'] as $suite) {
|
|
|
|
foreach($suite['tests'] as $test) {
|
|
|
|
$testCount++;
|
|
|
|
($test['status'] == 1) ? $passCount++ : $failCount++;
|
|
|
|
}
|
|
|
|
}
|
2008-10-04 07:41:15 +02:00
|
|
|
|
|
|
|
echo "\n\n";
|
|
|
|
if ($failCount == 0) {
|
|
|
|
echo SSCli::text(" ALL TESTS PASS ", "white", "green");
|
|
|
|
} else {
|
|
|
|
echo SSCli::text(" AT LEAST ONE FAILURE ", "white", "red");
|
|
|
|
}
|
2008-10-17 00:26:16 +02:00
|
|
|
echo "\n\n$testCount tests run: " . SSCli::text("$passCount passes", $passCount > 0 ? "green" : null) . ", ". SSCli::text("$failCount fails", $failCount > 0 ? "red" : null) . ", and 0 exceptions\n";
|
|
|
|
echo "Maximum memory usage: " . number_format(memory_get_peak_usage(), 0) . "\n\n";
|
2008-10-17 04:28:55 +02:00
|
|
|
|
|
|
|
$totalTime = array_sum($this->testSpeeds);
|
|
|
|
echo "Total time: " . round($totalTime,3) . " seconds\n";
|
|
|
|
|
|
|
|
// Use sake dev/tests/all --showslow to show slow tests
|
|
|
|
if((isset($_GET['args']) && is_array($_GET['args']) && in_array('--showslow', $_GET['args'])) || isset($_GET['showslow'])) {
|
|
|
|
$avgSpeed = round(array_sum($this->testSpeeds) / count($this->testSpeeds), 3);
|
|
|
|
echo "Slow tests (more than twice the average $avgSpeed seconds):\n";
|
|
|
|
|
|
|
|
arsort($this->testSpeeds);
|
|
|
|
foreach($this->testSpeeds as $k => $v) {
|
|
|
|
// Ignore below-average speeds
|
|
|
|
if($v < $avgSpeed*2) break;
|
|
|
|
|
|
|
|
echo " - $k: " . round($v,3) . "\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
echo "\n";
|
2008-08-13 03:47:05 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function endTest( PHPUnit_Framework_Test $test, $time) {
|
2008-09-23 05:22:13 +02:00
|
|
|
// Status indicator, a la PHPUnit
|
|
|
|
switch($this->currentTest['status']) {
|
2008-10-04 07:41:15 +02:00
|
|
|
case TEST_FAILURE: echo SSCli::text("F","red", null, true); break;
|
|
|
|
case TEST_ERROR: echo SSCli::text("E","red", null, true); break;
|
|
|
|
case TEST_INCOMPLETE: echo SSCli::text("I","yellow"); break;
|
|
|
|
case TEST_SUCCESS: echo SSCli::text(".","green"); break;
|
|
|
|
default: echo SSCli::text("?", "yellow"); break;
|
2008-09-23 05:22:13 +02:00
|
|
|
}
|
|
|
|
|
2008-10-03 04:23:35 +02:00
|
|
|
static $colCount = 0;
|
|
|
|
$colCount++;
|
|
|
|
if($colCount % 80 == 0) echo " - $colCount\n";
|
|
|
|
|
2008-08-13 03:47:05 +02:00
|
|
|
parent::endTest($test, $time);
|
|
|
|
$this->writeTest($this->currentTest);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
protected function writeTest($test) {
|
|
|
|
if ($test['status'] != 1) {
|
2008-10-09 03:45:36 +02:00
|
|
|
|
|
|
|
$filteredTrace = array();
|
|
|
|
$ignoredClasses = array('TestRunner');
|
|
|
|
foreach($test['trace'] as $item) {
|
2008-10-09 17:14:31 +02:00
|
|
|
if(
|
|
|
|
isset($item['file'])
|
|
|
|
&& strpos($item['file'], 'PHPUnit/Framework') === false
|
2008-10-09 03:45:36 +02:00
|
|
|
&& (!isset($item['class']) || !in_array($item['class'], $ignoredClasses))) {
|
|
|
|
|
|
|
|
$filteredTrace[] = $item;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(isset($item['class']) && isset($item['function']) && $item['class'] == 'PHPUnit_Framework_TestSuite'
|
|
|
|
&& $item['function'] == 'run') break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2008-10-04 07:41:15 +02:00
|
|
|
echo "\n\n" . SSCli::text($this->testNameToPhrase($test['name']) . "\n". $test['message'] . "\n", 'red', null, true);
|
2008-10-09 17:17:59 +02:00
|
|
|
echo SSCli::text("In line {$test['exception']['line']} of {$test['exception']['file']}" . "\n\n", 'red');
|
2008-10-09 03:45:36 +02:00
|
|
|
echo Debug::get_rendered_backtrace($filteredTrace, true);
|
2008-08-13 05:42:45 +02:00
|
|
|
echo "\n--------------------\n";
|
2008-08-13 03:47:05 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|