4 * The EnvTests suite allows you to specify an arbitrary mix of tests
5 * using an environment variable. For example:
7 * env PHPUNIT_TESTS="MyFirstTest MySecondTest" phpunit EnvTests
9 * The PHPUNIT_TESTS variable contains a space-delimited list of test
10 * names. Each name may be a class (eg "MyFirstTest") or a method
11 * (eg "MyFirstTest::testFoo").
13 class EnvTests
extends \PHPUnit_Framework_TestSuite
{
17 public static function suite() {
18 require_once 'CRM/Core/ClassLoader.php';
19 CRM_Core_ClassLoader
::singleton()->register();
21 $suite = new EnvTests();
22 $tests = getenv('PHPUNIT_TESTS');
23 foreach (explode(' ', $tests) as $test) {
24 if (strpos($test, '::') !== FALSE) {
25 list ($class, $method) = explode('::', $test);
26 $clazz = new \
ReflectionClass($class);
27 $suite->addTestMethod($clazz, $clazz->getMethod($method));
30 $suite->addTestSuite($test);