mirror of
https://github.com/Pathduck/gallery3.git
synced 2026-05-19 19:09:13 -04:00
Add support for filtering tests down to the Class::method level.
This commit is contained in:
@@ -23,13 +23,14 @@ class Unit_Test_Core {
|
||||
/**
|
||||
* Sets the test path(s), runs the tests inside and stores the results.
|
||||
*
|
||||
* @param string(s) test path(s)
|
||||
* @param array test path(s)
|
||||
* @param string filter (regular expression)
|
||||
* @return void
|
||||
*/
|
||||
public function __construct()
|
||||
public function __construct($extra_paths=array(), $filter=null)
|
||||
{
|
||||
// Merge possible default test path(s) from config with the rest
|
||||
$paths = array_merge(func_get_args(), Kohana::config('unit_test.paths', FALSE, FALSE));
|
||||
$paths = array_merge($extra_paths, Kohana::config('unit_test.paths', FALSE, FALSE));
|
||||
|
||||
// Normalize all test paths
|
||||
foreach ($paths as $path)
|
||||
@@ -64,10 +65,6 @@ class Unit_Test_Core {
|
||||
// The class name should be the same as the file name
|
||||
$class = substr($path, strrpos($path, '/') + 1, -(strlen(EXT)));
|
||||
|
||||
if (count($_SERVER['argv']) > 2 && !in_array($class, $_SERVER['argv'])) {
|
||||
continue;
|
||||
}
|
||||
|
||||
// Skip hidden files
|
||||
if (substr($class, 0, 1) === '.')
|
||||
continue;
|
||||
@@ -125,6 +122,10 @@ class Unit_Test_Core {
|
||||
if ( ! $method->isPublic() OR $method->isStatic() OR $method->getNumberOfRequiredParameters() !== 0)
|
||||
continue;
|
||||
|
||||
if ($filter && !preg_match("/$filter/i", "$class::{$method->getName()}")) {
|
||||
continue;
|
||||
}
|
||||
|
||||
// Test methods should be suffixed with "_test"
|
||||
if (substr($method_name = $method->getName(), -5) !== '_test')
|
||||
continue;
|
||||
@@ -187,6 +188,11 @@ class Unit_Test_Core {
|
||||
// Cleanup
|
||||
unset($object);
|
||||
}
|
||||
|
||||
if ($filter && $this->stats[$class]['total'] == 0) {
|
||||
unset($this->results[$class]);
|
||||
unset($this->stats[$class]);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user