| Conditions | 2 |
| Paths | 2 |
| Total Lines | 13 |
| Lines | 0 |
| Ratio | 0 % |
| Tests | 6 |
| CRAP Score | 2 |
| Changes | 0 | ||
| 1 | <?php |
||
| 23 | 119 | public function getDescription(): ?string |
|
| 24 | { |
||
| 25 | 119 | $description = $this->first('Description', 1); |
|
|
|
|||
| 26 | |||
| 27 | 119 | if ($description instanceof RuleInterface) { |
|
| 28 | /** @var StringValueNode $value */ |
||
| 29 | 16 | $value = $description->getChild(0); |
|
| 30 | |||
| 31 | 16 | return $this->trim($value->toPrimitive()); |
|
| 32 | } |
||
| 33 | |||
| 34 | 108 | return null; |
|
| 35 | } |
||
| 36 | |||
| 50 |
This check looks for methods that are used by a trait but not required by it.
To illustrate, let’s look at the following code example
The trait
Idableprovides a methodequalsIdthat in turn relies on the methodgetId(). If this method does not exist on a class mixing in this trait, the method will fail.Adding the
getId()as an abstract method to the trait will make sure it is available.