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
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.