mirror of
https://github.com/phabelio/PHP-Parser.git
synced 2025-01-22 13:21:12 +01:00
Fine grained version choice for test_old
This commit is contained in:
parent
544aee1671
commit
722119502f
16
.travis.yml
16
.travis.yml
@ -26,16 +26,18 @@ matrix:
|
||||
php: nightly
|
||||
install:
|
||||
- composer update --ignore-platform-req=php --no-progress --prefer-dist
|
||||
- name: PHP 7 Integration Tests
|
||||
php: 7.4
|
||||
- name: PHP 7.3 Code on PHP 8.0 Integration Tests
|
||||
php: nightly
|
||||
install:
|
||||
- composer update --ignore-platform-req=php --no-progress --prefer-dist
|
||||
script:
|
||||
- test_old/run-php-src.sh 7
|
||||
- name: PHP 8 Integration Tests
|
||||
php: 7.4
|
||||
- test_old/run-php-src.sh 7.3.21
|
||||
- name: PHP 8.0 Code on PHP 7.0 Integration Tests
|
||||
php: 7.0
|
||||
script:
|
||||
- test_old/run-php-src.sh 8
|
||||
- test_old/run-php-src.sh 8.0.0beta1
|
||||
allow_failures:
|
||||
- name: PHP 8 Integration Tests
|
||||
- name: PHP 8.0 Code on PHP 7.0 Integration Tests
|
||||
fast_finish: true
|
||||
|
||||
script: vendor/bin/phpunit
|
||||
|
@ -1,9 +1,5 @@
|
||||
if [[ $1 == '7' ]]; then
|
||||
VERSION='fa9bd812fcab6dfd6d9b506cb3cb04dfa75d239d'
|
||||
else
|
||||
VERSION='05478e985eb50c473054b4f1bf174f48ead78784'
|
||||
fi
|
||||
wget -q https://github.com/php/php-src/archive/$VERSION.tar.gz
|
||||
VERSION=$1
|
||||
wget -q https://github.com/php/php-src/archive/php-$VERSION.tar.gz
|
||||
mkdir -p ./data/php-src
|
||||
tar -xzf ./$VERSION.tar.gz -C ./data/php-src --strip-components=1
|
||||
php -n test_old/run.php --verbose --no-progress PHP$1 ./data/php-src
|
||||
tar -xzf ./php-$VERSION.tar.gz -C ./data/php-src --strip-components=1
|
||||
php -n test_old/run.php --verbose --no-progress --php-version=$VERSION PHP ./data/php-src
|
||||
|
@ -14,11 +14,13 @@ This script has to be called with the following signature:
|
||||
|
||||
php run.php [--no-progress] testType pathToTestFiles
|
||||
|
||||
The test type must be one of: PHP5, PHP7, PHP8 or Symfony.
|
||||
The test type must be one of: PHP, Symfony
|
||||
|
||||
The following options are available:
|
||||
|
||||
--no-progress Disables showing which file is currently tested.
|
||||
--verbose Print more information for failures.
|
||||
--php-version=VERSION PHP version to use for lexing/parsing.
|
||||
|
||||
OUTPUT
|
||||
);
|
||||
@ -32,7 +34,8 @@ array_shift($argv);
|
||||
|
||||
foreach ($argv as $arg) {
|
||||
if ('-' === $arg[0]) {
|
||||
$options[] = $arg;
|
||||
$parts = explode('=', $arg);
|
||||
$options[$parts[0]] = $parts[1] ?? true;
|
||||
} else {
|
||||
$arguments[] = $arg;
|
||||
}
|
||||
@ -42,18 +45,9 @@ if (count($arguments) !== 2) {
|
||||
showHelp('Too few arguments passed!');
|
||||
}
|
||||
|
||||
$showProgress = true;
|
||||
$verbose = false;
|
||||
foreach ($options as $option) {
|
||||
if ($option === '--no-progress') {
|
||||
$showProgress = false;
|
||||
} elseif ($option === '--verbose') {
|
||||
$verbose = true;
|
||||
} else {
|
||||
showHelp('Invalid option passed!');
|
||||
}
|
||||
}
|
||||
|
||||
$showProgress = !isset($options['--no-progress']);
|
||||
$verbose = isset($options['--verbose']);
|
||||
$phpVersion = $options['--php-version'] ?? '8.0';
|
||||
$testType = $arguments[0];
|
||||
$dir = $arguments[1];
|
||||
|
||||
@ -61,8 +55,6 @@ require_once __DIR__ . '/../vendor/autoload.php';
|
||||
|
||||
switch ($testType) {
|
||||
case 'Symfony':
|
||||
$parserVersion = 'Php7';
|
||||
$lexerVersion = PhpParser\Lexer\Emulative::PHP_7_3;
|
||||
$fileFilter = function($path) {
|
||||
if (!preg_match('~\.php$~', $path)) {
|
||||
return false;
|
||||
@ -85,11 +77,7 @@ switch ($testType) {
|
||||
return $code;
|
||||
};
|
||||
break;
|
||||
case 'PHP5':
|
||||
case 'PHP7':
|
||||
case 'PHP8':
|
||||
$parserVersion = $testType === 'PHP5' ? 'Php5' : 'Php7';
|
||||
$lexerVersion = $testType === 'PHP8' ? PhpParser\Lexer\Emulative::PHP_8_0 : PhpParser\Lexer\Emulative::PHP_7_4;
|
||||
case 'PHP':
|
||||
$fileFilter = function($path) {
|
||||
return preg_match('~\.phpt$~', $path);
|
||||
};
|
||||
@ -119,6 +107,9 @@ switch ($testType) {
|
||||
| ext.standard.tests.file.fread_basic
|
||||
# its too hard to emulate these on old PHP versions
|
||||
| Zend.tests.flexible-heredoc-complex-test[1-4]
|
||||
# whitespace in namespaced name
|
||||
| Zend.tests.bug55086
|
||||
| Zend.tests.grammar.regression_010
|
||||
)\.phpt$~x', $file)) {
|
||||
return null;
|
||||
}
|
||||
@ -134,18 +125,20 @@ switch ($testType) {
|
||||
};
|
||||
break;
|
||||
default:
|
||||
showHelp('Test type must be one of: PHP5, PHP7, PHP8 or Symfony');
|
||||
showHelp('Test type must be one of: PHP or Symfony');
|
||||
}
|
||||
|
||||
$lexer = new PhpParser\Lexer\Emulative([
|
||||
'usedAttributes' => [
|
||||
'comments', 'startLine', 'endLine', 'startTokenPos', 'endTokenPos',
|
||||
],
|
||||
'phpVersion' => $lexerVersion,
|
||||
'phpVersion' => $phpVersion,
|
||||
]);
|
||||
$parserName = 'PhpParser\Parser\\' . $parserVersion;
|
||||
/** @var PhpParser\Parser $parser */
|
||||
$parser = new $parserName($lexer);
|
||||
if (version_compare($phpVersion, '7.0', '>=')) {
|
||||
$parser = new PhpParser\Parser\Php7($lexer);
|
||||
} else {
|
||||
$parser = new PhpParser\Parser\Php5($lexer);
|
||||
}
|
||||
$prettyPrinter = new PhpParser\PrettyPrinter\Standard;
|
||||
$nodeDumper = new PhpParser\NodeDumper;
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user