1
0
mirror of https://github.com/danog/PHP-Parser.git synced 2025-01-23 06:11:23 +01:00
PHP-Parser/test/testAgainstDirectory.php

118 lines
3.0 KiB
PHP
Raw Normal View History

<?php
2011-05-30 22:11:11 +02:00
$DIR = '../../Symfony';
function __autoload($class) {
is_file($file = '../lib/' . strtr($class, '_', '/') . '.php') && require_once $file;
}
2011-05-30 19:21:25 +02:00
$parser = new Parser;
$prettyPrinter = new PrettyPrinter_Zend;
2011-05-30 19:21:25 +02:00
$nodeDumper = new NodeDumper;
include './testFormatting.html';
2011-05-29 20:38:36 +02:00
echo '<table>
<tr>
<td>File</td>
<td>Parse</td>
<td>PrettyPrint</td>
2011-05-29 20:38:36 +02:00
<td>Compare</td>
</tr>';
2011-05-29 20:38:36 +02:00
$parseFail = $parseCount = $ppFail = $ppCount = $compareFail = $compareCount = 0;
$parseTime = $ppTime = $compareTime = 0;
$totalStartTime = microtime(true);
foreach (new RecursiveIteratorIterator(
new RecursiveDirectoryIterator($DIR),
RecursiveIteratorIterator::LEAVES_ONLY)
as $file) {
if ('.php' !== substr($file, -4)) {
continue;
}
echo '
<tr>
<td>' . $file . '</td>';
set_time_limit(10);
try {
++$parseCount;
$startTime = microtime(true);
$stmts = $parser->parse(new Lexer(file_get_contents($file)));
$parseTime += microtime(true) - $startTime;
++$ppCount;
$startTime = microtime(true);
$code = '<?php' . "\n" . $prettyPrinter->prettyPrint($stmts);
$ppTime += microtime(true) - $startTime;
try {
$ppStmts = $parser->parse(new Lexer($code));
2011-05-29 20:38:36 +02:00
++$compareCount;
$startTime = microtime(true);
$same = $nodeDumper->dump($stmts) == $nodeDumper->dump($ppStmts);
$compareTime += microtime(true) - $startTime;
if ($same) {
echo '
<td class="pass">PASS</td>
<td class="pass">PASS</td>
<td class="pass">PASS</td>
2011-06-01 22:37:10 +02:00
</tr>';
} else {
echo '
<td class="pass">PASS</td>
<td class="pass">PASS</td>
<td class="fail">FAIL</td>
</tr>';
2011-05-29 20:38:36 +02:00
++$compareFail;
}
} catch (ParseErrorException $e) {
echo '
<td class="pass">PASS</td>
<td class="fail">FAIL</td>
<td></td>
</tr>
<tr class="failReason"><td colspan="4">' . $e->getMessage() . '</td></tr>';
2011-05-29 20:38:36 +02:00
++$ppFail;
}
} catch (ParseErrorException $e) {
echo '
<td class="fail">FAIL</td>
<td></td>
<td></td>
</tr>
<tr class="failReason"><td colspan="4">' . $e->getMessage() . '</td></tr>';
2011-05-29 20:38:36 +02:00
++$parseFail;
}
flush();
}
echo '
2011-05-29 20:38:36 +02:00
<tr>
<td>Fail / Total:</td>
<td><span class="failCount">' . $parseFail . '</span> / ' . $parseCount . '</td>
<td><span class="failCount">' . $ppFail . '</span> / ' . $ppCount . '</td>
<td><span class="failCount">' . $compareFail . '</span> / ' . $compareCount . '</td>
</tr>
<tr>
<td>Time:</td>
<td>' . $parseTime . '</td>
<td>' . $ppTime . '</td>
<td>' . $compareTime . '</td>
</tr>
</table>';
echo 'Total time: ', microtime(true) - $totalStartTime, '<br />',
'Maximum memory usage: ', memory_get_peak_usage(true);