2012-05-28 18:31:48 +12:00
|
|
|
<?php
|
2016-08-19 10:51:35 +12:00
|
|
|
|
|
|
|
namespace SilverStripe\Dev;
|
|
|
|
|
|
|
|
use PHPUnit_Framework_TestListener;
|
|
|
|
use PHPUnit_Framework_TestSuite;
|
|
|
|
use PHPUnit_Framework_Test;
|
|
|
|
use Exception;
|
|
|
|
use PHPUnit_Framework_AssertionFailedError;
|
|
|
|
use PHPUnit_Framework_TestFailure;
|
|
|
|
|
2013-11-29 17:12:47 +13:00
|
|
|
/**
|
|
|
|
* Bind TeamCity test listener. Echos messages to stdout that TeamCity interprets into the test results
|
|
|
|
*/
|
2012-05-28 18:31:48 +12:00
|
|
|
class TeamCityListener implements PHPUnit_Framework_TestListener {
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-05-28 18:31:48 +12:00
|
|
|
private function escape($str) {
|
|
|
|
return strtr($str, array(
|
|
|
|
"\n" => '|n',
|
|
|
|
"\r" => '|r',
|
|
|
|
"[" => '|[',
|
|
|
|
"]" => '|]',
|
|
|
|
"'" => "|'",
|
|
|
|
"|" => '||'
|
|
|
|
));
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-05-28 18:31:48 +12:00
|
|
|
public function startTestSuite(PHPUnit_Framework_TestSuite $suite) {
|
|
|
|
echo "##teamcity[testSuiteStarted name='{$suite->getName()}']\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
public function endTestSuite(PHPUnit_Framework_TestSuite $suite) {
|
|
|
|
echo "##teamcity[testSuiteFinished name='{$suite->getName()}']\n";
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-05-28 18:31:48 +12:00
|
|
|
public function startTest(PHPUnit_Framework_Test $test) {
|
|
|
|
$class = get_class($test);
|
|
|
|
echo "##teamcity[testStarted name='{$class}.{$test->getName()}']\n";
|
|
|
|
}
|
2012-12-09 00:20:20 +13:00
|
|
|
|
2012-05-28 18:31:48 +12:00
|
|
|
public function endTest(PHPUnit_Framework_Test $test, $time) {
|
|
|
|
$class = get_class($test);
|
|
|
|
echo "##teamcity[testFinished name='{$class}.{$test->getName()}' duration='$time']\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
public function addError(PHPUnit_Framework_Test $test, Exception $e, $time) {
|
|
|
|
$class = get_class($test);
|
|
|
|
$message = $this->escape("Exception: {$e->getMessage()}");
|
|
|
|
$trace = $this->escape($e->getTraceAsString());
|
2012-09-27 09:34:00 +12:00
|
|
|
echo "##teamcity[testFailed type='exception' name='{$class}.{$test->getName()}' message='$message'"
|
|
|
|
. " details='$trace']\n";
|
2012-05-28 18:31:48 +12:00
|
|
|
}
|
2012-12-09 00:20:20 +13:00
|
|
|
|
2012-05-28 18:31:48 +12:00
|
|
|
public function addFailure(PHPUnit_Framework_Test $test, PHPUnit_Framework_AssertionFailedError $e, $time) {
|
|
|
|
$class = get_class($test);
|
2015-08-21 17:30:50 +12:00
|
|
|
$message = $this->escape(PHPUnit_Framework_TestFailure::exceptionToString($e));
|
2012-05-28 18:31:48 +12:00
|
|
|
$trace = $this->escape($e->getTraceAsString());
|
2012-09-27 09:34:00 +12:00
|
|
|
echo "##teamcity[testFailed type='failure' name='{$class}.{$test->getName()}' message='$message'"
|
|
|
|
. " details='$trace']\n";
|
2012-05-28 18:31:48 +12:00
|
|
|
}
|
|
|
|
|
|
|
|
public function addIncompleteTest(PHPUnit_Framework_Test $test, Exception $e, $time) {
|
|
|
|
// NOP
|
|
|
|
}
|
|
|
|
|
|
|
|
public function addSkippedTest(PHPUnit_Framework_Test $test, Exception $e, $time) {
|
|
|
|
$class = get_class($test);
|
|
|
|
$message = $this->escape($e->getMessage());
|
|
|
|
echo "##teamcity[testIgnored name='{$class}.{$test->getName()}' message='$message']\n";
|
|
|
|
}
|
2014-02-03 15:32:58 -08:00
|
|
|
|
2014-03-30 19:37:54 +13:00
|
|
|
/**
|
|
|
|
* Risky test.
|
|
|
|
*
|
|
|
|
* @param PHPUnit_Framework_Test $test
|
|
|
|
* @param Exception $e
|
|
|
|
* @param float $time
|
|
|
|
* @since Method available since Release 3.8.0
|
|
|
|
*/
|
|
|
|
public function addRiskyTest(PHPUnit_Framework_Test $test, Exception $e, $time) {
|
|
|
|
// Stub out to support PHPUnit 3.8
|
|
|
|
}
|
2012-05-28 18:31:48 +12:00
|
|
|
}
|