Conditions | 3 |
Paths | 3 |
Total Lines | 20 |
Code Lines | 13 |
Lines | 0 |
Ratio | 0 % |
Tests | 10 |
CRAP Score | 3 |
Changes | 1 | ||
Bugs | 0 | Features | 0 |
1 | <?php |
||
21 | 14 | public static function resolveDiscriminatorsForClass( |
|
22 | ClassMetadata $rootClassMetadata, |
||
23 | EntityManagerInterface $entityManager |
||
24 | ): array { |
||
25 | 14 | $hierarchyClasses = $rootClassMetadata->subClasses; |
|
|
|||
26 | 14 | $hierarchyClasses[] = $rootClassMetadata->name; |
|
27 | |||
28 | 14 | $discriminators = []; |
|
29 | |||
30 | 14 | foreach ($hierarchyClasses as $class) { |
|
31 | 14 | $currentMetadata = $entityManager->getClassMetadata($class); |
|
32 | 14 | $currentDiscriminator = $currentMetadata->discriminatorValue; |
|
33 | |||
34 | 14 | if (null !== $currentDiscriminator) { |
|
35 | 14 | $discriminators[$currentDiscriminator] = null; |
|
36 | } |
||
37 | } |
||
38 | |||
39 | 14 | return $discriminators; |
|
40 | } |
||
41 | } |
||
42 |
If you access a property on an interface, you most likely code against a concrete implementation of the interface.
Available Fixes
Adding an additional type check:
Changing the type hint: