2010-01-05 20:29:08 -05:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* CakeBaseReporter contains common functionality to all cake test suite reporters.
|
|
|
|
*
|
|
|
|
* PHP versions 4 and 5
|
|
|
|
*
|
|
|
|
* CakePHP(tm) Tests <https://trac.cakephp.org/wiki/Developement/TestSuite>
|
|
|
|
* Copyright 2005-2009, Cake Software Foundation, Inc. (http://cakefoundation.org)
|
|
|
|
*
|
|
|
|
* Licensed under The Open Group Test Suite License
|
|
|
|
* Redistributions of files must retain the above copyright notice.
|
|
|
|
*
|
|
|
|
* @copyright Copyright 2005-2009, Cake Software Foundation, Inc. (http://cakefoundation.org)
|
2010-01-26 17:03:03 -05:00
|
|
|
* @link http://cakephp.org CakePHP(tm) Project
|
2010-01-05 20:29:08 -05:00
|
|
|
* @package cake
|
2010-01-09 20:20:13 -05:00
|
|
|
* @subpackage cake.tests.libs.reporter
|
2010-01-05 20:29:08 -05:00
|
|
|
* @since CakePHP(tm) v 1.3
|
|
|
|
* @license http://www.opensource.org/licenses/opengroup.php The Open Group Test Suite License
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* CakeBaseReporter contains common reporting features used in the CakePHP Test suite
|
|
|
|
*
|
|
|
|
* @package cake
|
|
|
|
* @subpackage cake.tests.lib
|
|
|
|
*/
|
2010-05-04 13:50:07 -04:30
|
|
|
class CakeBaseReporter {
|
2010-01-05 20:29:08 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Time the test runs started.
|
|
|
|
*
|
|
|
|
* @var integer
|
|
|
|
* @access protected
|
|
|
|
*/
|
2010-04-04 16:36:12 +10:00
|
|
|
protected $_timeStart = 0;
|
2010-01-05 20:29:08 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Time the test runs ended
|
|
|
|
*
|
|
|
|
* @var integer
|
|
|
|
* @access protected
|
|
|
|
*/
|
2010-04-04 16:36:12 +10:00
|
|
|
protected $_timeEnd = 0;
|
2010-01-05 20:29:08 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Duration of all test methods.
|
|
|
|
*
|
|
|
|
* @var integer
|
|
|
|
* @access protected
|
|
|
|
*/
|
2010-04-04 16:36:12 +10:00
|
|
|
protected $_timeDuration = 0;
|
2010-01-05 20:29:08 -05:00
|
|
|
|
2010-01-09 11:20:47 -05:00
|
|
|
/**
|
|
|
|
* Array of request parameters. Usually parsed GET params.
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
2010-04-04 17:14:00 +10:00
|
|
|
public $params = array();
|
2010-01-09 11:20:47 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Character set for the output of test reporting.
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
* @access protected
|
|
|
|
*/
|
2010-04-04 16:36:12 +10:00
|
|
|
protected $_characterSet;
|
2010-01-09 11:20:47 -05:00
|
|
|
|
2010-05-04 16:31:03 -04:30
|
|
|
/**
|
|
|
|
* The number of assertions done for a test suite
|
|
|
|
*/
|
|
|
|
protected $numAssertions = 0;
|
2010-01-09 11:20:47 -05:00
|
|
|
/**
|
|
|
|
* Does nothing yet. The first output will
|
|
|
|
* be sent on the first test start.
|
|
|
|
*
|
|
|
|
* ### Params
|
|
|
|
*
|
|
|
|
* - show_passes - Should passes be shown
|
|
|
|
* - plugin - Plugin test being run?
|
|
|
|
* - app - App test being run.
|
|
|
|
* - case - The case being run
|
2010-01-10 13:24:41 -05:00
|
|
|
* - codeCoverage - Whether the case/group being run is being code covered.
|
2010-01-09 11:20:47 -05:00
|
|
|
*
|
|
|
|
* @param string $charset The character set to output with. Defaults to UTF-8
|
|
|
|
* @param array $params Array of request parameters the reporter should use. See above.
|
|
|
|
*/
|
2010-04-14 22:56:51 -04:00
|
|
|
function __construct($charset = 'utf-8', $params = array()) {
|
2010-01-10 12:48:11 -05:00
|
|
|
if (!$charset) {
|
|
|
|
$charset = 'utf-8';
|
|
|
|
}
|
2010-01-09 11:20:47 -05:00
|
|
|
$this->_characterSet = $charset;
|
|
|
|
$this->params = $params;
|
|
|
|
}
|
|
|
|
|
2010-01-05 20:29:08 -05:00
|
|
|
/**
|
|
|
|
* Signals / Paints the beginning of a TestSuite executing.
|
|
|
|
* Starts the timer for the TestSuite execution time.
|
|
|
|
*
|
|
|
|
* @param string $test_name Name of the test that is being run.
|
|
|
|
* @param integer $size
|
|
|
|
* @return void
|
|
|
|
*/
|
2010-04-14 22:56:51 -04:00
|
|
|
public function paintGroupStart($test_name, $size) {
|
2010-01-05 20:29:08 -05:00
|
|
|
if (empty($this->_timeStart)) {
|
2010-04-16 02:58:28 +10:00
|
|
|
$this->_timeStart = microtime(true);
|
2010-01-05 20:29:08 -05:00
|
|
|
}
|
|
|
|
parent::paintGroupStart($test_name, $size);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Signals/Paints the end of a TestSuite. All test cases have run
|
|
|
|
* and timers are stopped.
|
|
|
|
*
|
|
|
|
* @param string $test_name Name of the test that is being run.
|
|
|
|
* @return void
|
|
|
|
*/
|
2010-04-14 22:56:51 -04:00
|
|
|
public function paintGroupEnd($test_name) {
|
2010-04-16 02:58:28 +10:00
|
|
|
$this->_timeEnd = microtime(true);
|
2010-01-05 20:29:08 -05:00
|
|
|
$this->_timeDuration = $this->_timeEnd - $this->_timeStart;
|
|
|
|
parent::paintGroupEnd($test_name);
|
|
|
|
}
|
|
|
|
|
2010-01-10 13:24:41 -05:00
|
|
|
/**
|
|
|
|
* Paints the beginning of a test method being run. This is used
|
|
|
|
* to start/resume the code coverage tool.
|
|
|
|
*
|
|
|
|
* @param string $method The method name being run.
|
|
|
|
* @return void
|
|
|
|
*/
|
2010-04-14 22:56:51 -04:00
|
|
|
public function paintMethodStart($method) {
|
2010-01-10 13:24:41 -05:00
|
|
|
parent::paintMethodStart($method);
|
|
|
|
if (!empty($this->params['codeCoverage'])) {
|
|
|
|
CodeCoverageManager::start();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Paints the end of a test method being run. This is used
|
|
|
|
* to pause the collection of code coverage if its being used.
|
|
|
|
*
|
|
|
|
* @param string $method The name of the method being run.
|
|
|
|
* @return void
|
|
|
|
*/
|
2010-04-14 22:56:51 -04:00
|
|
|
public function paintMethodEnd($method) {
|
2010-01-10 13:24:41 -05:00
|
|
|
parent::paintMethodEnd($method);
|
|
|
|
if (!empty($this->params['codeCoverage'])) {
|
|
|
|
CodeCoverageManager::stop();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-01-05 22:52:25 -05:00
|
|
|
/**
|
|
|
|
* Retrieves a list of test cases from the active Manager class,
|
|
|
|
* displaying it in the correct format for the reporter subclass
|
|
|
|
*
|
|
|
|
* @return mixed
|
|
|
|
*/
|
2010-04-14 22:56:51 -04:00
|
|
|
public function testCaseList() {
|
2010-01-09 10:55:58 -05:00
|
|
|
$testList = TestManager::getTestCaseList();
|
|
|
|
return $testList;
|
2010-01-05 22:52:25 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves a list of group test cases from the active Manager class
|
|
|
|
* displaying it in the correct format for the reporter subclass.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2010-04-14 22:56:51 -04:00
|
|
|
public function groupTestList() {
|
2010-01-09 10:55:58 -05:00
|
|
|
$testList = TestManager::getGroupTestList();
|
|
|
|
return $testList;
|
2010-01-06 22:52:04 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2010-01-09 11:20:47 -05:00
|
|
|
* Paints the start of the response from the test suite.
|
2010-01-06 22:52:04 -05:00
|
|
|
* Used to paint things like head elements in an html page.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2010-04-14 22:56:51 -04:00
|
|
|
public function paintDocumentStart() {
|
2010-01-06 22:52:04 -05:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2010-01-09 11:20:47 -05:00
|
|
|
* Paints the end of the response from the test suite.
|
2010-01-06 22:52:04 -05:00
|
|
|
* Used to paint things like </body> in an html page.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2010-04-14 22:56:51 -04:00
|
|
|
public function paintDocumentEnd() {
|
2010-01-09 11:20:47 -05:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Paint a list of test sets, core, app, and plugin test sets
|
|
|
|
* available.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2010-04-14 22:56:51 -04:00
|
|
|
public function paintTestMenu() {
|
2010-01-05 22:52:25 -05:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2010-01-09 11:20:47 -05:00
|
|
|
/**
|
|
|
|
* Get the baseUrl if one is available.
|
|
|
|
*
|
|
|
|
* @return string The base url for the request.
|
|
|
|
*/
|
2010-04-14 22:56:51 -04:00
|
|
|
public function baseUrl() {
|
2010-01-09 11:20:47 -05:00
|
|
|
if (!empty($_SERVER['PHP_SELF'])) {
|
|
|
|
return $_SERVER['PHP_SELF'];
|
|
|
|
}
|
|
|
|
return '';
|
|
|
|
}
|
|
|
|
|
2010-01-05 20:29:08 -05:00
|
|
|
}
|
2010-01-05 22:52:25 -05:00
|
|
|
?>
|