From 190afaeb6564d06e3e350b95c9211477c4dc0acf Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jaroslav=20Hansl=C3=ADk?= Date: Sun, 19 May 2019 21:59:01 +0200 Subject: [PATCH 1/3] Enabled installation on PHP 7.4 --- composer.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/composer.json b/composer.json index 7159846dc..877af92b0 100644 --- a/composer.json +++ b/composer.json @@ -3,7 +3,7 @@ "description": "Better Reflection - an improved code reflection API", "license": "MIT", "require": { - "php": ">=7.2.0,<7.4.0", + "php": ">=7.2.0,<7.5.0", "ext-json": "*", "jetbrains/phpstorm-stubs": "2019.1", "nikic/php-parser": "^4.2.1", From 11d1d5757897e0a9f43d897aff7be901eb2d4a8f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jaroslav=20Hansl=C3=ADk?= Date: Sun, 19 May 2019 14:14:22 +0200 Subject: [PATCH 2/3] Run tests on PHP 7.4 (linux only - no chocolatey package currently) --- .travis.yml | 30 +++++++++++++++++++ .../PhpStormStubsSourceStubberTest.php | 21 +++++++++++-- 2 files changed, 49 insertions(+), 2 deletions(-) diff --git a/.travis.yml b/.travis.yml index 12d028e24..0c42458e1 100644 --- a/.travis.yml +++ b/.travis.yml @@ -76,6 +76,16 @@ jobs: - echo "memory_limit=1G" >> /c/tools/php/php.ini script: vendor/bin/phpunit + - stage: Test + php: 7.4snapshot + env: DEPENDENCIES="" + script: vendor/bin/phpunit + + - stage: Test + php: 7.4snapshot + env: DEPENDENCIES="--prefer-lowest --prefer-stable" + script: vendor/bin/phpunit + - stage: Test Compatibility php: 7.2 env: DEPENDENCIES="" @@ -144,6 +154,16 @@ jobs: - echo "memory_limit=1G" >> /c/tools/php/php.ini script: vendor/bin/phpunit test/compat + - stage: Test Compatibility + php: 7.4snapshot + env: DEPENDENCIES="" + script: vendor/bin/phpunit test/compat + + - stage: Test Compatibility + php: 7.4snapshot + env: DEPENDENCIES="--prefer-lowest --prefer-stable" + script: vendor/bin/phpunit test/compat + - stage: Check Demo Scripts php: 7.2 env: DEPENDENCIES="" @@ -164,6 +184,16 @@ jobs: env: DEPENDENCIES="--prefer-lowest --prefer-stable" script: test/demo/check-demo.sh + - stage: Check Demo Scripts + php: 7.4snapshot + env: DEPENDENCIES="" + script: test/demo/check-demo.sh + + - stage: Check Demo Scripts + php: 7.4snapshot + env: DEPENDENCIES="--prefer-lowest --prefer-stable" + script: test/demo/check-demo.sh + - stage: Check Coding Standard php: 7.3 env: DEPENDENCIES="" diff --git a/test/unit/SourceLocator/SourceStubber/PhpStormStubsSourceStubberTest.php b/test/unit/SourceLocator/SourceStubber/PhpStormStubsSourceStubberTest.php index 72e806377..14032f85a 100644 --- a/test/unit/SourceLocator/SourceStubber/PhpStormStubsSourceStubberTest.php +++ b/test/unit/SourceLocator/SourceStubber/PhpStormStubsSourceStubberTest.php @@ -72,13 +72,20 @@ public function internalClassesProvider() : array get_declared_traits() ); + // Needs fixes in JetBrains/phpstorm-stubs + $missingClassesInStubs = ['WeakReference']; + return array_map( static function (string $className) : array { return [$className]; }, array_filter( $classNames, - static function (string $className) : bool { + static function (string $className) use ($missingClassesInStubs) : bool { + if (in_array($className, $missingClassesInStubs, true)) { + return false; + } + $reflection = new CoreReflectionClass($className); if (! $reflection->isInternal()) { @@ -152,6 +159,11 @@ private function assertSameClassAttributes(CoreReflectionClass $original, Reflec continue; } + // Added in PHP 7.4.0 + if (PHP_VERSION_ID >= 70400 && $method->getShortName() === '__unserialize') { + return; + } + $this->assertSameMethodAttributes($method, $stubbed->getMethod($method->getName())); } @@ -265,7 +277,7 @@ public function internalFunctionsProvider() : array $functionNames = get_defined_functions()['internal']; // Needs fixes in JetBrains/phpstorm-stubs - $missingFunctionsInStubs = ['sapi_windows_vt100_support']; + $missingFunctionsInStubs = ['password_algos', 'sapi_windows_vt100_support', 'sapi_windows_set_ctrl_handler', 'sapi_windows_generate_ctrl_event']; return array_map( static function (string $functionName) : array { @@ -354,6 +366,11 @@ public function testInternalFunctions(string $functionName) : void return; } + // Changed in PHP 7.4.0 + if (PHP_VERSION_ID >= 70400 && $functionName === 'preg_replace_callback') { + return; + } + // Needs fixes in JetBrains/phpstorm-stubs or PHP if (in_array($functionName, ['get_resources', 'sapi_windows_cp_get', 'stream_context_set_option'], true)) { return; From f4b346910b86dc8bd01cf52bb096b20e08c910e1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jaroslav=20Hansl=C3=ADk?= Date: Sun, 19 May 2019 22:27:54 +0200 Subject: [PATCH 3/3] Allow failure on PHP 7.4 currently --- .travis.yml | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/.travis.yml b/.travis.yml index 0c42458e1..21e48c58d 100644 --- a/.travis.yml +++ b/.travis.yml @@ -6,6 +6,10 @@ before_script: - rm composer.lock - travis_retry composer update --prefer-dist $DEPENDENCIES +matrix: + allow_failures: + - php: 7.4snapshot + jobs: include: - stage: Test