Test Failed
Push — fix/failing-tests ( 0c7645 )
by Konrad
03:03
created

ElementDateTest::testGetContent()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 2
nc 1
nop 0
dl 0
loc 4
rs 10
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\Element\ElementDate;
40
41
class ElementDateTest extends TestCase
42
{
43
    public function testParse(): void
44
    {
45
        // Skipped.
46
        $offset = 0;
47
        $element = ElementDate::parse('ABC', null, $offset);
48
        $this->assertFalse($element);
49
        $this->assertEquals(0, $offset);
50
51
        $offset = 0;
52
        $element = ElementDate::parse(' [ (ABC) 5 6 ]', null, $offset);
53
        $this->assertFalse($element);
54
        $this->assertEquals(0, $offset);
55
56
        $offset = 0;
57
        $element = ElementDate::parse(' << (invalid) >>', null, $offset);
58
        $this->assertFalse($element);
59
        $this->assertEquals(0, $offset);
60
61
        $offset = 0;
62
        $element = ElementDate::parse(' / (FlateDecode) ', null, $offset);
63
        $this->assertFalse($element);
64
        $this->assertEquals(0, $offset);
65
66
        $offset = 0;
67
        $element = ElementDate::parse(' 0 (FlateDecode) ', null, $offset);
68
        $this->assertFalse($element);
69
        $this->assertEquals(0, $offset);
70
71
        $offset = 0;
72
        $element = ElementDate::parse(" 0 \n (FlateDecode) ", null, $offset);
73
        $this->assertFalse($element);
74
        $this->assertEquals(0, $offset);
75
76
        // Valid.
77
        $offset = 0;
78
        $element = ElementDate::parse(' (D:20130901235555+02\'00\') ', null, $offset);
79
        $element->setFormat('c');
80
        $this->assertTrue($element->getContent() instanceof \DateTime);
81
        $this->assertEquals('2013-09-01T23:55:55+02:00', (string) $element);
82
        $this->assertEquals(26, $offset);
83
84
        $offset = 0;
85
        $element = ElementDate::parse(' (D:20130901235555+02\'00\') ', null, $offset);
86
        $element->setFormat('c');
87
        $this->assertTrue($element->getContent() instanceof \DateTime);
88
        $this->assertEquals('2013-09-01T23:55:55+02:00', (string) $element);
89
        $this->assertEquals(26, $offset);
90
91
        $offset = 0;
92
        $element = ElementDate::parse(' (D:20130901235555+02\'00\')', null, $offset);
93
        $element->setFormat('c');
94
        $this->assertTrue($element->getContent() instanceof \DateTime);
95
        $this->assertEquals('2013-09-01T23:55:55+02:00', (string) $element);
96
        $this->assertEquals(26, $offset);
97
98
        $offset = 0;
99
        $element = ElementDate::parse('(D:20130901235555+02\'00\')', null, $offset);
100
        $element->setFormat('c');
101
        $this->assertTrue($element->getContent() instanceof \DateTime);
102
        $this->assertEquals('2013-09-01T23:55:55+02:00', (string) $element);
103
        $this->assertEquals(25, $offset);
104
105
        $offset = 0;
106
        $element = ElementDate::parse(" \n (D:20130901235555+02'00') ", null, $offset);
107
        $element->setFormat('c');
108
        $this->assertTrue($element->getContent() instanceof \DateTime);
109
        $this->assertEquals('2013-09-01T23:55:55+02:00', (string) $element);
110
        $this->assertEquals(28, $offset);
111
112
        $offset = 0;
113
        $element = ElementDate::parse(" \n (D:20130901235555) ", null, $offset);
114
        $element->setFormat('c');
115
        $this->assertTrue($element->getContent() instanceof \DateTime);
116
        $this->assertEquals('2013-09-01T23:55:55+00:00', (string) $element);
117
        $this->assertEquals(21, $offset);
118
119
        $offset = 0;
120
        $element = ElementDate::parse("(D:20131206091846Z00'00')", null, $offset);
121
        $element->setFormat('c');
122
        $this->assertTrue($element->getContent() instanceof \DateTime);
123
        $this->assertEquals('2013-12-06T09:18:46+00:00', (string) $element);
124
        $this->assertEquals(25, $offset);
125
126
        $offset = 0;
127
        $element = ElementDate::parse(" \n (D:1-23-2014, 19:02:15-03'00') ", null, $offset);
128
        $element->setFormat('c');
129
        $this->assertTrue($element->getContent() instanceof \DateTime);
130
        $this->assertEquals('2014-01-23T19:02:15-03:00', (string) $element);
131
        $this->assertEquals(33, $offset);
132
133
        // Format invalid
134
        $offset = 0;
135
        $element = ElementDate::parse(" \n (D:2013+02'00') ", null, $offset);
136
        $this->assertFalse($element);
137
        $this->assertEquals(0, $offset);
138
    }
139
140
    public function testGetContent(): void
141
    {
142
        $element = new ElementDate(new \DateTime('2013-09-01 23:55:55+02:00'));
143
        $this->assertEquals(new \DateTime('2013-09-01 21:55:55+00:00'), $element->getContent());
144
    }
145
146
    public function testGetContentInvalidParameter(): void
147
    {
148
        $this->expectException(\Exception::class);
149
150
        $element = new ElementDate('2013-09-01 23:55:55+02:00');
151
        $this->assertEquals(new \DateTime('2013-09-01 21:55:55+02:00'), $element->getContent());
152
    }
153
154
    public function testEquals(): void
155
    {
156
        $element = new ElementDate(new \DateTime('2013-09-01 23:55:55+02:00'));
157
        $element->setFormat('c');
158
159
        $this->assertTrue($element->equals('2013-09-01T23:55:55+02:00'));
160
        $this->assertFalse($element->equals('2013-09-01T23:55:55+01:00'));
161
162
        $this->assertTrue($element->equals(new \DateTime('2013-09-01T21:55:55+00:00')));
163
        $this->assertFalse($element->equals(new \DateTime('2013-09-01T23:55:55+01:00')));
164
165
        $this->assertFalse($element->equals('ABC'));
166
    }
167
168
    public function testContains(): void
169
    {
170
        $element = new ElementDate(new \DateTime('2013-09-01 23:55:55+02:00'));
171
172
        $this->assertTrue($element->contains('2013-09-01T21:55:55+00:00'));
173
        $this->assertFalse($element->contains('2013-06-15'));
174
    }
175
176
    public function testToString(): void
177
    {
178
        $element = new ElementDate(new \DateTime('2013-09-01 23:55:55+02:00'));
179
180
        $element->setFormat('c');
181
        $this->assertEquals('2013-09-01T23:55:55+02:00', (string) $element);
182
    }
183
}
184