coverage; } /** * Setter for $coverage (@see $coverage). * @parameter $value Boolean */ public function setCoverageStatus($value) { $this->coverage = $value; } /** * Getter for $suite (@see $suite). * @return PHPUnit_Framework_TestSuite */ public function getSuite() { return $this->suite; } /** * Setter for $suite (@see $suite). * @param $value PHPUnit_Framework_TestSuite */ public function setSuite($value) { $this->suite = $value; } /** * Getter for $reporter (@see $reporter). * @return PHPUnit_Framework_TestListener */ public function getReporter() { return $this->reporter; } /** * Setter for $reporter (@see $reporter). * @param $value PHPUnit_Framework_TestListener */ public function setReporter($value) { $this->reporter = $value; } /** * Getter for $results (@see $results). * @return PHPUnit_Framework_TestResult */ public function getFrameworkTestResults() { return $this->results; } /** * Setter for $results (@see $results). * @param $value PHPUnit_Framework_TestResult */ public function setFrameworkTestResults($value) { $this->results = $value; } /** * Getter for $version (@see $version). * @return String */ public function getVersion() { return $this->version; } /** * Loads and initiates phpunit, based on the available phpunit version. * * @return PhpUnitWrapper Instance of the php-wrapper class */ public static function inst() { if (self::$phpunit_wrapper == null) { // Loaded via autoloader, composer or other generic if (class_exists('PHPUnit_Runner_Version')) { self::$phpunit_wrapper = new PhpUnitWrapper_Generic(); } // 3.5 detection else if (fileExistsInIncludePath("/PHPUnit/Autoload.php")) { self::$phpunit_wrapper = new PhpUnitWrapper_3_5(); } // 3.4 detection else if (fileExistsInIncludePath("/PHPUnit/Framework.php")) { self::$phpunit_wrapper = new PhpUnitWrapper_3_4(); } // No version found - will lead to an error else { self::$phpunit_wrapper = new PhpUnitWrapper(); } self::$phpunit_wrapper->init(); } return self::$phpunit_wrapper; } /** * Returns true if one of the two supported PHPUNIT versions is installed. * * @return boolean true if PHPUnit has been installed on the environment. */ static function has_php_unit() { return (Bool) self::inst()->getVersion(); } /** * Implements method, defined in the interface IPhpUnitWrapper:init (@see IPhpUnitWrapper). * This wrapper class doesn't require any initialisation. */ public function init() { } /** * This method is called before the unittests are performed. * This wrapper implements the non-PHPUnit version which means that unit tests * can not be performed. * @throws PhpUnitWrapper_Excption */ protected function beforeRunTests() { throw new PhpUnitWrapper_Exception('Method \'beforeRunTests\' not implemented in PhpUnitWrapper.'); } /** * This method is called after the unittests are performed. * This wrapper implements the non-PHPUnit version which means that unit tests * can not be performed. * @throws PhpUnitWrapper_Excption */ protected function afterRunTests() { throw new PhpUnitWrapper_Exception('Method \'afterRunTests\' not implemented in PhpUnitWrapper.'); } /** * Perform all tests, added to the suite and initialises Sapphire to collect * the results of the unit tests. * * This method calls @see beforeRunTests and @see afterRunTests. */ public function runTests() { if(Director::is_cli()) { $this->setReporter( new CliTestReporter() ); } else { $this->setReporter( new SapphireTestReporter() ); } if ($this->getFrameworkTestResults() == null) { $this->setFrameworkTestResults(new PHPUnit_Framework_TestResult()); } $this->getFrameworkTestResults()->addListener( $this->getReporter() ); $this->beforeRunTests(); $this->getSuite()->run($this->getFrameworkTestResults()); $this->afterRunTests(); } } /** * Interface, implementing the general PHPUnit wrapper API. */ interface IPhpUnitWrapper { public function init(); public function runTests(); } /** * PHPUnitWrapper Exception class */ class PhpUnitWrapper_Exception extends Exception {} // If PHPUnit is not installed on the local environment, declare the class to // ensure that missing class declarations are available to avoind any PHP fatal // errors. // if(!PhpUnitWrapper::has_php_unit()) { /** * PHPUnit is a testing framework that can be installed using PEAR. * It's not bundled with Sapphire, you will need to install it yourself. * * @package sapphire * @subpackage testing */ class PHPUnit_Framework_TestCase { } }