Skip to content

Commit

Permalink
Merge branch '5.4' into 6.4
Browse files Browse the repository at this point in the history
* 5.4:
  [VarDumper] Fix generator dump on PHP 8.4
  keep boolean options when their value is false
  • Loading branch information
xabbuh committed May 27, 2024
2 parents 102f750 + e335c87 commit 0843fcb
Show file tree
Hide file tree
Showing 2 changed files with 85 additions and 3 deletions.
4 changes: 2 additions & 2 deletions Caster/ReflectionCaster.php
Original file line number Diff line number Diff line change
Expand Up @@ -89,13 +89,13 @@ public static function castGenerator(\Generator $c, array $a, Stub $stub, bool $
// Cannot create ReflectionGenerator based on a terminated Generator
try {
$reflectionGenerator = new \ReflectionGenerator($c);

return self::castReflectionGenerator($reflectionGenerator, $a, $stub, $isNested);
} catch (\Exception) {
$a[Caster::PREFIX_VIRTUAL.'closed'] = true;

return $a;
}

return self::castReflectionGenerator($reflectionGenerator, $a, $stub, $isNested);
}

/**
Expand Down
84 changes: 83 additions & 1 deletion Tests/Caster/ReflectionCasterTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -463,6 +463,84 @@ class: "Symfony\Component\VarDumper\Tests\Caster\ReflectionCasterTest"
);
}

/**
* @requires PHP < 8.4
*/
public function testGeneratorPriorTo84()
{
if (\extension_loaded('xdebug')) {
$this->markTestSkipped('xdebug is active');
}

$generator = new GeneratorDemo();
$generator = $generator->baz();

$expectedDump = <<<'EODUMP'
Generator {
this: Symfony\Component\VarDumper\Tests\Fixtures\GeneratorDemo { …}
%s: {
%sGeneratorDemo.php:14 {
Symfony\Component\VarDumper\Tests\Fixtures\GeneratorDemo->baz()
› {
› yield from bar();
› }
}
%A}
closed: false
}
EODUMP;

$this->assertDumpMatchesFormat($expectedDump, $generator);

foreach ($generator as $v) {
break;
}

$expectedDump = <<<'EODUMP'
array:2 [
0 => ReflectionGenerator {
this: Symfony\Component\VarDumper\Tests\Fixtures\GeneratorDemo { …}
%s: {
%s%eTests%eFixtures%eGeneratorDemo.php:%d {
Symfony\Component\VarDumper\Tests\Fixtures\GeneratorDemo::foo()
%A › yield 1;
%A }
%s%eTests%eFixtures%eGeneratorDemo.php:20 { …}
%s%eTests%eFixtures%eGeneratorDemo.php:14 { …}
%A }
closed: false
}
1 => Generator {
%s: {
%s%eTests%eFixtures%eGeneratorDemo.php:%d {
Symfony\Component\VarDumper\Tests\Fixtures\GeneratorDemo::foo()
› yield 1;
› }
}
%A }
closed: false
}
]
EODUMP;

$r = new \ReflectionGenerator($generator);
$this->assertDumpMatchesFormat($expectedDump, [$r, $r->getExecutingGenerator()]);

foreach ($generator as $v) {
}

$expectedDump = <<<'EODUMP'
Generator {
closed: true
}
EODUMP;
$this->assertDumpMatchesFormat($expectedDump, $generator);
}

/**
* @requires PHP 8.4
*/
public function testGenerator()
{
if (\extension_loaded('xdebug')) {
Expand All @@ -474,6 +552,7 @@ public function testGenerator()

$expectedDump = <<<'EODUMP'
Generator {
function: "Symfony\Component\VarDumper\Tests\Fixtures\GeneratorDemo::baz"
this: Symfony\Component\VarDumper\Tests\Fixtures\GeneratorDemo { …}
%s: {
%sGeneratorDemo.php:14 {
Expand All @@ -482,6 +561,7 @@ public function testGenerator()
› yield from bar();
› }
}
Symfony\Component\VarDumper\Tests\Fixtures\GeneratorDemo->baz() {}
%A}
closed: false
}
Expand All @@ -508,12 +588,13 @@ public function testGenerator()
closed: false
}
1 => Generator {
function: "Symfony\Component\VarDumper\Tests\Fixtures\GeneratorDemo::foo"
%s: {
%s%eTests%eFixtures%eGeneratorDemo.php:%d {
Symfony\Component\VarDumper\Tests\Fixtures\GeneratorDemo::foo()
› yield 1;
› }
}
%A }
closed: false
Expand All @@ -529,6 +610,7 @@ public function testGenerator()

$expectedDump = <<<'EODUMP'
Generator {
function: "Symfony\Component\VarDumper\Tests\Fixtures\GeneratorDemo::baz"
closed: true
}
EODUMP;
Expand Down

0 comments on commit 0843fcb

Please sign in to comment.