1
0
Fork 0

Full functional test-bed improvements

pull/9702/head
Jordi Boggiano 2021-02-12 11:05:13 +01:00
parent 1c715b5821
commit d3ba447b79
No known key found for this signature in database
GPG Key ID: 7BBD42C429EC80BC
5 changed files with 79 additions and 47 deletions

View File

@ -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) {
$this->assertRegExp($regex, $cleanOutput, 'Output: '.$output);
} }
if (isset($testData['EXPECT-ERROR-REGEX'])) {
$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;

View File

@ -1,4 +1,4 @@
--RUN-- --RUN--
create-project seld/jsonlint %testDir% 1.0.0 --prefer-source -n create-project seld/jsonlint foo 1.0.0 --prefer-source -n
--EXPECT-ERROR-REGEX-- --EXPECT-REGEX--
{Installing seld/jsonlint \(1.0.0\): Cloning [a-f0-9]{10}( from cache)?} {- Installing seld/jsonlint \(1.0.0\): Cloning [a-f0-9]{10}( from cache)?}

View File

@ -1,4 +1,4 @@
--RUN-- --RUN--
create-project --repository=packages.json -v seld/jsonlint %testDir% dev-master create-project --repository=packages.json -v seld/jsonlint foo dev-main
--EXPECT-ERROR-REGEX-- --EXPECT-REGEX--
{^Installing seld/jsonlint \(dev-master [a-f0-9]{40}\)}m {^Installing seld/jsonlint \(dev-main [a-f0-9]{40}\)}m

View File

@ -9,8 +9,9 @@
"validator" "validator"
], ],
"homepage": "", "homepage": "",
"version": "dev-master", "version": "dev-main",
"version_normalized": "9999999-dev", "version_normalized": "dev-main",
"default-branch": true,
"license": [ "license": [
"MIT" "MIT"
], ],

View File

@ -26,6 +26,11 @@ class InstalledVersionsTest extends TestCase
$prop->setValue(array()); $prop->setValue(array());
} }
public static function tearDownAfterClass()
{
self::setUpBeforeClass();
}
public function setUp() public function setUp()
{ {
InstalledVersions::reload(require __DIR__.'/Repository/Fixtures/installed.php'); InstalledVersions::reload(require __DIR__.'/Repository/Fixtures/installed.php');