Skip to content

Commit adfa1ef

Browse files
committed
do not process private properties from parent class
1 parent f6a6fb6 commit adfa1ef

File tree

4 files changed

+62
-2
lines changed

4 files changed

+62
-2
lines changed

src/Symfony/Bridge/Doctrine/Tests/Fixtures/DoctrineLoaderEntity.php

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -21,7 +21,7 @@
2121
*
2222
* @author Kévin Dunglas <dunglas@gmail.com>
2323
*/
24-
class DoctrineLoaderEntity
24+
class DoctrineLoaderEntity extends DoctrineLoaderParentEntity
2525
{
2626
/**
2727
* @ORM\Id
Lines changed: 40 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,40 @@
1+
<?php
2+
3+
/*
4+
* This file is part of the Symfony package.
5+
*
6+
* (c) Fabien Potencier <fabien@symfony.com>
7+
*
8+
* For the full copyright and license information, please view the LICENSE
9+
* file that was distributed with this source code.
10+
*/
11+
12+
namespace Symfony\Bridge\Doctrine\Tests\Fixtures;
13+
14+
use Doctrine\ORM\Mapping as ORM;
15+
16+
/**
17+
* @ORM\MappedSuperclass
18+
*/
19+
class DoctrineLoaderParentEntity
20+
{
21+
/**
22+
* @ORM\Column(length=35)
23+
*/
24+
public $publicParentMaxLength;
25+
26+
/**
27+
* @ORM\Column(length=30)
28+
*/
29+
private $privateParentMaxLength;
30+
31+
public function getPrivateParentMaxLength()
32+
{
33+
return $this->privateParentMaxLength;
34+
}
35+
36+
public function setPrivateParentMaxLength($privateParentMaxLength): void
37+
{
38+
$this->privateParentMaxLength = $privateParentMaxLength;
39+
}
40+
}

src/Symfony/Bridge/Doctrine/Tests/Validator/DoctrineLoaderTest.php

Lines changed: 20 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -16,6 +16,7 @@
1616
use Symfony\Bridge\Doctrine\Tests\Fixtures\BaseUser;
1717
use Symfony\Bridge\Doctrine\Tests\Fixtures\DoctrineLoaderEmbed;
1818
use Symfony\Bridge\Doctrine\Tests\Fixtures\DoctrineLoaderEntity;
19+
use Symfony\Bridge\Doctrine\Tests\Fixtures\DoctrineLoaderParentEntity;
1920
use Symfony\Bridge\Doctrine\Validator\Constraints\UniqueEntity;
2021
use Symfony\Bridge\Doctrine\Validator\DoctrineLoader;
2122
use Symfony\Component\Validator\Constraints\Length;
@@ -75,11 +76,30 @@ public function testLoadClassMetadata()
7576
$this->assertSame(10, $alreadyMappedMaxLengthConstraints[0]->max);
7677
$this->assertSame(1, $alreadyMappedMaxLengthConstraints[0]->min);
7778

79+
$publicParentMaxLengthMetadata = $classMetadata->getPropertyMetadata('publicParentMaxLength');
80+
$this->assertCount(1, $publicParentMaxLengthMetadata);
81+
$publicParentMaxLengthConstraints = $publicParentMaxLengthMetadata[0]->getConstraints();
82+
$this->assertCount(1, $publicParentMaxLengthConstraints);
83+
$this->assertInstanceOf(Length::class, $publicParentMaxLengthConstraints[0]);
84+
$this->assertSame(35, $publicParentMaxLengthConstraints[0]->max);
85+
7886
$embeddedMetadata = $classMetadata->getPropertyMetadata('embedded');
7987
$this->assertCount(1, $embeddedMetadata);
8088
$this->assertSame(CascadingStrategy::CASCADE, $embeddedMetadata[0]->getCascadingStrategy());
8189
$this->assertSame(TraversalStrategy::IMPLICIT, $embeddedMetadata[0]->getTraversalStrategy());
8290

91+
$parentClassMetadata = $validator->getMetadataFor(new DoctrineLoaderParentEntity());
92+
93+
$publicParentMaxLengthMetadata = $parentClassMetadata->getPropertyMetadata('publicParentMaxLength');
94+
$this->assertCount(0, $publicParentMaxLengthMetadata);
95+
96+
$privateParentMaxLengthMetadata = $parentClassMetadata->getPropertyMetadata('privateParentMaxLength');
97+
$this->assertCount(1, $privateParentMaxLengthMetadata);
98+
$privateParentMaxLengthConstraints = $privateParentMaxLengthMetadata[0]->getConstraints();
99+
$this->assertCount(1, $privateParentMaxLengthConstraints);
100+
$this->assertInstanceOf(Length::class, $privateParentMaxLengthConstraints[0]);
101+
$this->assertSame(30, $privateParentMaxLengthConstraints[0]->max);
102+
83103
$embeddedClassMetadata = $validator->getMetadataFor(new DoctrineLoaderEmbed());
84104

85105
$embeddedMaxLengthMetadata = $embeddedClassMetadata->getPropertyMetadata('embeddedMaxLength');

src/Symfony/Bridge/Doctrine/Validator/DoctrineLoader.php

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -81,7 +81,7 @@ public function loadClassMetadata(ClassMetadata $metadata): bool
8181
if (null === $constraint) {
8282
if (isset($mapping['originalClass'])) {
8383
$metadata->addPropertyConstraint($mapping['declaredField'], new Valid());
84-
} else {
84+
} elseif (property_exists($className, $mapping['fieldName'])) {
8585
$metadata->addPropertyConstraint($mapping['fieldName'], new Length(['max' => $mapping['length']]));
8686
}
8787
} elseif (null === $constraint->max) {

0 commit comments

Comments
 (0)