Passed
Pull Request — main (#3)
by Viktor
19:55
created

LargerThan::applicableToTypes()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 1

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 1
c 1
b 0
f 0
dl 0
loc 3
ccs 2
cts 2
cp 1
rs 10
cc 1
nc 1
nop 0
crap 1
1
<?php
2
declare(strict_types=1);
3
4
namespace PrinsFrank\PhpStrictModels\Rule;
5
6
use Attribute;
7
use PrinsFrank\PhpStrictModels\Enum\Type;
8
9
#[Attribute]
10
class LargerThan implements Rule
11
{
12 1
    public function __construct(private float|int $largerThan){}
13
14 1
    public function applicableToTypes(): array
15
    {
16 1
        return [Type::float, Type::int, Type::array, Type::string];
17
    }
18
19
    /**
20
     * @param int|float|string|mixed[] $value
21
     */
22 1
    public function isValid(mixed $value): bool
23
    {
24 1
        if (is_array($value)) {
25 1
            return count($value) > $this->largerThan;
26
        }
27
28 1
        if (is_string($value)) {
29 1
            return mb_strlen($value) > $this->largerThan;
30
        }
31
32 1
        return $value > $this->largerThan;
33
    }
34
35 1
    public function getMessage(): string
36
    {
37 1
        return 'Should be larger than ' . $this->largerThan;
38
    }
39
}
40