Conditions | 4 |
Paths | 4 |
Total Lines | 16 |
Code Lines | 8 |
Lines | 0 |
Ratio | 0 % |
Changes | 0 |
1 | <?php |
||
11 | public function getHealthAsEmojiAttribute(): string |
||
12 | { |
||
13 | if ($this->isHealthy()) { |
||
|
|||
14 | return Emoji::ok(); |
||
15 | } |
||
16 | |||
17 | if ($this->isUnhealthy()) { |
||
18 | return Emoji::notOk(); |
||
19 | } |
||
20 | |||
21 | if ($this->hasWarning()) { |
||
22 | return Emoji::warning(); |
||
23 | } |
||
24 | |||
25 | throw new Exception("Could not determine health emoji for host `{$this->id}`"); |
||
26 | } |
||
27 | } |
||
28 |
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
Idable
provides a methodequalsId
that 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.