ExclusionPolicy::__construct()   A
last analyzed

Complexity

Conditions 3
Paths 2

Size

Total Lines 8
Code Lines 4

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 3
CRAP Score 3.1406

Importance

Changes 0
Metric Value
cc 3
eloc 4
nc 2
nop 2
dl 0
loc 8
ccs 3
cts 4
cp 0.75
crap 3.1406
rs 10
c 0
b 0
f 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace JMS\Serializer\Annotation;
6
7
use JMS\Serializer\Exception\RuntimeException;
8
9
/**
10
 * @Annotation
11
 * @Target("CLASS")
12
 */
13
#[\Attribute(\Attribute::TARGET_CLASS)]
14
final class ExclusionPolicy implements SerializerAttribute
15
{
16
    use AnnotationUtilsTrait;
17
18
    public const NONE = 'NONE';
19
    public const ALL = 'ALL';
20 25
21
    /**
22 25
     * @var string|null
23
     */
24
    public $policy = 'NONE';
25
26 25
    public function __construct($values = [], ?string $policy = null)
27
    {
28 25
        $this->loadAnnotationParameters(get_defined_vars());
29
30
        $this->policy = strtoupper($this->policy);
0 ignored issues
show
Bug introduced by
It seems like $this->policy can also be of type null; however, parameter $string of strtoupper() does only seem to accept string, maybe add an additional type check? ( Ignorable by Annotation )

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

30
        $this->policy = strtoupper(/** @scrutinizer ignore-type */ $this->policy);
Loading history...
31 25
32
        if (self::NONE !== $this->policy && self::ALL !== $this->policy) {
33
            throw new RuntimeException('Exclusion policy must either be "ALL", or "NONE".');
34
        }
35
    }
36
}
37