home *** CD-ROM | disk | FTP | other *** search
- <?php
- //
- // +------------------------------------------------------------------------+
- // | PEAR :: PHPUnit |
- // +------------------------------------------------------------------------+
- // | Copyright (c) 2002-2003 Sebastian Bergmann <sb@sebastian-bergmann.de>. |
- // +------------------------------------------------------------------------+
- // | 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: TestDecorator.php,v 1.4 2003/03/26 18:04:32 sebastian Exp $
- //
-
- require_once 'PHPUnit/TestCase.php';
- require_once 'PHPUnit/TestSuite.php';
-
- /**
- * A Decorator for Tests.
- *
- * Use TestDecorator as the base class for defining new
- * test decorators. Test decorator subclasses can be introduced
- * to add behaviour before or after a test is run.
- *
- * @package PHPUnit
- * @author Sebastian Bergmann <sb@sebastian-bergmann.de>
- * Based upon JUnit, see http://www.junit.org/ for details.
- */
- class PHPUnit_TestDecorator {
- /**
- * The Test to be decorated.
- *
- * @var object
- * @access protected
- */
- var $_test = null;
-
- /**
- * Constructor.
- *
- * @param object
- * @access public
- */
- function PHPUnit_TestDecorator(&$test) {
- if (is_object($test) &&
- (is_a($test, 'PHPUnit_TestCase') ||
- is_a($test, 'PHPUnit_TestSuite'))) {
-
- $this->_test = $test;
- }
- }
-
- /**
- * Runs the test and collects the
- * result in a TestResult.
- *
- * @param object
- * @access public
- */
- function basicRun(&$result) {
- $this->_test->run($result);
- }
-
- /**
- * Counts the number of test cases that
- * will be run by this test.
- *
- * @return integer
- * @access public
- */
- function countTestCases() {
- return $this->_test->countTestCases();
- }
-
- /**
- * Returns the test to be run.
- *
- * @return object
- * @access public
- */
- function &getTest() {
- return $this->_test;
- }
-
- /**
- * Runs the decorated test and collects the
- * result in a TestResult.
- *
- * @param object
- * @access public
- * @abstract
- */
- function run(&$result) { /* abstract */ }
-
- /**
- * Returns a string representation of the test.
- *
- * @return string
- * @access public
- */
- function toString() {
- return $this->_test->toString();
- }
- }
- ?>
-