Initial Commit

This commit is contained in:
Riley Schneider
2025-12-03 16:38:10 +01:00
parent c5e26bf594
commit b732d8d4b5
17680 changed files with 5977495 additions and 2 deletions

View File

@@ -0,0 +1,356 @@
<?php
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
/**
* PHP Version 5
*
* Copyright (c) 2002-2006, Sebastian Bergmann <sb@sebastian-bergmann.de>.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
*
* * Neither the name of Sebastian Bergmann nor the names of his
* contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRIC
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*
* @category Testing
* @package PHPUnit2
* @author Sebastian Bergmann <sb@sebastian-bergmann.de>
* @copyright 2002-2006 Sebastian Bergmann <sb@sebastian-bergmann.de>
* @license http://www.opensource.org/licenses/bsd-license.php BSD License
* @version CVS: $Id: ResultPrinter.php,v 1.20.2.5 2005/12/17 16:04:57 sebastian Exp $
* @link http://pear.php.net/package/PHPUnit2
* @since File available since Release 2.0.0
*/
require_once 'PHPUnit2/Framework/TestListener.php';
require_once 'PHPUnit2/Framework/TestFailure.php';
require_once 'PHPUnit2/Util/Filter.php';
require_once 'PHPUnit2/Util/Printer.php';
/**
* Prints the result of a TextUI TestRunner run.
*
* @category Testing
* @package PHPUnit2
* @author Sebastian Bergmann <sb@sebastian-bergmann.de>
* @copyright 2002-2006 Sebastian Bergmann <sb@sebastian-bergmann.de>
* @license http://www.opensource.org/licenses/bsd-license.php BSD License
* @version Release: 2.3.6
* @link http://pear.php.net/package/PHPUnit2
* @since Class available since Release 2.0.0
*/
class PHPUnit2_TextUI_ResultPrinter extends PHPUnit2_Util_Printer implements PHPUnit2_Framework_TestListener {
/**
* @var integer
* @access private
*/
private $column = 0;
/**
* @var boolean
* @access private
*/
private $lastTestFailed = FALSE;
/**
* @param PHPUnit2_Framework_TestResult $result
* @param float $runTime
* @access public
*/
public function printResult(PHPUnit2_Framework_TestResult $result, $timeElapsed) {
$this->printHeader($timeElapsed);
$this->printErrors($result);
$this->printFailures($result);
$this->printIncompletes($result);
$this->printFooter($result);
}
/**
* @param array $defects
* @param integer $count
* @param string $type
* @access protected
*/
protected function printDefects($defects, $count, $type) {
if ($count == 0) {
return;
}
$this->write(
sprintf(
"There %s %d %s%s:\n",
($count == 1) ? 'was' : 'were',
$count,
$type,
($count == 1) ? '' : 's'
)
);
$i = 1;
foreach ($defects as $defect) {
$this->printDefect($defect, $i++);
}
}
/**
* @param PHPUnit2_Framework_TestFailure $defect
* @param integer $count
* @access protected
*/
protected function printDefect(PHPUnit2_Framework_TestFailure $defect, $count) {
$this->printDefectHeader($defect, $count);
$this->printDefectTrace($defect);
}
/**
* @param PHPUnit2_Framework_TestFailure $defect
* @param integer $count
* @access protected
*/
protected function printDefectHeader(PHPUnit2_Framework_TestFailure $defect, $count) {
$this->write(
sprintf(
"%d) %s\n",
$count,
$defect->failedTest()->toString()
)
);
}
/**
* @param PHPUnit2_Framework_TestFailure $defect
* @access protected
*/
protected function printDefectTrace(PHPUnit2_Framework_TestFailure $defect) {
$e = $defect->thrownException();
$message = method_exists($e, 'toString') ? $e->toString() : $e->getMessage();
$this->write($message . "\n");
$this->write(
PHPUnit2_Util_Filter::getFilteredStacktrace(
$defect->thrownException()
)
);
}
/**
* @param PHPUnit2_Framework_TestResult $result
* @access protected
*/
protected function printErrors(PHPUnit2_Framework_TestResult $result) {
$this->printDefects($result->errors(), $result->errorCount(), 'error');
}
/**
* @param PHPUnit2_Framework_TestResult $result
* @access protected
*/
protected function printFailures(PHPUnit2_Framework_TestResult $result) {
$this->printDefects($result->failures(), $result->failureCount(), 'failure');
}
/**
* @param PHPUnit2_Framework_TestResult $result
* @access protected
*/
protected function printIncompletes(PHPUnit2_Framework_TestResult $result) {
$this->printDefects($result->notImplemented(), $result->notImplementedCount(), 'incomplete test case');
}
/**
* @param float $timeElapsed
* @access protected
*/
protected function printHeader($timeElapsed) {
$this->write(
sprintf(
"\n\nTime: %s\n",
$timeElapsed
)
);
}
/**
* @param PHPUnit2_Framework_TestResult $result
* @access protected
*/
protected function printFooter(PHPUnit2_Framework_TestResult $result) {
if ($result->allCompletlyImplemented() &&
$result->wasSuccessful()) {
$this->write(
sprintf(
"\nOK (%d test%s)\n",
$result->runCount(),
($result->runCount() == 1) ? '' : 's'
)
);
}
else if (!$result->allCompletlyImplemented() &&
$result->wasSuccessful()) {
$this->write(
sprintf(
"\nOK, but incomplete test cases!!!\nTests run: %d, Incomplete Tests: %d.\n",
$result->runCount(),
$result->notImplementedCount()
)
);
}
else {
$this->write(
sprintf(
"\nFAILURES!!!\nTests run: %d, Failures: %d, Errors: %d, Incomplete Tests: %d.\n",
$result->runCount(),
$result->failureCount(),
$result->errorCount(),
$result->notImplementedCount()
)
);
}
}
/**
* @access public
*/
public function printWaitPrompt() {
$this->write("\n<RETURN> to continue\n");
}
/**
* An error occurred.
*
* @param PHPUnit2_Framework_Test $test
* @param Exception $e
* @access public
*/
public function addError(PHPUnit2_Framework_Test $test, Exception $e) {
$this->write('E');
$this->nextColumn();
$this->lastTestFailed = TRUE;
}
/**
* A failure occurred.
*
* @param PHPUnit2_Framework_Test $test
* @param PHPUnit2_Framework_AssertionFailedError $e
* @access public
*/
public function addFailure(PHPUnit2_Framework_Test $test, PHPUnit2_Framework_AssertionFailedError $e) {
$this->write('F');
$this->nextColumn();
$this->lastTestFailed = TRUE;
}
/**
* Incomplete test.
*
* @param PHPUnit2_Framework_Test $test
* @param Exception $e
* @access public
*/
public function addIncompleteTest(PHPUnit2_Framework_Test $test, Exception $e) {
$this->write('I');
$this->nextColumn();
$this->lastTestFailed = TRUE;
}
/**
* A testsuite started.
*
* @param PHPUnit2_Framework_TestSuite $suite
* @access public
* @since Method available since Release 2.2.0
*/
public function startTestSuite(PHPUnit2_Framework_TestSuite $suite) {
}
/**
* A testsuite ended.
*
* @param PHPUnit2_Framework_TestSuite $suite
* @access public
* @since Method available since Release 2.2.0
*/
public function endTestSuite(PHPUnit2_Framework_TestSuite $suite) {
}
/**
* A test started.
*
* @param PHPUnit2_Framework_Test $test
* @access public
*/
public function startTest(PHPUnit2_Framework_Test $test) {
}
/**
* A test ended.
*
* @param PHPUnit2_Framework_Test $test
* @access public
*/
public function endTest(PHPUnit2_Framework_Test $test) {
if (!$this->lastTestFailed) {
$this->write('.');
$this->nextColumn();
}
$this->lastTestFailed = FALSE;
}
/**
* @access protected
*/
protected function nextColumn() {
if ($this->column++ >= 40) {
$this->column = 0;
$this->write("\n");
}
}
}
/*
* Local variables:
* tab-width: 4
* c-basic-offset: 4
* c-hanging-comment-ender-p: nil
* End:
*/
?>

