Test Failed
Push — master ( 70433d...3ef8bc )
by Konrad
02:17
created

ElementArrayTest::testGetDetails()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 34
Code Lines 12

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 12
nc 1
nop 0
dl 0
loc 34
rs 9.8666
c 0
b 0
f 0
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\Document;
40
use Smalot\PdfParser\Element\ElementArray;
41
use Smalot\PdfParser\Element\ElementNumeric;
42
use Smalot\PdfParser\Header;
43
use Smalot\PdfParser\Page;
44
45
class ElementArrayTest extends TestCase
46
{
47
    public function testParse(): void
48
    {
49
        $document = $this->getDocumentInstance();
50
51
        // Skipped.
52
        $offset = 0;
53
        $element = ElementArray::parse('ABC', $document, $offset);
54
        $this->assertFalse($element);
55
        $this->assertEquals(0, $offset);
56
57
        $offset = 0;
58
        $element = ElementArray::parse(' / [ 4 2 ] ', $document, $offset);
59
        $this->assertFalse($element);
60
        $this->assertEquals(0, $offset);
61
62
        $offset = 0;
63
        $element = ElementArray::parse(' 0 [ 4 2 ] ', $document, $offset);
64
        $this->assertFalse($element);
65
        $this->assertEquals(0, $offset);
66
67
        $offset = 0;
68
        $element = ElementArray::parse(" 0 \n [ 4 2 ] ", $document, $offset);
69
        $this->assertFalse($element);
70
        $this->assertEquals(0, $offset);
71
72
        // Valid.
73
        $offset = 0;
74
        $element = ElementArray::parse(' [ 4 2 ] ', $document, $offset);
75
        $this->assertTrue($element->contains(2));
76
        $this->assertTrue($element->contains(4));
77
        $this->assertFalse($element->contains(8));
78
        $this->assertEquals(8, $offset);
79
80
        $offset = 0;
81
        $element = ElementArray::parse(' [ 4 2 ]', $document, $offset);
82
        $this->assertTrue($element->contains(2));
83
        $this->assertTrue($element->contains(4));
84
        $this->assertFalse($element->contains(8));
85
        $this->assertEquals(8, $offset);
86
87
        $offset = 0;
88
        $element = ElementArray::parse('[ 4 2 ]', $document, $offset);
89
        $this->assertTrue($element->contains(2));
90
        $this->assertTrue($element->contains(4));
91
        $this->assertFalse($element->contains(8));
92
        $this->assertEquals(7, $offset);
93
94
        $offset = 0;
95
        $element = ElementArray::parse(" \n [ 4 2 ] ", $document, $offset);
96
        $this->assertTrue($element->contains(2));
97
        $this->assertTrue($element->contains(4));
98
        $this->assertFalse($element->contains(8));
99
        $this->assertEquals(10, $offset);
100
    }
101
102
    public function testGetContent(): void
103
    {
104
        $val_4 = new ElementNumeric('4');
105
        $val_2 = new ElementNumeric('2');
106
        $element = new ElementArray([$val_4, $val_2]);
107
108
        $content = $element->getContent();
109
        $this->assertCount(2, $content);
110
    }
111
112
    public function testContains(): void
113
    {
114
        $val_4 = new ElementNumeric('4');
115
        $val_2 = new ElementNumeric('2');
116
        $element = new ElementArray([$val_4, $val_2]);
117
118
        $this->assertTrue($element->contains(2));
119
        $this->assertTrue($element->contains(4));
120
121
        $this->assertFalse($element->contains(8));
122
    }
123
124
    public function testResolveXRef(): void
125
    {
126
        // Document with text.
127
        $filename = $this->rootDir.'/samples/Document1_pdfcreator_nocompressed.pdf';
128
        $parser = $this->getParserInstance();
129
        $document = $parser->parseFile($filename);
130
        $object = $document->getObjectById('3_0');
131
        $kids = $object->get('Kids');
132
133
        $this->assertTrue($kids instanceof ElementArray);
134
        $this->assertCount(1, $kids->getContent());
135
136
        $pages = $kids->getContent();
137
        $this->assertTrue(reset($pages) instanceof Page);
138
    }
139
140
    public function testGetDetails(): void
141
    {
142
        $document = $this->getDocumentInstance();
143
        $content = '<</Type/Page/Types[8]/Sizes[1 2 3 4 5 <</Subtype/XObject>> [8 [9 <</FontSize 10>>]]]>>';
144
        $details_reference = [
145
            'Type' => 'Page',
146
            'Types' => [
147
                8,
148
            ],
149
            'Sizes' => [
150
                1,
151
                2,
152
                3,
153
                4,
154
                5,
155
                [
156
                    'Subtype' => 'XObject',
157
                ],
158
                [
159
                    8,
160
                    [
161
                        9,
162
                        [
163
                            'FontSize' => 10,
164
                        ],
165
                    ],
166
                ],
167
            ],
168
        ];
169
        $header = Header::parse($content, $document);
170
        $details = $header->getDetails();
171
172
        $this->assertCount(3, $details);
173
        $this->assertEquals($details_reference, $details);
174
    }
175
176
    public function testToString(): void
177
    {
178
        $val_4 = new ElementNumeric('4');
179
        $val_2 = new ElementNumeric('2');
180
        $element = new ElementArray([$val_4, $val_2]);
181
        $this->assertEquals('4,2', (string) $element);
182
183
        $document = $this->getDocumentInstance();
184
        $element = ElementArray::parse(' [ 4 2 ]', $document);
185
        $this->assertEquals('4,2', (string) $element);
186
    }
187
}
188