diff --git a/src/Analyser/MutatingScope.php b/src/Analyser/MutatingScope.php index 85a59ff8b5..94fb9c11da 100644 --- a/src/Analyser/MutatingScope.php +++ b/src/Analyser/MutatingScope.php @@ -5690,7 +5690,7 @@ private function getGlobalConstantType(Name $name): ?Type $fetches[] = new ConstFetch(new FullyQualified($name->toString())); $fetches[] = new ConstFetch($name); - foreach($fetches as $constFetch) { + foreach ($fetches as $constFetch) { if ($this->hasExpressionType($constFetch)->yes()) { return $this->getType($constFetch); } diff --git a/src/Php/PhpVersions.php b/src/Php/PhpVersions.php index 7bdc70e3bf..6239ef6918 100644 --- a/src/Php/PhpVersions.php +++ b/src/Php/PhpVersions.php @@ -18,6 +18,11 @@ public function __construct( { } + public function getType(): Type + { + return $this->phpVersions; + } + public function supportsNoncapturingCatches(): TrinaryLogic { return IntegerRangeType::fromInterval(80000, null)->isSuperTypeOf($this->phpVersions)->result; diff --git a/tests/PHPStan/Analyser/ScopePhpVersionTest.php b/tests/PHPStan/Analyser/ScopePhpVersionTest.php new file mode 100644 index 0000000000..d83ee6a62d --- /dev/null +++ b/tests/PHPStan/Analyser/ScopePhpVersionTest.php @@ -0,0 +1,40 @@ +', + __DIR__ . '/data/global-scope-constants.php', + ], + ]; + } + + /** + * @dataProvider dataTestPhpVersion + */ + public function testPhpVersion(string $expected, string $file): void + { + self::processFile($file, function (Node $node, Scope $scope) use ($expected): void { + if (!($node instanceof Exit_)) { + return; + } + $this->assertSame( + $expected, + $scope->getPhpVersion()->getType()->describe(VerbosityLevel::precise()), + ); + }); + } + +} diff --git a/tests/PHPStan/Analyser/data/global-scope-constants.php b/tests/PHPStan/Analyser/data/global-scope-constants.php new file mode 100644 index 0000000000..56eba41c9a --- /dev/null +++ b/tests/PHPStan/Analyser/data/global-scope-constants.php @@ -0,0 +1,9 @@ +