Passed
Pull Request — main (#3)
by Peter
05:56 queued 03:02
created

AttributeTest   A

Complexity

Total Complexity 10

Size/Duplication

Total Lines 123
Duplicated Lines 0 %

Importance

Changes 2
Bugs 0 Features 0
Metric Value
eloc 42
c 2
b 0
f 0
dl 0
loc 123
rs 10
wmc 10

10 Methods

Rating   Name   Duplication   Size   Complexity  
A testGetValuesWithValues() 0 7 1
A appendProvider() 0 18 1
A testSet() 0 9 1
A testAppend() 0 7 1
A setUp() 0 3 1
A testGetValuesDefault() 0 5 1
A testRemove() 0 6 1
A testReset() 0 8 1
A removeProvider() 0 6 1
A testToString() 0 7 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace AbterPhp\Framework\Html;
6
7
use PHPUnit\Framework\TestCase;
8
9
class AttributeTest extends TestCase
10
{
11
    protected const KEY = 'foo';
12
13
    /** @var Attribute - System Under Test */
14
    protected Attribute $sut;
15
16
    public function setUp(): void
17
    {
18
        $this->sut = new Attribute(static::KEY);
19
    }
20
21
    public function testToString(): void
22
    {
23
        $expectedResult = 'foo';
24
25
        $actualResult = (string)($this->sut);
26
27
        $this->assertSame($expectedResult, $actualResult);
28
    }
29
30
    public function testSet(): void
31
    {
32
        $expectedResult = 'foo="bar"';
33
34
        $this->sut->set('bar');
35
36
        $actualResult = (string)($this->sut);
37
38
        $this->assertSame($expectedResult, $actualResult);
39
    }
40
41
    /**
42
     * @return array<string,array>
43
     */
44
    public function appendProvider(): array
45
    {
46
        return [
47
            'empty'  => [
48
                [],
49
                'foo',
50
            ],
51
            'simple' => [
52
                ['bar'],
53
                'foo="bar"',
54
            ],
55
            'more'   => [
56
                ['bar', 'baz'],
57
                'foo="bar baz"',
58
            ],
59
            'repeat' => [
60
                ['bar', 'baz', 'baz', 'bar'],
61
                'foo="bar baz"',
62
            ],
63
        ];
64
    }
65
66
    /**
67
     * @dataProvider appendProvider
68
     *
69
     * @param array  $values
70
     * @param string $expectedResult
71
     */
72
    public function testAppend(array $values, string $expectedResult): void
73
    {
74
        $this->sut->append(...$values);
75
76
        $actualResult = (string)$this->sut;
77
78
        $this->assertSame($expectedResult, $actualResult);
79
    }
80
81
    /**
82
     * @return array<string,string[]>
83
     */
84
    public function removeProvider(): array
85
    {
86
        return [
87
            'simple'     => [['bar', 'baz', 'quix'], 'baz', 1],
88
            'repeat'     => [['bar', 'baz', 'quix', 'baz'], 'baz', 1],
89
            'expression' => [['bar', 'baz quix'], 'baz', 0],
90
        ];
91
    }
92
93
    /**
94
     * @dataProvider removeProvider
95
     *
96
     * @param string[] $values
97
     * @param string   $removeValue
98
     * @param int      $expectedResult
99
     */
100
    public function testRemove(array $values, string $removeValue, int $expectedResult): void
101
    {
102
        $sut          = new Attribute(self::KEY, ...$values);
103
        $actualResult = $sut->remove($removeValue);
104
105
        $this->assertSame($expectedResult, $actualResult);
106
    }
107
108
    public function testReset(): void
109
    {
110
        $this->sut->append('foo', 'bar', 'baz');
111
        $this->sut->reset();
112
113
        $actualResult = $this->sut->getValues();
114
115
        $this->assertNull($actualResult);
116
    }
117
118
    public function testGetValuesDefault(): void
119
    {
120
        $actualResult = $this->sut->getValues();
121
122
        $this->assertNull($actualResult);
123
    }
124
125
    public function testGetValuesWithValues(): void
126
    {
127
        $this->sut->append('foo', 'bar', 'baz');
128
129
        $actualResult = $this->sut->getValues();
130
131
        $this->assertSame(['foo', 'bar', 'baz'], $actualResult);
132
    }
133
}
134