Passed
Push — develop ( 3bea6f...0f8f07 )
by Mark
36:13
created

XmlTest::testValidXML()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 5
Code Lines 3

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 3
nc 1
nop 2
dl 0
loc 5
rs 10
c 0
b 0
f 0
1
<?php
2
3
namespace PhpOffice\PhpSpreadsheetTests\Reader;
4
5
use PhpOffice\PhpSpreadsheet\Cell\DataType;
6
use PhpOffice\PhpSpreadsheet\Reader\Xml;
7
use PHPUnit\Framework\TestCase;
8
9
class XmlTest extends TestCase
10
{
11
    /**
12
     * @dataProvider providerInvalidSimpleXML
13
     *
14
     * @param $filename
15
     */
16
    public function testInvalidSimpleXML($filename)
17
    {
18
        $this->expectException(\PhpOffice\PhpSpreadsheet\Reader\Exception::class);
19
20
        $xmlReader = new Xml();
21
        $xmlReader->trySimpleXMLLoadString($filename);
22
    }
23
24
    public function providerInvalidSimpleXML()
25
    {
26
        $tests = [];
27
        foreach (glob(__DIR__ . '/../../data/Reader/Xml/XEETestInvalidSimpleXML*.xml') as $file) {
28
            $tests[basename($file)] = [realpath($file)];
29
        }
30
31
        return $tests;
32
    }
33
34
    /**
35
     * Check if it can read XML Hyperlink correctly.
36
     */
37
    public function testReadHyperlinks()
38
    {
39
        $reader = new Xml();
40
        $spreadsheet = $reader->load('../samples/templates/Excel2003XMLTest.xml');
41
        $firstSheet = $spreadsheet->getSheet(0);
42
43
        $hyperlink = $firstSheet->getCell('L1');
44
45
        self::assertEquals(DataType::TYPE_STRING, $hyperlink->getDataType());
46
        self::assertEquals('PhpSpreadsheet', $hyperlink->getValue());
47
        self::assertEquals('https://phpspreadsheet.readthedocs.io', $hyperlink->getHyperlink()->getUrl());
48
    }
49
50
    public function testReadWithoutStyle()
51
    {
52
        $reader = new Xml();
53
        $spreadsheet = $reader->load(__DIR__ . '/../../data/Reader/Xml/WithoutStyle.xml');
54
        self::assertSame('Test String 1', $spreadsheet->getActiveSheet()->getCell('A1')->getValue());
55
    }
56
}
57