. * 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 * @copyright 2002-2006 Sebastian Bergmann * @license http://www.opensource.org/licenses/bsd-license.php BSD License * @version CVS: $Id: TestCase.php,v 1.32.2.5 2005/12/17 16:04:56 sebastian Exp $ * @link http://pear.php.net/package/PHPUnit2 * @since File available since Release 2.0.0 */ require_once 'PHPUnit2/Framework/Assert.php'; require_once 'PHPUnit2/Framework/Error.php'; require_once 'PHPUnit2/Framework/Test.php'; require_once 'PHPUnit2/Framework/TestResult.php'; /** * A TestCase defines the fixture to run multiple tests. * * To define a TestCase * * 1) Implement a subclass of PHPUnit2_Framework_TestCase. * 2) Define instance variables that store the state of the fixture. * 3) Initialize the fixture state by overriding setUp(). * 4) Clean-up after a test by overriding tearDown(). * * Each test runs in its own fixture so there can be no side effects * among test runs. * * Here is an example: * * * value1 = 2; * $this->value2 = 3; * } * } * ?> * * * For each test implement a method which interacts with the fixture. * Verify the expected results with assertions specified by calling * assert with a boolean. * * * assertTrue($this->value1 + $this->value2 == 5); * } * ?> * * * @category Testing * @package PHPUnit2 * @author Sebastian Bergmann * @copyright 2002-2006 Sebastian Bergmann * @license http://www.opensource.org/licenses/bsd-license.php BSD License * @version Release: @package_version@ * @link http://pear.php.net/package/PHPUnit2 * @since Class available since Release 2.0.0 * @abstract */ abstract class PHPUnit2_Framework_TestCase extends PHPUnit2_Framework_Assert implements PHPUnit2_Framework_Test { /** * The name of the test case. * * @var string * @access private */ private $name = NULL; /** * Constructs a test case with the given name. * * @param string * @access public */ public function __construct($name = NULL) { if ($name !== NULL) { $this->setName($name); } } /** * Returns a string representation of the test case. * * @return string * @access public */ public function toString() { $class = new ReflectionClass($this); return sprintf( '%s(%s)', $this->getName(), $class->name ); } /** * Counts the number of test cases executed by run(TestResult result). * * @return integer * @access public */ public function countTestCases() { return 1; } /** * Gets the name of a TestCase. * * @return string * @access public */ public function getName() { return $this->name; } /** * Runs the test case and collects the results in a TestResult object. * If no TestResult object is passed a new one will be created. * * @param PHPUnit2_Framework_TestResult $result * @return PHPUnit2_Framework_TestResult * @throws Exception * @access public */ public function run($result = NULL) { if ($result === NULL) { $result = $this->createResult(); } // XXX: Workaround for missing ability to declare type-hinted parameters as optional. else if (!($result instanceof PHPUnit2_Framework_TestResult)) { throw new Exception( 'Argument 1 must be an instance of PHPUnit2_Framework_TestResult.' ); } $result->run($this); return $result; } /** * Runs the bare test sequence. * * @access public */ public function runBare() { $catchedException = NULL; $this->setUp(); try { $this->runTest(); } catch (Exception $e) { $catchedException = $e; } $this->tearDown(); // Workaround for missing "finally". if ($catchedException !== NULL) { throw $catchedException; } } /** * Override to run the test and assert its state. * * @throws PHPUnit2_Framework_Error * @access protected */ protected function runTest() { if ($this->name === NULL) { throw new PHPUnit2_Framework_Error( 'PHPUnit2_Framework_TestCase::$name must not be NULL.' ); } try { $class = new ReflectionClass($this); $method = $class->getMethod($this->name); } catch (ReflectionException $e) { $this->fail($e->getMessage()); } $method->invoke($this); } /** * Sets the name of a TestCase. * * @param string * @access public */ public function setName($name) { $this->name = $name; } /** * Creates a default TestResult object. * * @return PHPUnit2_Framework_TestResult * @access protected */ protected function createResult() { return new PHPUnit2_Framework_TestResult; } /** * Sets up the fixture, for example, open a network connection. * This method is called before a test is executed. * * @access protected */ protected function setUp() { } /** * Tears down the fixture, for example, close a network connection. * This method is called after a test is executed. * * @access protected */ protected function tearDown() { } } /* * Local variables: * tab-width: 4 * c-basic-offset: 4 * c-hanging-comment-ender-p: nil * End: */ ?>