Passed
Pull Request — master (#4185)
by Owen
15:32
created

BinderTest   A

Complexity

Total Complexity 1

Size/Duplication

Total Lines 45
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
wmc 1
eloc 36
dl 0
loc 45
rs 10
c 1
b 0
f 0

1 Method

Rating   Name   Duplication   Size   Complexity  
A testLoadFromString() 0 43 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace PhpOffice\PhpSpreadsheetTests\Reader\Html;
6
7
use PhpOffice\PhpSpreadsheet\Cell\DataType;
8
use PhpOffice\PhpSpreadsheet\Cell\StringValueBinder;
9
use PhpOffice\PhpSpreadsheet\Reader\Html;
10
use PHPUnit\Framework\TestCase;
11
12
class BinderTest extends TestCase
13
{
14
    public function testLoadFromString(): void
15
    {
16
        $data = <<<EOF
17
            <table>
18
            <tbody>
19
            <tr><td>1</td><td>2</td><td>3</td></tr>
20
            <tr><td>4</td><td>5</td><td>6</td></tr>
21
            </tbody>
22
            </table>
23
            EOF;
24
        $reader1 = new Html();
25
        $spreadsheet1 = $reader1->loadFromString($data);
26
        $sheet1 = $spreadsheet1->getActiveSheet();
27
        $sheet1->getCell('A3')->setValueExplicit(7, DataType::TYPE_STRING);
28
        $sheet1->getCell('B3')->setValueExplicit(8, DataType::TYPE_NUMERIC);
29
        $sheet1->setCellValue('C3', 9);
30
        $sheet1->fromArray([10, 11, 12], null, 'A4');
31
        $expected1 = [
32
            [1, 2, 3],
33
            [4, 5, 6],
34
            ['7', 8, 9],
35
            [10, 11, 12],
36
        ];
37
        self::AssertSame($expected1, $sheet1->toArray(null, false, false));
38
39
        $reader2 = new Html();
40
        $reader2->setValueBinder(new StringValueBinder());
41
        $spreadsheet2 = $reader2->loadFromString($data);
42
        $sheet2 = $spreadsheet2->getActiveSheet();
43
        $sheet2->getCell('A3')->setValueExplicit(7, DataType::TYPE_STRING);
44
        $sheet2->getCell('B3')->setValueExplicit(8, DataType::TYPE_NUMERIC);
45
        $sheet2->setCellValue('C3', 9);
46
        $sheet2->fromArray([10, 11, 12], null, 'A4');
47
        $expected2 = [
48
            ['1', '2', '3'],
49
            ['4', '5', '6'],
50
            ['7', 8, '9'],
51
            ['10', '11', '12'],
52
        ];
53
        self::AssertSame($expected2, $sheet2->toArray(null, false, false));
54
55
        $spreadsheet1->disconnectWorksheets();
56
        $spreadsheet2->disconnectWorksheets();
57
    }
58
}
59