| Conditions | 2 |
| Paths | 2 |
| Total Lines | 12 |
| Lines | 0 |
| Ratio | 0 % |
| Tests | 6 |
| CRAP Score | 2 |
| Changes | 0 | ||
| 1 | <?php |
||
| 7 | 1 | protected function guessBelongsToManyRelation() |
|
| 8 | { |
||
| 9 | 1 | $debug = debug_backtrace(DEBUG_BACKTRACE_PROVIDE_OBJECT, 3); |
|
| 10 | |||
| 11 | 1 | $name = $debug[1]['args'][8] ?? $debug[2]['function']; |
|
| 12 | |||
| 13 | 1 | if ($name == "morphedByMany") { |
|
| 14 | 1 | $name = $debug[2]['args'][7] ?? debug_backtrace(DEBUG_BACKTRACE_PROVIDE_OBJECT, 4)[3]['function']; |
|
| 15 | } |
||
| 16 | |||
| 17 | 1 | return $name; |
|
| 18 | } |
||
| 19 | |||
| 37 |
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.