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

XmlTest   A

Complexity

Total Complexity 5

Size/Duplication

Total Lines 46
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
eloc 18
dl 0
loc 46
rs 10
c 0
b 0
f 0
wmc 5

4 Methods

Rating   Name   Duplication   Size   Complexity  
A testInvalidSimpleXML() 0 6 1
A providerInvalidSimpleXML() 0 8 2
A testReadWithoutStyle() 0 5 1
A testReadHyperlinks() 0 11 1
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