2011-05-29 17:33:03 +02:00
|
|
|
<?php
|
|
|
|
|
2011-10-19 17:53:40 +02:00
|
|
|
if ('cli' !== php_sapi_name()) {
|
|
|
|
die('This script is designed for running on the command line.');
|
|
|
|
}
|
|
|
|
|
|
|
|
if (3 !== $argc) {
|
|
|
|
die('This script expects exactly two arguments:
|
|
|
|
1. The test type (either "Symfony" or "PHP")
|
|
|
|
2. The path to the test files');
|
|
|
|
}
|
2011-10-17 17:49:24 +02:00
|
|
|
|
2011-10-19 17:53:40 +02:00
|
|
|
$TEST_TYPE = $argv[1];
|
|
|
|
$DIR = $argv[2];
|
|
|
|
|
|
|
|
if ('Symfony' === $TEST_TYPE) {
|
|
|
|
$FILTER_FUNC = function ($path) {
|
|
|
|
return preg_match('~\.php(?:\.cache)?$~', $path) && false === strpos($path, 'skeleton');
|
|
|
|
};
|
|
|
|
} elseif ('PHP' === $TEST_TYPE) {
|
|
|
|
$FILTER_FUNC = function ($path) {
|
|
|
|
return preg_match('~\.phpt$~', $path);
|
|
|
|
};
|
|
|
|
} else {
|
|
|
|
die('The test type must be either "Symfony" or "PHP".');
|
|
|
|
}
|
|
|
|
|
|
|
|
ini_set('short_open_tag', false);
|
2011-05-29 17:33:03 +02:00
|
|
|
|
2011-09-21 21:43:19 +02:00
|
|
|
require_once dirname(__FILE__) . '/../lib/PHPParser/Autoloader.php';
|
2011-06-05 18:47:52 +02:00
|
|
|
PHPParser_Autoloader::register();
|
2011-05-29 17:33:03 +02:00
|
|
|
|
2011-06-05 18:40:04 +02:00
|
|
|
$parser = new PHPParser_Parser;
|
|
|
|
$prettyPrinter = new PHPParser_PrettyPrinter_Zend;
|
|
|
|
$nodeDumper = new PHPParser_NodeDumper;
|
2011-05-29 17:33:03 +02:00
|
|
|
|
2011-09-05 21:48:00 +02:00
|
|
|
$parseFail = $ppFail = $compareFail = 0;
|
2011-06-01 20:00:52 +02:00
|
|
|
$parseTime = $ppTime = $compareTime = 0;
|
2011-09-05 21:48:00 +02:00
|
|
|
$count = 0;
|
2011-06-01 20:00:52 +02:00
|
|
|
|
2011-06-03 17:44:23 +02:00
|
|
|
$totalStartTime = microtime(true);
|
|
|
|
|
2011-05-29 17:33:03 +02:00
|
|
|
foreach (new RecursiveIteratorIterator(
|
|
|
|
new RecursiveDirectoryIterator($DIR),
|
|
|
|
RecursiveIteratorIterator::LEAVES_ONLY)
|
|
|
|
as $file) {
|
2011-10-17 17:49:24 +02:00
|
|
|
if (!$FILTER_FUNC($file)) {
|
2011-05-29 17:33:03 +02:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2011-10-19 17:53:40 +02:00
|
|
|
$code = file_get_contents($file);
|
|
|
|
|
|
|
|
if ('PHP' === $TEST_TYPE) {
|
|
|
|
if (!preg_match('~--FILE--\s*(.*?)--[A-Z]+--~s', $code, $matches)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (preg_match('~--EXPECTF?--\s*Parse error~', $code)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$code = $matches[1];
|
|
|
|
}
|
|
|
|
|
2011-05-31 16:33:11 +02:00
|
|
|
set_time_limit(10);
|
2011-05-29 17:33:03 +02:00
|
|
|
|
2011-09-05 21:48:00 +02:00
|
|
|
++$count;
|
|
|
|
|
2011-06-03 17:44:23 +02:00
|
|
|
try {
|
|
|
|
$startTime = microtime(true);
|
2011-10-19 17:53:40 +02:00
|
|
|
$stmts = $parser->parse(new PHPParser_Lexer($code));
|
2011-06-03 17:44:23 +02:00
|
|
|
$parseTime += microtime(true) - $startTime;
|
2011-05-29 17:33:03 +02:00
|
|
|
|
2011-06-03 17:44:23 +02:00
|
|
|
$startTime = microtime(true);
|
2011-06-02 22:52:24 +02:00
|
|
|
$code = '<?php' . "\n" . $prettyPrinter->prettyPrint($stmts);
|
2011-06-03 17:44:23 +02:00
|
|
|
$ppTime += microtime(true) - $startTime;
|
2011-05-29 17:33:03 +02:00
|
|
|
|
2011-06-03 17:44:23 +02:00
|
|
|
try {
|
2011-06-05 18:40:04 +02:00
|
|
|
$ppStmts = $parser->parse(new PHPParser_Lexer($code));
|
2011-05-29 17:33:03 +02:00
|
|
|
|
2011-06-03 17:44:23 +02:00
|
|
|
$startTime = microtime(true);
|
2011-06-01 20:00:52 +02:00
|
|
|
$same = $nodeDumper->dump($stmts) == $nodeDumper->dump($ppStmts);
|
2011-06-03 17:44:23 +02:00
|
|
|
$compareTime += microtime(true) - $startTime;
|
2011-06-01 20:00:52 +02:00
|
|
|
|
2011-09-05 21:48:00 +02:00
|
|
|
if (!$same) {
|
|
|
|
echo $file, ":\n Result of initial parse and parse after pretty print differ\n";
|
2011-05-29 20:38:36 +02:00
|
|
|
|
|
|
|
++$compareFail;
|
2011-05-29 17:33:03 +02:00
|
|
|
}
|
2011-06-05 18:52:41 +02:00
|
|
|
} catch (PHPParser_Error $e) {
|
2011-09-05 21:48:00 +02:00
|
|
|
echo $file, ":\n Parse of pretty print failed with message: {$e->getMessage()}\n";
|
2011-05-29 20:38:36 +02:00
|
|
|
|
|
|
|
++$ppFail;
|
2011-05-29 17:33:03 +02:00
|
|
|
}
|
2011-06-05 18:52:41 +02:00
|
|
|
} catch (PHPParser_Error $e) {
|
2011-09-05 21:48:00 +02:00
|
|
|
echo $file, ":\n Parse failed with message: {$e->getMessage()}\n";
|
2011-05-29 20:38:36 +02:00
|
|
|
|
|
|
|
++$parseFail;
|
2011-05-29 17:33:03 +02:00
|
|
|
}
|
2011-09-05 21:48:00 +02:00
|
|
|
}
|
2011-05-29 17:33:03 +02:00
|
|
|
|
2011-09-05 21:48:00 +02:00
|
|
|
if (0 === $parseFail && 0 === $ppFail && 0 === $compareFail) {
|
|
|
|
echo 'All tests passed.', "\n";
|
|
|
|
} else {
|
|
|
|
echo "\n", '==========', "\n\n", 'There were: ', "\n";
|
|
|
|
if (0 !== $parseFail) {
|
|
|
|
echo ' ', $parseFail, ' parse failures.', "\n";
|
|
|
|
}
|
|
|
|
if (0 !== $ppFail) {
|
|
|
|
echo ' ', $ppFail, ' pretty print failures.', "\n";
|
|
|
|
}
|
|
|
|
if (0 !== $compareFail) {
|
|
|
|
echo ' ', $compareFail, ' compare failures.', "\n";
|
|
|
|
}
|
2011-05-29 17:33:03 +02:00
|
|
|
}
|
|
|
|
|
2011-09-05 21:48:00 +02:00
|
|
|
echo "\n",
|
|
|
|
'Tested files: ', $count, "\n",
|
|
|
|
"\n",
|
|
|
|
'Parsing took: ', $parseTime, "\n",
|
|
|
|
'Pretty printing took: ', $ppTime, "\n",
|
|
|
|
'Comparing took: ', $compareTime, "\n",
|
|
|
|
"\n",
|
|
|
|
'Total time: ', microtime(true) - $totalStartTime, "\n",
|
2011-10-19 17:53:40 +02:00
|
|
|
'Maximum memory usage: ', memory_get_peak_usage(true), "\n";
|