mirror of
https://github.com/phpbb/phpbb.git
synced 2025-06-28 22:28:51 +00:00
[ticket/13809] Test each file individually
PHPBB3-13809
This commit is contained in:
parent
b73b9f1dec
commit
923fdb0aa0
1 changed files with 28 additions and 21 deletions
|
@ -38,31 +38,34 @@ class phpbb_lint_test extends phpbb_test_case
|
|||
self::markTestSkipped(sprintf('Could not run PHP_BINARY %s. Output: %s', self::$php_binary, $output));
|
||||
}
|
||||
}
|
||||
|
||||
self::$exclude = array(
|
||||
dirname(__FILE__) . '/../.git',
|
||||
dirname(__FILE__) . '/../build/new_version',
|
||||
dirname(__FILE__) . '/../build/old_versions',
|
||||
dirname(__FILE__) . '/../phpBB/cache',
|
||||
// PHP Fatal error: Cannot declare class Container because the name is already in use in /var/www/projects/phpbb3/tests/../phpBB/vendor/symfony/dependency-injection/Symfony/Component/DependencyInjection/Tests/Fixtures/php/services1-1.php on line 20
|
||||
// https://gist.github.com/e003913ffd493da63cbc
|
||||
dirname(__FILE__) . '/../phpBB/vendor',
|
||||
);
|
||||
}
|
||||
|
||||
public function test_lint()
|
||||
/**
|
||||
* @dataProvider lint_data
|
||||
*/
|
||||
public function test_lint($path)
|
||||
{
|
||||
if (version_compare(PHP_VERSION, '5.3.0', '<'))
|
||||
{
|
||||
$this->markTestSkipped('phpBB uses PHP 5.3 syntax in some files, linting on PHP < 5.3 will fail');
|
||||
}
|
||||
|
||||
$root = dirname(__FILE__) . '/..';
|
||||
$this->check($root);
|
||||
$cmd = sprintf('(%s -l %s) 2>&1', self::$php_binary, escapeshellarg($path));
|
||||
$output = array();
|
||||
$status = 1;
|
||||
exec($cmd, $output, $status);
|
||||
$output = implode("\n", $output);
|
||||
$this->assertEquals(0, $status, "PHP lint failed for $path:\n$output");
|
||||
}
|
||||
|
||||
public function lint_data()
|
||||
{
|
||||
return $this->check(dirname(__FILE__) . '/..');
|
||||
}
|
||||
|
||||
protected function check($root)
|
||||
{
|
||||
$files = array();
|
||||
$dh = opendir($root);
|
||||
while (($filename = readdir($dh)) !== false)
|
||||
{
|
||||
|
@ -76,19 +79,23 @@ class phpbb_lint_test extends phpbb_test_case
|
|||
{
|
||||
continue;
|
||||
}
|
||||
if (is_dir($path) && !in_array($path, self::$exclude))
|
||||
if (is_dir($path) && !in_array($path, array(
|
||||
dirname(__FILE__) . '/../.git',
|
||||
dirname(__FILE__) . '/../build/new_version',
|
||||
dirname(__FILE__) . '/../build/old_versions',
|
||||
dirname(__FILE__) . '/../phpBB/cache',
|
||||
// PHP Fatal error: Cannot declare class Container because the name is already in use in /var/www/projects/phpbb3/tests/../phpBB/vendor/symfony/dependency-injection/Symfony/Component/DependencyInjection/Tests/Fixtures/php/services1-1.php on line 20
|
||||
// https://gist.github.com/e003913ffd493da63cbc
|
||||
dirname(__FILE__) . '/../phpBB/vendor',
|
||||
)))
|
||||
{
|
||||
$this->check($path);
|
||||
$files = array_merge($files, $this->check($path));
|
||||
}
|
||||
else if (substr($filename, strlen($filename)-4) == '.php')
|
||||
{
|
||||
$cmd = sprintf('(%s -l %s) 2>&1', self::$php_binary, escapeshellarg($path));
|
||||
$output = array();
|
||||
$status = 1;
|
||||
exec($cmd, $output, $status);
|
||||
$output = implode("\n", $output);
|
||||
$this->assertEquals(0, $status, "PHP lint failed for $path:\n$output");
|
||||
$files[] = array($path);
|
||||
}
|
||||
}
|
||||
return $files;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue