_resolveTestFile($filePath, $params); return parent::load('', $file); } /** * Convert path fragments used by Cake's test runner to absolute paths that can be fed to PHPUnit. * * @return void */ protected function _resolveTestFile($filePath, $params) { $basePath = $this->_basePath($params) . DS . $filePath; $ending = 'Test.php'; return (strpos($basePath, $ending) === (strlen($basePath) - strlen($ending))) ? $basePath : $basePath . $ending; } /** * Generates the base path to a set of tests based on the parameters. * * @param array $params * @return string The base path. */ protected static function _basePath($params) { $result = null; if (!empty($params['core'])) { $result = CORE_TEST_CASES; } elseif (!empty($params['app'])) { $result = APP_TEST_CASES; } else if (!empty($params['plugin'])) { if (!CakePlugin::loaded($params['plugin'])) { CakePlugin::load($params['plugin']); } $pluginPath = CakePlugin::path($params['plugin']); $result = $pluginPath . 'Test' . DS . 'Case'; } return $result; } /** * Get the list of files for the test listing. * * @return void */ public static function generateTestList($params) { $directory = self::_basePath($params); $fileList = self::_getRecursiveFileList($directory); $testCases = array(); foreach ($fileList as $testCaseFile) { $case = str_replace($directory . DS, '', $testCaseFile); $case = str_replace('Test.php', '', $case); $testCases[$testCaseFile] = $case; } sort($testCases); return $testCases; } /** * Gets a recursive list of files from a given directory and matches then against * a given fileTestFunction, like isTestCaseFile() * * @param string $directory The directory to scan for files. * @param mixed $fileTestFunction */ protected static function _getRecursiveFileList($directory = '.') { $fileList = array(); if (!is_dir($directory)) { return $fileList; } $files = new RegexIterator( new RecursiveIteratorIterator(new RecursiveDirectoryIterator($directory)), '/.*Test.php$/' ); foreach ($files as $file) { $fileList[] = $file->getPathname(); } return $fileList; } }