View File

@@ -0,0 +1,622 @@
<?php
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
/**
* PHP Version 5
*
* Copyright (c) 2002-2006, Sebastian Bergmann <sb@sebastian-bergmann.de>.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
*
* * Neither the name of Sebastian Bergmann nor the names of his
* contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRIC
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*
* @category Testing
* @package PHPUnit2
* @author Sebastian Bergmann <sb@sebastian-bergmann.de>
* @copyright 2002-2006 Sebastian Bergmann <sb@sebastian-bergmann.de>
* @license http://www.opensource.org/licenses/bsd-license.php BSD License
* @version CVS: $Id: TestRunner.php,v 1.64.2.5 2005/12/17 16:04:58 sebastian Exp $
* @link http://pear.php.net/package/PHPUnit2
* @since File available since Release 2.0.0
*/
if (!defined('PHPUnit2_MAIN_METHOD')) {
define('PHPUnit2_MAIN_METHOD', 'PHPUnit2_TextUI_TestRunner::main');
}
require_once 'PHPUnit2/Framework/TestSuite.php';
require_once 'PHPUnit2/Runner/Version.php';
require_once 'PHPUnit2/Runner/BaseTestRunner.php';
require_once 'PHPUnit2/TextUI/ResultPrinter.php';
require_once 'PHPUnit2/Util/Fileloader.php';
require_once 'Console/Getopt.php';
require_once 'Benchmark/Timer.php';
/**
* A TestRunner for the Command Line Interface (CLI)
* PHP SAPI Module.
*
* @category Testing
* @package PHPUnit2
* @author Sebastian Bergmann <sb@sebastian-bergmann.de>
* @copyright 2002-2006 Sebastian Bergmann <sb@sebastian-bergmann.de>
* @license http://www.opensource.org/licenses/bsd-license.php BSD License
* @version Release: 2.3.6
* @link http://pear.php.net/package/PHPUnit2
* @since Class available since Release 2.0.0
*/
class PHPUnit2_TextUI_TestRunner extends PHPUnit2_Runner_BaseTestRunner {
const SUCCESS_EXIT = 0;
const FAILURE_EXIT = 1;
const EXCEPTION_EXIT = 2;
/**
* @var PHPUnit2_Runner_TestSuiteLoader
* @access private
*/
private $loader = NULL;
/**
* @var PHPUnit2_TextUI_ResultPrinter
* @access private
*/
private $printer = NULL;
/**
* @var boolean
* @access private
* @static
*/
private static $versionStringPrinted = FALSE;
/**
* @access public
* @static
*/
public static function main() {
$aTestRunner = new PHPUnit2_TextUI_TestRunner;
try {
$result = $aTestRunner->start($_SERVER['argv']);
if (!$result->wasSuccessful()) {
exit(self::FAILURE_EXIT);
}
exit(self::SUCCESS_EXIT);
}
catch (Exception $e) {
self::printVersionString();
print $e->getMessage();
exit(self::EXCEPTION_EXIT);
}
}
/**
* @param array $arguments
* @throws Exception
* @access protected
*/
protected function start($arguments) {
$coverageDataFile = FALSE;
$coverageHTMLFile = FALSE;
$coverageTextFile = FALSE;
$testdoxHTMLFile = FALSE;
$testdoxTextFile = FALSE;
$xmlLogfile = FALSE;
$wait = FALSE;
$possibleOptions = array(
'help',
'loader=',
'log-xml=',
'skeleton',
'testdox-html=',
'testdox-text=',
'version',
'wait'
);
if (extension_loaded('xdebug')) {
$possibleOptions[] = 'coverage-data=';
$possibleOptions[] = 'coverage-html=';
$possibleOptions[] = 'coverage-text=';
}
$options = Console_Getopt::getopt(
$arguments,
'',
$possibleOptions
);
if (PEAR::isError($options)) {
$this->showError($options->getMessage());
}
$test = isset($options[1][0]) ? $options[1][0] : FALSE;
$testFile = isset($options[1][1]) ? $options[1][1] : $test . '.php';
foreach ($options[0] as $option) {
switch ($option[0]) {
case '--coverage-data': {
$coverageDataFile = $option[1];
}
break;
case '--coverage-html': {
$coverageHTMLFile = $option[1];
}
break;
case '--coverage-text': {
$coverageTextFile = $option[1];
}
break;
case '--help': {
$this->showHelp();
exit(self::SUCCESS_EXIT);
}
break;
case '--testdox-html': {
$testdoxHTMLFile = $option[1];
}
break;
case '--testdox-text': {
$testdoxTextFile = $option[1];
}
break;
case '--loader': {
if (!class_exists($option[1])) {
PHPUnit2_Util_Fileloader::checkAndLoad(
str_replace('_', '/', $option[1]) . '.php'
);
}
if (class_exists($option[1])) {
$class = new ReflectionClass($option[1]);
if ($class->implementsInterface('PHPUnit2_Runner_TestSuiteLoader') &&
$class->isInstantiable()) {
$this->loader = $class->newInstance();
}
}
if ($this->loader === NULL) {
$this->showError(
sprintf(
'Could not use "%s" as loader.',
$option[1]
)
);
}
}
break;
case '--log-xml': {
$xmlLogfile = $option[1];
}
break;
case '--skeleton': {
if ($test !== FALSE) {
self::printVersionString();
try {
require_once 'PHPUnit2/Util/Skeleton.php';
$skeleton = new PHPUnit2_Util_Skeleton($test, $testFile);
$skeleton->write();
}
catch (Exception $e) {
print $e->getMessage() . "\n";
printf(
"Could not write test class skeleton for %s to %s.\n",
$test,
$test . 'Test.php'
);
exit(self::FAILURE_EXIT);
}
printf(
"Wrote test class skeleton for %s to %s.\n",
$test,
$test . 'Test.php'
);
exit(self::SUCCESS_EXIT);
}
}
break;
case '--version': {
self::printVersionString();
exit(self::SUCCESS_EXIT);
}
break;
case '--wait': {
$wait = TRUE;
}
break;
}
}
if ($test === FALSE) {
$this->showHelp();
exit(self::SUCCESS_EXIT);
}
try {
return $this->doRun(
$this->getTest($test, $testFile),
$coverageDataFile,
$coverageHTMLFile,
$coverageTextFile,
$testdoxHTMLFile,
$testdoxTextFile,
$xmlLogfile,
$wait
);
}
catch (Exception $e) {
throw new Exception(
'Could not create and run test suite: ' . $e->getMessage()
);
}
}
/**
* @param mixed $test
* @param mixed $coverageDataFile
* @param mixed $testdoxHTMLFile
* @param mixed $testdoxTextFile
* @param mixed $xmlLogfile
* @param boolean $wait
* @access public
* @static
*/
public static function run($test, $coverageDataFile = FALSE, $coverageHTMLFile = FALSE, $coverageTextFile = FALSE, $testdoxHTMLFile = FALSE, $testdoxTextFile = FALSE, $xmlLogfile = FALSE, $wait = FALSE) {
if ($test instanceof ReflectionClass) {
$test = new PHPUnit2_Framework_TestSuite($test);
}
if ($test instanceof PHPUnit2_Framework_Test) {
$aTestRunner = new PHPUnit2_TextUI_TestRunner;
return $aTestRunner->doRun(
$test,
$coverageDataFile,
$coverageHTMLFile,
$coverageTextFile,
$testdoxHTMLFile,
$testdoxTextFile,
$xmlLogfile,
$wait
);
}
}
/**
* Runs a single test and waits until the user types RETURN.
*
* @param PHPUnit2_Framework_Test $suite
* @access public
* @static
*/
public static function runAndWait(PHPUnit2_Framework_Test $suite) {
$aTestRunner = new PHPUnit2_TextUI_TestRunner;
$aTestRunner->doRun(
$suite,
FALSE,
FALSE,
FALSE,
FALSE,
FALSE,
FALSE,
TRUE
);
}
/**
* @return PHPUnit2_Framework_TestResult
* @access protected
*/
protected function createTestResult() {
return new PHPUnit2_Framework_TestResult;
}
/**
* @param PHPUnit2_Framework_Test $suite
* @param mixed $coverageDataFile
* @param mixed $coverageHTMLFile
* @param mixed $coverageTextFile
* @param mixed $testdoxHTMLFile
* @param mixed $testdoxTextFile
* @param mixed $xmlLogfile
* @param boolean $wait
* @return PHPUnit2_Framework_TestResult
* @access public
*/
public function doRun(PHPUnit2_Framework_Test $suite, $coverageDataFile = FALSE, $coverageHTMLFile = FALSE, $coverageTextFile = FALSE, $testdoxHTMLFile = FALSE, $testdoxTextFile = FALSE, $xmlLogfile = FALSE, $wait = FALSE) {
$result = $this->createTestResult();
$timer = new Benchmark_Timer;
if ($this->printer === NULL) {
$this->printer = new PHPUnit2_TextUI_ResultPrinter;
}
$this->printer->write(
PHPUnit2_Runner_Version::getVersionString() . "\n\n"
);
$result->addListener($this->printer);
if ($testdoxHTMLFile !== FALSE || $testdoxTextFile !== FALSE) {
require_once 'PHPUnit2/Util/TestDox/ResultPrinter.php';
if ($testdoxHTMLFile !== FALSE) {
$result->addListener(
PHPUnit2_Util_TestDox_ResultPrinter::factory(
'HTML',
$testdoxHTMLFile
)
);
}
if ($testdoxTextFile !== FALSE) {
$result->addListener(
PHPUnit2_Util_TestDox_ResultPrinter::factory(
'Text',
$testdoxTextFile
)
);
}
}
if ($xmlLogfile !== FALSE) {
require_once 'PHPUnit2/Util/Log/XML.php';
$result->addListener(
new PHPUnit2_Util_Log_XML($xmlLogfile)
);
}
if ($coverageDataFile !== FALSE ||
$coverageHTMLFile !== FALSE ||
$coverageTextFile !== FALSE) {
$result->collectCodeCoverageInformation(TRUE);
}
$timer->start();
$suite->run($result);
$timer->stop();
$timeElapsed = $timer->timeElapsed();
$this->pause($wait);
$this->printer->printResult($result, $timeElapsed);
$this->handleCodeCoverageInformation(
$result,
$coverageDataFile,
$coverageHTMLFile,
$coverageTextFile
);
return $result;
}
/**
* Returns the loader to be used.
*
* @return PHPUnit2_Runner_TestSuiteLoader
* @access public
* @since Method available since Release 2.2.0
*/
public function getLoader() {
if ($this->loader === NULL) {
$this->loader = new PHPUnit2_Runner_StandardTestSuiteLoader;
}
return $this->loader;
}
/**
* @param PHPUnit2_Framework_TestResult $result
* @param mixed $coverageDataFile
* @param mixed $coverageHTMLFile
* @param mixed $coverageTextFile
* @access protected
* @since Method available since Release 2.1.0
*/
protected function handleCodeCoverageInformation(PHPUnit2_Framework_TestResult $result, $coverageDataFile, $coverageHTMLFile, $coverageTextFile) {
if ($coverageDataFile !== FALSE &&
$fp = fopen($coverageDataFile, 'w')) {
fputs($fp, serialize($result->getCodeCoverageInformation()));
fclose($fp);
}
if ($coverageHTMLFile !== FALSE || $coverageTextFile !== FALSE) {
require_once 'PHPUnit2/Util/CodeCoverage/Renderer.php';
if ($coverageHTMLFile !== FALSE) {
$renderer = PHPUnit2_Util_CodeCoverage_Renderer::factory(
'HTML',
$result->getCodeCoverageInformation()
);
$renderer->renderToFile($coverageHTMLFile);
}
if ($coverageTextFile !== FALSE) {
$renderer = PHPUnit2_Util_CodeCoverage_Renderer::factory(
'Text',
$result->getCodeCoverageInformation()
);
$renderer->renderToFile($coverageTextFile);
}
}
}
/**
* @access public
*/
public function showError($message) {
self::printVersionString();
print $message . "\n";
exit(self::FAILURE_EXIT);
}
/**
* @access public
*/
public function showHelp() {
self::printVersionString();
print "Usage: phpunit [switches] UnitTest [UnitTest.php]\n";
if (extension_loaded('xdebug')) {
print " --coverage-data <file> Write Code Coverage data in raw format to file.\n" .
" --coverage-html <file> Write Code Coverage data in HTML format to file.\n" .
" --coverage-text <file> Write Code Coverage data in text format to file.\n\n";
}
print " --testdox-html <file> Write agile documentation in HTML format to file.\n" .
" --testdox-text <file> Write agile documentation in Text format to file.\n" .
" --log-xml <file> Log test progress in XML format to file.\n\n";
print " --loader <loader> TestSuiteLoader implementation to use.\n\n" .
" --skeleton Generate skeleton UnitTest class for Unit in Unit.php.\n\n" .
" --wait Waits for a keystroke after each test.\n\n" .
" --help Prints this usage information.\n" .
" --version Prints the version and exits.\n";
}
/**
* @param boolean $wait
* @access protected
*/
protected function pause($wait) {
if (!$wait) {
return;
}
$this->printer->printWaitPrompt();
fgets(STDIN);
}
/**
* @param PHPUnit2_TextUI_ResultPrinter $resultPrinter
* @access public
*/
public function setPrinter(PHPUnit2_TextUI_ResultPrinter $resultPrinter) {
$this->printer = $resultPrinter;
}
/**
* A test started.
*
* @param string $testName
* @access public
*/
public function testStarted($testName) {
}
/**
* A test ended.
*
* @param string $testName
* @access public
*/
public function testEnded($testName) {
}
/**
* A test failed.
*
* @param integer $status
* @param PHPUnit2_Framework_Test $test
* @param PHPUnit2_Framework_AssertionFailedError $e
* @access public
*/
public function testFailed($status, PHPUnit2_Framework_Test $test, PHPUnit2_Framework_AssertionFailedError $e) {
}
/**
* Override to define how to handle a failed loading of
* a test suite.
*
* @param string $message
* @access protected
*/
protected function runFailed($message) {
self::printVersionString();
print $message;
exit(self::FAILURE_EXIT);
}
/**
* @access private
* @since Method available since Release 2.2.0
*/
private static function printVersionString() {
if (!self::$versionStringPrinted) {
print PHPUnit2_Runner_Version::getVersionString() . "\n\n";
self::$versionStringPrinted = TRUE;
}
}
}
if (PHPUnit2_MAIN_METHOD == 'PHPUnit2_TextUI_TestRunner::main') {
PHPUnit2_TextUI_TestRunner::main();
}
/*
* Local variables:
* tab-width: 4
* c-basic-offset: 4
* c-hanging-comment-ender-p: nil
* End:
*/
?>