. |
// +------------------------------------------------------------------------+
// | This source file is subject to version 3.00 of the PHP License, |
// | that is available at http://www.php.net/license/3_0.txt. |
// | If you did not receive a copy of the PHP license and are unable to |
// | obtain it through the world-wide-web, please send a note to |
// | license@php.net so we can mail you a copy immediately. |
// +------------------------------------------------------------------------+
//
// $Id: RepeatedTest.php,v 1.10 2004/12/22 08:06:11 sebastian Exp $
//
require_once 'PHPUnit/TestDecorator.php';
/**
* A Decorator that runs a test repeatedly.
*
* Here is an example:
*
*
* PHPUnit_TestCase($name);
* }
*
* function setUp() {
* $this->fValue1 = 2;
* $this->fValue2 = 3;
* }
*
* function testAdd() {
* $this->assertTrue($this->fValue1 + $this->fValue2 == 5);
* }
* }
*
* $suite = new PHPUnit_TestSuite;
*
* $suite->addTest(
* new PHPUnit_RepeatedTest(
* new MathTest('testAdd'),
* 10
* )
* );
*
* $result = PHPUnit::run($suite);
* print $result->toString();
* ?>
*
*
* @author Sebastian Bergmann
* @copyright Copyright © 2002-2005 Sebastian Bergmann
* @license http://www.php.net/license/3_0.txt The PHP License, Version 3.0
* @category Testing
* @package PHPUnit
*/
class PHPUnit_RepeatedTest extends PHPUnit_TestDecorator {
/**
* @var integer
* @access private
*/
var $_timesRepeat = 1;
/**
* Constructor.
*
* @param object
* @param integer
* @access public
*/
function PHPUnit_RepeatedTest(&$test, $timesRepeat = 1) {
$this->PHPUnit_TestDecorator($test);
$this->_timesRepeat = $timesRepeat;
}
/**
* Counts the number of test cases that
* will be run by this test.
*
* @return integer
* @access public
*/
function countTestCases() {
return $this->_timesRepeat * $this->_test->countTestCases();
}
/**
* Runs the decorated test and collects the
* result in a TestResult.
*
* @param object
* @access public
* @abstract
*/
function run(&$result) {
for ($i = 0; $i < $this->_timesRepeat; $i++) {
$this->_test->run($result);
}
}
}
?>