RoleFactory   A
last analyzed

Complexity

Total Complexity 1

Size/Duplication

Total Lines 25
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
eloc 9
dl 0
loc 25
rs 10
c 0
b 0
f 0
wmc 1

1 Method

Rating   Name   Duplication   Size   Complexity  
A definition() 0 7 1
1
<?php
2
3
namespace Sfneal\Users\Factories;
4
5
use Illuminate\Database\Eloquent\Factories\Factory;
6
use Sfneal\Users\Models\Role;
7
8
class RoleFactory extends Factory
9
{
10
    public const TYPES = ['user', 'client'];
11
    // todo: lowercase they and add mutator
12
    public const NAMES = ['Employee', 'Team Leader', 'Administrator', 'Web Developer'];
13
14
    /**
15
     * The name of the factory's corresponding model.
16
     *
17
     * @var string
18
     */
19
    protected $model = Role::class;
20
21
    /**
22
     * Define the model's default state.
23
     *
24
     * @return array
25
     */
26
    public function definition(): array
27
    {
28
        return [
29
            'type' => $this->faker->randomElement(self::TYPES),
0 ignored issues
show
Bug introduced by
The call to Faker\Generator::randomElement() has too few arguments starting with 'b'. ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-call  annotation

29
            'type' => $this->faker->/** @scrutinizer ignore-call */ randomElement(self::TYPES),

This check compares calls to functions or methods with their respective definitions. If the call has less arguments than are defined, it raises an issue.

If a function is defined several times with a different number of parameters, the check may pick up the wrong definition and report false positives. One codebase where this has been known to happen is Wordpress. Please note the @ignore annotation hint above.

Loading history...
30
            'name' => $this->faker->randomElement(self::NAMES),
31
            'description' => $this->faker->text(255),
32
            'order' => $this->faker->randomNumber(2),
33
        ];
34
    }
35
}
36