diff options
author | xue <> | 2006-07-16 01:50:23 +0000 |
---|---|---|
committer | xue <> | 2006-07-16 01:50:23 +0000 |
commit | af68030fcf0c266300feb2c100149ecadef7d364 (patch) | |
tree | 76b7c8ad5d8227870b9ef10c3e7b92a36336b320 /tests/test_tools/simpletest/detached.php | |
parent | 4b78404c20490a615459267426ce9e6737bf4485 (diff) |
Merge from 3.0 branch till 1264.
Diffstat (limited to 'tests/test_tools/simpletest/detached.php')
-rw-r--r-- | tests/test_tools/simpletest/detached.php | 96 |
1 files changed, 96 insertions, 0 deletions
diff --git a/tests/test_tools/simpletest/detached.php b/tests/test_tools/simpletest/detached.php new file mode 100644 index 00000000..00f08880 --- /dev/null +++ b/tests/test_tools/simpletest/detached.php @@ -0,0 +1,96 @@ +<?php + /** + * base include file for SimpleTest + * @package SimpleTest + * @subpackage UnitTester + * @version $Id: detached.php,v 1.1 2005/12/08 19:35:06 lastcraft Exp $ + */ + + /**#@+ + * include other SimpleTest class files + */ + require_once(dirname(__FILE__) . '/xml.php'); + require_once(dirname(__FILE__) . '/shell_tester.php'); + /**#@-*/ + + /** + * Runs an XML formated test in a separate process. + * @package SimpleTest + * @subpackage UnitTester + */ + class DetachedTestCase { + protected $_command; + protected $_dry_command; + protected $_size; + + /** + * Sets the location of the remote test. + * @param string $command Test script. + * @param string $dry_command Script for dry run. + * @access public + */ + function DetachedTestCase($command, $dry_command = false) { + $this->_command = $command; + $this->_dry_command = $dry_command ? $dry_command : $command; + $this->_size = false; + } + + /** + * Accessor for the test name for subclasses. + * @return string Name of the test. + * @access public + */ + function getLabel() { + return $this->_command; + } + + /** + * Runs the top level test for this class. Currently + * reads the data as a single chunk. I'll fix this + * once I have added iteration to the browser. + * @param SimpleReporter $reporter Target of test results. + * @returns boolean True if no failures. + * @access public + */ + function run($reporter) { + $shell = new SimpleShell(); + $shell->execute($this->_command); + $parser = $this->_createParser($reporter); + if (! $parser->parse($shell->getOutput())) { + trigger_error('Cannot parse incoming XML from [' . $this->_command . ']'); + return false; + } + return true; + } + + /** + * Accessor for the number of subtests. + * @return integer Number of test cases. + * @access public + */ + function getSize() { + if ($this->_size === false) { + $shell = new SimpleShell(); + $shell->execute($this->_dry_command); + $reporter = new SimpleReporter(); + $parser = $this->_createParser($reporter); + if (! $parser->parse($shell->getOutput())) { + trigger_error('Cannot parse incoming XML from [' . $this->_dry_command . ']'); + return false; + } + $this->_size = $reporter->getTestCaseCount(); + } + return $this->_size; + } + + /** + * Creates the XML parser. + * @param SimpleReporter $reporter Target of test results. + * @return SimpleTestXmlListener XML reader. + * @access protected + */ + function &_createParser($reporter) { + return new SimpleTestXmlParser($reporter); + } + } +?>
\ No newline at end of file |