<?php
//
// +----------------------------------------------------------------------+
// | PEAR :: PHPUnit                                                      |
// +----------------------------------------------------------------------+
// | Copyright (c) 2002 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: TestSuite.php,v 1.1 2003/04/23 03:53:13 vieglais Exp $
//

require_once 'PHPUnit/TestCase.php';

/**
 * A TestSuite is a Composite of Tests. It runs a collection of test cases.
 *
 * Here is an example using the dynamic test definition. 
 *
 *   $suite = new PHPUnit_TestSuite();
 *   $suite->addTest(new MathTest('testPass'));
 *
 * Alternatively, a TestSuite can extract the tests to be run automatically.
 * To do so you pass the classname of your TestCase class to the TestSuite
 * constructor. 
 *
 *   $suite = new TestSuite('classname');
 *
 * This constructor creates a suite with all the methods starting with
 * "test" that take no arguments.
 *
 * @package PHPUnit
 * @author  Sebastian Bergmann <sb@sebastian-bergmann.de>
 *          Based upon JUnit, see http://www.junit.org/ for details.
 */
class PHPUnit_TestSuite {
    /**
    * The name of the test suite.
    *
    * @var    string
    * @access private
    */
    var $_name = '';

    /**
    * The tests in the test suite.
    *
    * @var    array
    * @access private
    */
    var $_tests = array();

    /**
    * Constructs a TestSuite.
    *
    * @param  mixed
    * @access public
    */
    function PHPUnit_TestSuite($test = false) {
        if ($test != false) {
            $this->setName($test);
            $this->addTestSuite($test);
        }
    }

    /**
    * Adds a test to the suite.
    *
    * @param  object
    * @access public
    */
    function addTest(&$test) {
        $this->_tests[] = $test;
    }

    /**
    * Adds the tests from the given class to the suite.
    *
    * @param  string
    * @access public
    */
    function addTestSuite($testClass) {
        if (class_exists($testClass)) {
            $methods = get_class_methods($testClass);

            foreach ($methods as $method) {
                if (substr($method, 0, 4) == 'test') {
                    $this->addTest(new $testClass($method));
                }
            }
        }
    }

    /**
    * Counts the number of test cases that will be run by this test.
    *
    * @return integer
    * @access public
    */
    function countTestCases() {
        $count = 0;

        foreach ($this->_tests as $test) {
            $count += $test->countTestCases();
        }

        return $count;
    }

    /**
    * Returns the name of the suite.
    *
    * @return string
    * @access public
    */
    function getName() {
        return $this->_name;
    }

    /**
    * Runs the tests and collects their result in a TestResult.
    *
    * @param  object
    * @access public
    */
    function run(&$result) {
        for ($i = 0; $i < sizeof($this->_tests) && !$result->shouldStop(); $i++) {
            $this->_tests[$i]->run($result);
        }
    }

    /**
    * Runs a test.
    *
    * @param  object
    * @param  object
    * @access public
    */
    function runTest(&$test, &$result) {
        $test->run($result);
    }

    /**
    * Sets the name of the suite.
    *
    * @param  string
    * @access public
    */
    function setName($name) {
        $this->_name = $name;
    }

    /**
    * Returns the test at the given index.
    *
    * @param  integer
    * @return object
    * @access public
    */
    function &testAt($index) {
        if (isset($this->_tests[$index])) {
            return $this->_tests[$index];
        } else {
            return false;
        }
    }

    /**
    * Returns the number of tests in this suite.
    *
    * @return integer
    * @access public
    */
    function testCount() {
        return sizeof($this->_tests);
    }

    /**
    * Returns the tests as an enumeration.
    *
    * @return array
    * @access public
    */
    function &tests() {
        return $this->_tests;
    }

    /**
    * Returns a string representation of the test suite.
    *
    * @return string
    * @access public
    */
    function toString() {
        return '';
    }
}
?>
