Skip to content

Commit

Permalink
[VarDumper] Fix generator dump on PHP 8.4
Browse files Browse the repository at this point in the history
  • Loading branch information
alexandre-daubois committed May 27, 2024
1 parent b4d9d29 commit e335c87
Show file tree
Hide file tree
Showing 2 changed files with 84 additions and 2 deletions.
4 changes: 2 additions & 2 deletions Caster/ReflectionCaster.php
Original file line number Diff line number Diff line change
Expand Up @@ -83,13 +83,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 $e) {
$a[Caster::PREFIX_VIRTUAL.'closed'] = true;

return $a;
}

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

public static function castType(\ReflectionType $c, array $a, Stub $stub, bool $isNested)
Expand Down
82 changes: 82 additions & 0 deletions Tests/Caster/ReflectionCasterTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -500,6 +500,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 @@ -511,6 +589,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 @@ -519,6 +598,7 @@ public function testGenerator()
› yield from bar();
› }
}
Symfony\Component\VarDumper\Tests\Fixtures\GeneratorDemo->baz() {}
%A}
closed: false
}
Expand All @@ -545,6 +625,7 @@ 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()
Expand All @@ -566,6 +647,7 @@ public function testGenerator()

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

0 comments on commit e335c87

Please sign in to comment.