Conditions | 3 |
Paths | 3 |
Total Lines | 16 |
Code Lines | 9 |
Lines | 0 |
Ratio | 0 % |
Tests | 10 |
CRAP Score | 3 |
Changes | 1 | ||
Bugs | 0 | Features | 0 |
1 | <?php namespace C4tech\RayEmitter\Domain; |
||
8 | 1 | public function makeEntity() |
|
9 | { |
||
10 | 1 | $class = get_parent_class($this); |
|
11 | 1 | $entity = new $class($this->getId()); |
|
|
|||
12 | |||
13 | 1 | $properties = get_object_vars($this); |
|
14 | 1 | foreach ($properties as $key => $value) { |
|
15 | 1 | if ($key === 'identity') { |
|
16 | 1 | continue; |
|
17 | } |
||
18 | |||
19 | 1 | $entity->set($key, $value); |
|
20 | 1 | } |
|
21 | |||
22 | 1 | return $entity; |
|
23 | } |
||
24 | |||
33 |
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.