|
|
@ -85,7 +85,7 @@ class AllFunctionalTest extends TestCase
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
$proc = new Process('php '.escapeshellarg('./bin/compile'), $target);
|
|
|
|
$proc = new Process('php -dphar.readonly=0 '.escapeshellarg('./bin/compile'), $target);
|
|
|
|
$exitcode = $proc->run();
|
|
|
|
$exitcode = $proc->run();
|
|
|
|
|
|
|
|
|
|
|
|
if ($exitcode !== 0 || trim($proc->getOutput())) {
|
|
|
|
if ($exitcode !== 0 || trim($proc->getOutput())) {
|
|
|
@ -102,26 +102,73 @@ class AllFunctionalTest extends TestCase
|
|
|
|
public function testIntegration($testFile)
|
|
|
|
public function testIntegration($testFile)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
$testData = $this->parseTestFile($testFile);
|
|
|
|
$testData = $this->parseTestFile($testFile);
|
|
|
|
|
|
|
|
$this->testDir = self::getUniqueTmpDirectory();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// if a dir is present with the name of the .test file (without .test), we
|
|
|
|
|
|
|
|
// copy all its contents in the $testDir to be used to run the test with
|
|
|
|
|
|
|
|
$testFileSetupDir = substr($testFile, 0, -5);
|
|
|
|
|
|
|
|
if (is_dir($testFileSetupDir)) {
|
|
|
|
|
|
|
|
$fs = new Filesystem();
|
|
|
|
|
|
|
|
$fs->copy($testFileSetupDir, $this->testDir);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
$this->oldenv = getenv('COMPOSER_HOME');
|
|
|
|
$this->oldenv = getenv('COMPOSER_HOME');
|
|
|
|
$_SERVER['COMPOSER_HOME'] = $this->testDir.'home';
|
|
|
|
$_SERVER['COMPOSER_HOME'] = $this->testDir.'home';
|
|
|
|
putenv('COMPOSER_HOME='.$_SERVER['COMPOSER_HOME']);
|
|
|
|
putenv('COMPOSER_HOME='.$_SERVER['COMPOSER_HOME']);
|
|
|
|
|
|
|
|
|
|
|
|
$cmd = 'php '.escapeshellarg(self::$pharPath).' --no-ansi '.$testData['RUN'];
|
|
|
|
$cmd = 'php '.escapeshellarg(self::$pharPath).' --no-ansi '.$testData['RUN'];
|
|
|
|
$proc = new Process($cmd, __DIR__.'/Fixtures/functional', null, null, 300);
|
|
|
|
$proc = new Process($cmd, $this->testDir, null, null, 300);
|
|
|
|
$exitcode = $proc->run();
|
|
|
|
$output = '';
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$exitcode = $proc->run(function ($type, $buffer) use (&$output) {
|
|
|
|
|
|
|
|
$output .= $buffer;
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
if (isset($testData['EXPECT'])) {
|
|
|
|
if (isset($testData['EXPECT'])) {
|
|
|
|
$this->assertEquals($testData['EXPECT'], $this->cleanOutput($proc->getOutput()), 'Error Output: '.$proc->getErrorOutput());
|
|
|
|
$output = trim($this->cleanOutput($output));
|
|
|
|
|
|
|
|
$expected = $testData['EXPECT'];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$line = 1;
|
|
|
|
|
|
|
|
for ($i = 0, $j = 0; $i < strlen($expected); ) {
|
|
|
|
|
|
|
|
if ($expected[$i] === "\n") {
|
|
|
|
|
|
|
|
$line++;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($expected[$i] === '%') {
|
|
|
|
|
|
|
|
preg_match('{%(.+?)%}', substr($expected, $i), $match);
|
|
|
|
|
|
|
|
$regex = $match[1];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (preg_match('{'.$regex.'}', substr($output, $j), $match)) {
|
|
|
|
|
|
|
|
$i += strlen($regex) + 2;
|
|
|
|
|
|
|
|
$j += strlen($match[0]);
|
|
|
|
|
|
|
|
continue;
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
$this->fail(
|
|
|
|
|
|
|
|
'Failed to match pattern '.$regex.' at line '.$line.' / abs offset '.$i.': '
|
|
|
|
|
|
|
|
.substr($output, $j, min(strpos($output, "\n", $j)-$j, 100)).PHP_EOL.PHP_EOL.
|
|
|
|
|
|
|
|
'Output:'.PHP_EOL.$output
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($expected[$i] !== $output[$j]) {
|
|
|
|
|
|
|
|
$this->fail(
|
|
|
|
|
|
|
|
'Output does not match expectation at line '.$line.' / abs offset '.$i.': '.PHP_EOL
|
|
|
|
|
|
|
|
.'-'.substr($expected, $i, min(strpos($expected, "\n", $i)-$i, 100)).PHP_EOL
|
|
|
|
|
|
|
|
.'+'.substr($output, $j, min(strpos($output, "\n", $j)-$j, 100)).PHP_EOL.PHP_EOL
|
|
|
|
|
|
|
|
.'Output:'.PHP_EOL.$output
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
$i++;
|
|
|
|
|
|
|
|
$j++;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (isset($testData['EXPECT-REGEX'])) {
|
|
|
|
if (isset($testData['EXPECT-REGEX'])) {
|
|
|
|
$this->assertRegExp($testData['EXPECT-REGEX'], $this->cleanOutput($proc->getOutput()), 'Error Output: '.$proc->getErrorOutput());
|
|
|
|
$this->assertRegExp($testData['EXPECT-REGEX'], $this->cleanOutput($output));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (isset($testData['EXPECT-ERROR'])) {
|
|
|
|
if (isset($testData['EXPECT-REGEXES'])) {
|
|
|
|
$this->assertEquals($testData['EXPECT-ERROR'], $this->cleanOutput($proc->getErrorOutput()));
|
|
|
|
$cleanOutput = $this->cleanOutput($output);
|
|
|
|
}
|
|
|
|
foreach (explode("\n", $testData['EXPECT-REGEXES']) as $regex) {
|
|
|
|
if (isset($testData['EXPECT-ERROR-REGEX'])) {
|
|
|
|
$this->assertRegExp($regex, $cleanOutput, 'Output: '.$output);
|
|
|
|
$this->assertRegExp($testData['EXPECT-ERROR-REGEX'], $this->cleanOutput($proc->getErrorOutput()));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (isset($testData['EXPECT-EXIT-CODE'])) {
|
|
|
|
if (isset($testData['EXPECT-EXIT-CODE'])) {
|
|
|
|
$this->assertSame($testData['EXPECT-EXIT-CODE'], $exitcode);
|
|
|
|
$this->assertSame($testData['EXPECT-EXIT-CODE'], $exitcode);
|
|
|
@ -132,7 +179,7 @@ class AllFunctionalTest extends TestCase
|
|
|
|
{
|
|
|
|
{
|
|
|
|
$tests = array();
|
|
|
|
$tests = array();
|
|
|
|
foreach (Finder::create()->in(__DIR__.'/Fixtures/functional')->name('*.test')->files() as $file) {
|
|
|
|
foreach (Finder::create()->in(__DIR__.'/Fixtures/functional')->name('*.test')->files() as $file) {
|
|
|
|
$tests[] = array($file->getRealPath());
|
|
|
|
$tests[basename($file)] = array($file->getRealPath());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return $tests;
|
|
|
|
return $tests;
|
|
|
@ -144,23 +191,6 @@ class AllFunctionalTest extends TestCase
|
|
|
|
$data = array();
|
|
|
|
$data = array();
|
|
|
|
$section = null;
|
|
|
|
$section = null;
|
|
|
|
|
|
|
|
|
|
|
|
$testDir = self::getUniqueTmpDirectory();
|
|
|
|
|
|
|
|
$this->testDir = $testDir;
|
|
|
|
|
|
|
|
$varRegex = '#%([a-zA-Z_-]+)%#';
|
|
|
|
|
|
|
|
$variableReplacer = function ($match) use (&$data, $testDir) {
|
|
|
|
|
|
|
|
list(, $var) = $match;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
switch ($var) {
|
|
|
|
|
|
|
|
case 'testDir':
|
|
|
|
|
|
|
|
$data['test_dir'] = $testDir;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return $testDir;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
|
|
|
throw new \InvalidArgumentException(sprintf('Unknown variable "%s". Supported variables: "testDir"', $var));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
foreach ($tokens as $token) {
|
|
|
|
foreach ($tokens as $token) {
|
|
|
|
if ('' === $token && null === $section) {
|
|
|
|
if ('' === $token && null === $section) {
|
|
|
|
continue;
|
|
|
|
continue;
|
|
|
@ -176,24 +206,20 @@ class AllFunctionalTest extends TestCase
|
|
|
|
|
|
|
|
|
|
|
|
// Allow sections to validate, or modify their section data.
|
|
|
|
// Allow sections to validate, or modify their section data.
|
|
|
|
switch ($section) {
|
|
|
|
switch ($section) {
|
|
|
|
case 'RUN':
|
|
|
|
|
|
|
|
$sectionData = preg_replace_callback($varRegex, $variableReplacer, $sectionData);
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
case 'EXPECT-EXIT-CODE':
|
|
|
|
case 'EXPECT-EXIT-CODE':
|
|
|
|
$sectionData = (int) $sectionData;
|
|
|
|
$sectionData = (int) $sectionData;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
case 'RUN':
|
|
|
|
case 'EXPECT':
|
|
|
|
case 'EXPECT':
|
|
|
|
case 'EXPECT-REGEX':
|
|
|
|
case 'EXPECT-REGEX':
|
|
|
|
case 'EXPECT-ERROR':
|
|
|
|
case 'EXPECT-REGEXES':
|
|
|
|
case 'EXPECT-ERROR-REGEX':
|
|
|
|
$sectionData = trim($sectionData);
|
|
|
|
$sectionData = preg_replace_callback($varRegex, $variableReplacer, $sectionData);
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
default:
|
|
|
|
throw new \RuntimeException(sprintf(
|
|
|
|
throw new \RuntimeException(sprintf(
|
|
|
|
'Unknown section "%s". Allowed sections: "RUN", "EXPECT", "EXPECT-ERROR", "EXPECT-EXIT-CODE", "EXPECT-REGEX", "EXPECT-ERROR-REGEX". '
|
|
|
|
'Unknown section "%s". Allowed sections: "RUN", "EXPECT", "EXPECT-EXIT-CODE", "EXPECT-REGEX", "EXPECT-REGEXES". '
|
|
|
|
.'Section headers must be written as "--HEADER_NAME--".',
|
|
|
|
.'Section headers must be written as "--HEADER_NAME--".',
|
|
|
|
$section
|
|
|
|
$section
|
|
|
|
));
|
|
|
|
));
|
|
|
@ -207,8 +233,8 @@ class AllFunctionalTest extends TestCase
|
|
|
|
if (!isset($data['RUN'])) {
|
|
|
|
if (!isset($data['RUN'])) {
|
|
|
|
throw new \RuntimeException('The test file must have a section named "RUN".');
|
|
|
|
throw new \RuntimeException('The test file must have a section named "RUN".');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!isset($data['EXPECT']) && !isset($data['EXPECT-ERROR']) && !isset($data['EXPECT-REGEX']) && !isset($data['EXPECT-ERROR-REGEX'])) {
|
|
|
|
if (!isset($data['EXPECT']) && !isset($data['EXPECT-REGEX']) && !isset($data['EXPECT-REGEXES'])) {
|
|
|
|
throw new \RuntimeException('The test file must have a section named "EXPECT", "EXPECT-ERROR", "EXPECT-REGEX", or "EXPECT-ERROR-REGEX".');
|
|
|
|
throw new \RuntimeException('The test file must have a section named "EXPECT", "EXPECT-REGEX", or "EXPECT-REGEXES".');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return $data;
|
|
|
|
return $data;
|
|
|
|