Conditions | 2 |
Paths | 2 |
Total Lines | 8 |
Lines | 0 |
Ratio | 0 % |
Tests | 3 |
CRAP Score | 2 |
Changes | 0 |
1 | <?php |
||
29 | 17 | public function getScore() |
|
30 | { |
||
31 | 17 | if (!$this instanceof ScoreAwareInterface) |
|
32 | { |
||
33 | throw new UnexpectedValueException(sprintf('Class `%s` using `%s` must implement `%s`', get_class($this), __CLASS__, ScoreAwareInterface::class)); // @codeCoverageIgnore |
||
34 | } |
||
35 | 17 | return $this->score; |
|
|
|||
36 | } |
||
37 | |||
49 |
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: