Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Commit 2732dda

Browse files
Merge branch '3.4' into 4.4
* 3.4: [PhpUnitBridge] fix PHP 5.3 compat [PhpUnitBridge] Mark parent class also covered in CoverageListener prevent notice for invalid octal numbers on PHP 7.4
2 parents b0573cb + f7fc3cf commit 2732dda

File tree

3 files changed

+30
-5
lines changed

3 files changed

+30
-5
lines changed

src/Symfony/Bridge/PhpUnit/Legacy/CoverageListenerTrait.php

Lines changed: 10 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -69,10 +69,19 @@ public function startTest($test)
6969
$r = new \ReflectionProperty(Test::class, 'annotationCache');
7070
$r->setAccessible(true);
7171

72+
$covers = $sutFqcn;
73+
if (!\is_array($sutFqcn)) {
74+
$covers = [$sutFqcn];
75+
while ($parent = get_parent_class($sutFqcn)) {
76+
$covers[] = $parent;
77+
$sutFqcn = $parent;
78+
}
79+
}
80+
7281
$cache = $r->getValue();
7382
$cache = array_replace_recursive($cache, [
7483
\get_class($test) => [
75-
'covers' => \is_array($sutFqcn) ? $sutFqcn : [$sutFqcn],
84+
'covers' => $covers,
7685
],
7786
]);
7887
$r->setValue(Test::class, $cache);

src/Symfony/Component/Yaml/Inline.php

Lines changed: 10 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -636,15 +636,21 @@ private static function evaluateScalar(string $scalar, int $flags, array $refere
636636

637637
switch (true) {
638638
case ctype_digit($scalar):
639-
$raw = $scalar;
639+
if ('0' === $scalar[0]) {
640+
return octdec(preg_replace('/[^0-7]/', '', $scalar));
641+
}
642+
640643
$cast = (int) $scalar;
641644

642-
return '0' == $scalar[0] ? octdec($scalar) : (((string) $raw == (string) $cast) ? $cast : $raw);
645+
return ($scalar === (string) $cast) ? $cast : $scalar;
643646
case '-' === $scalar[0] && ctype_digit(substr($scalar, 1)):
644-
$raw = $scalar;
647+
if ('0' === $scalar[1]) {
648+
return -octdec(preg_replace('/[^0-7]/', '', substr($scalar, 1)));
649+
}
650+
645651
$cast = (int) $scalar;
646652

647-
return '0' == $scalar[1] ? -octdec(substr($scalar, 1)) : (($raw === (string) $cast) ? $cast : $raw);
653+
return ($scalar === (string) $cast) ? $cast : $scalar;
648654
case is_numeric($scalar):
649655
case Parser::preg_match(self::getHexRegex(), $scalar):
650656
$scalar = str_replace('_', '', $scalar);

src/Symfony/Component/Yaml/Tests/InlineTest.php

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -781,6 +781,16 @@ public function phpConstTagWithEmptyValueProvider()
781781
];
782782
}
783783

784+
public function testParsePositiveOctalNumberContainingInvalidDigits()
785+
{
786+
self::assertSame(342391, Inline::parse('0123456789'));
787+
}
788+
789+
public function testParseNegativeOctalNumberContainingInvalidDigits()
790+
{
791+
self::assertSame(-342391, Inline::parse('-0123456789'));
792+
}
793+
784794
/**
785795
* @dataProvider unquotedExclamationMarkThrowsProvider
786796
*/

0 commit comments

Comments
 (0)