ElementBooleanTest   A
last analyzed

Complexity

Total Complexity 5

Size/Duplication

Total Lines 106
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
eloc 71
dl 0
loc 106
rs 10
c 0
b 0
f 0
wmc 5

5 Methods

Rating   Name   Duplication   Size   Complexity  
A testContains() 0 6 1
A testParse() 0 63 1
A testToString() 0 7 1
A testGetContent() 0 7 1
A testEquals() 0 13 1
1
<?php
2
3
/**
4
 * @file This file is part of the PdfParser library.
5
 *
6
 * @author  Konrad Abicht <[email protected]>
7
 *
8
 * @date    2020-06-02
9
 *
10
 * @author  Sébastien MALOT <[email protected]>
11
 *
12
 * @date    2017-01-03
13
 *
14
 * @license LGPLv3
15
 *
16
 * @url     <https://github.com/smalot/pdfparser>
17
 *
18
 *  PdfParser is a pdf library written in PHP, extraction oriented.
19
 *  Copyright (C) 2017 - Sébastien MALOT <[email protected]>
20
 *
21
 *  This program is free software: you can redistribute it and/or modify
22
 *  it under the terms of the GNU Lesser General Public License as published by
23
 *  the Free Software Foundation, either version 3 of the License, or
24
 *  (at your option) any later version.
25
 *
26
 *  This program is distributed in the hope that it will be useful,
27
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
28
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
29
 *  GNU Lesser General Public License for more details.
30
 *
31
 *  You should have received a copy of the GNU Lesser General Public License
32
 *  along with this program.
33
 *  If not, see <http://www.pdfparser.org/sites/default/LICENSE.txt>.
34
 */
35
36
namespace PHPUnitTests\Integration\Element;
37
38
use PHPUnitTests\TestCase;
39
use Smalot\PdfParser\Element\ElementBoolean;
40
41
class ElementBooleanTest extends TestCase
42
{
43
    public function testParse(): void
44
    {
45
        // Skipped.
46
        $offset = 0;
47
        $element = ElementBoolean::parse('ABC', null, $offset);
48
        $this->assertFalse($element);
49
        $this->assertEquals(0, $offset);
50
51
        $offset = 0;
52
        $element = ElementBoolean::parse(' [ false ]', null, $offset);
53
        $this->assertFalse($element);
54
        $this->assertEquals(0, $offset);
55
56
        $offset = 0;
57
        $element = ElementBoolean::parse(' << true >>', null, $offset);
58
        $this->assertFalse($element);
59
        $this->assertEquals(0, $offset);
60
61
        $offset = 0;
62
        $element = ElementBoolean::parse(' / false ', null, $offset);
63
        $this->assertFalse($element);
64
        $this->assertEquals(0, $offset);
65
66
        $offset = 0;
67
        $element = ElementBoolean::parse(' 0 true ', null, $offset);
68
        $this->assertFalse($element);
69
        $this->assertEquals(0, $offset);
70
71
        $offset = 0;
72
        $element = ElementBoolean::parse(" 0 \n true ", null, $offset);
73
        $this->assertFalse($element);
74
        $this->assertEquals(0, $offset);
75
76
        // Valid.
77
        $offset = 0;
78
        $element = ElementBoolean::parse(' true ', null, $offset);
79
        $this->assertTrue($element->getContent());
80
        $this->assertEquals(5, $offset);
81
82
        $offset = 0;
83
        $element = ElementBoolean::parse(' TRUE ', null, $offset);
84
        $this->assertTrue($element->getContent());
85
        $this->assertEquals(5, $offset);
86
87
        $offset = 0;
88
        $element = ElementBoolean::parse(' True', null, $offset);
89
        $this->assertTrue($element->getContent());
90
        $this->assertEquals(5, $offset);
91
92
        $offset = 0;
93
        $element = ElementBoolean::parse('true', null, $offset);
94
        $this->assertTrue($element->getContent());
95
        $this->assertEquals(4, $offset);
96
97
        $offset = 0;
98
        $element = ElementBoolean::parse('False', null, $offset);
99
        $this->assertFalse($element->getContent());
100
        $this->assertEquals(5, $offset);
101
102
        $offset = 0;
103
        $element = ElementBoolean::parse(" \n true ", null, $offset);
104
        $this->assertTrue($element->getContent());
105
        $this->assertEquals(7, $offset);
106
    }
107
108
    public function testGetContent(): void
109
    {
110
        $element = new ElementBoolean('true');
111
        $this->assertTrue($element->getContent());
112
113
        $element = new ElementBoolean('false');
114
        $this->assertFalse($element->getContent());
115
    }
116
117
    public function testEquals(): void
118
    {
119
        $element = new ElementBoolean('true');
120
        $this->assertTrue($element->equals(true));
121
        $this->assertFalse($element->equals(1));
122
        $this->assertFalse($element->equals(false));
123
        $this->assertFalse($element->equals(null));
124
125
        $element = new ElementBoolean('false');
126
        $this->assertTrue($element->equals(false));
127
        $this->assertFalse($element->equals(0));
128
        $this->assertFalse($element->equals(true));
129
        $this->assertFalse($element->equals(null));
130
    }
131
132
    public function testContains(): void
133
    {
134
        $element = new ElementBoolean('true');
135
        $this->assertTrue($element->contains(true));
136
        $this->assertFalse($element->contains(false));
137
        $this->assertFalse($element->contains(1));
138
    }
139
140
    public function testToString(): void
141
    {
142
        $element = new ElementBoolean('true');
143
        $this->assertEquals('true', (string) $element);
144
145
        $element = new ElementBoolean('false');
146
        $this->assertEquals('false', (string) $element);
147
    }
148
}
149