1
0
mirror of https://github.com/danog/PHP-Parser.git synced 2025-01-22 13:51:12 +01:00
PHP-Parser/test/PhpParser/CodeTestParser.php

69 lines
1.9 KiB
PHP
Raw Normal View History

<?php declare(strict_types=1);
2017-01-19 22:23:19 +01:00
namespace PhpParser;
2018-01-10 14:24:26 -02:00
class CodeTestParser
{
2017-01-19 22:23:19 +01:00
public function parseTest($code, $chunksPerTest) {
$code = canonicalize($code);
// evaluate @@{expr}@@ expressions
$code = preg_replace_callback(
'/@@\{(.*?)\}@@/',
function($matches) {
return eval('return ' . $matches[1] . ';');
},
$code
);
// parse sections
$parts = preg_split("/\n-----(?:\n|$)/", $code);
// first part is the name
$name = array_shift($parts);
// multiple sections possible with always two forming a pair
$chunks = array_chunk($parts, $chunksPerTest);
$tests = [];
foreach ($chunks as $i => $chunk) {
$lastPart = array_pop($chunk);
list($lastPart, $mode) = $this->extractMode($lastPart);
$tests[] = [$mode, array_merge($chunk, [$lastPart])];
}
return [$name, $tests];
}
public function reconstructTest($name, array $tests) {
$result = $name;
foreach ($tests as list($mode, $parts)) {
$lastPart = array_pop($parts);
foreach ($parts as $part) {
$result .= "\n-----\n$part";
}
$result .= "\n-----\n";
if (null !== $mode) {
$result .= "!!$mode\n";
}
$result .= $lastPart;
}
return $result;
}
private function extractMode($expected) {
$firstNewLine = strpos($expected, "\n");
if (false === $firstNewLine) {
$firstNewLine = strlen($expected);
}
$firstLine = substr($expected, 0, $firstNewLine);
if (0 !== strpos($firstLine, '!!')) {
return [$expected, null];
}
$expected = (string) substr($expected, $firstNewLine + 1);
return [$expected, substr($firstLine, 2)];
}
2018-01-10 15:04:06 -02:00
}