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
{
18 public static function suite() {
19 require_once 'CRM/Core/ClassLoader.php';
20 CRM_Core_ClassLoader
::singleton()->register();
22 $suite = new EnvTests();
23 $tests = getenv('PHPUNIT_TESTS');
24 foreach (explode(' ', $tests) as $test) {
25 if (strpos($test, '::') !== FALSE) {
26 list ($class, $method) = explode('::', $test);
27 $clazz = new \
ReflectionClass($class);
28 $suite->addTestMethod($clazz, $clazz->getMethod($method));
31 $suite->addTestSuite($test);