Conditions | 3 |
Paths | 3 |
Total Lines | 19 |
Code Lines | 12 |
Lines | 0 |
Ratio | 0 % |
Tests | 10 |
CRAP Score | 3 |
Changes | 1 | ||
Bugs | 0 | Features | 0 |
1 | <?php |
||
15 | 11 | public static function resolveDiscriminatorsForClass( |
|
16 | ClassMetadata $rootClassMetadata, |
||
17 | EntityManagerInterface $entityManager |
||
18 | ) { |
||
19 | 11 | $hierarchyClasses = $rootClassMetadata->subClasses; |
|
|
|||
20 | 11 | $hierarchyClasses[] = $rootClassMetadata->name; |
|
21 | |||
22 | 11 | $discriminators = []; |
|
23 | 11 | foreach ($hierarchyClasses as $class) { |
|
24 | 11 | $currentMetadata = $entityManager->getClassMetadata($class); |
|
25 | 11 | $currentDiscriminator = $currentMetadata->discriminatorValue; |
|
26 | |||
27 | 11 | if (null !== $currentDiscriminator) { |
|
28 | 11 | $discriminators[$currentDiscriminator] = null; |
|
29 | } |
||
30 | } |
||
31 | |||
32 | 11 | return $discriminators; |
|
33 | } |
||
34 | } |
||
35 |
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: