Passed
Pull Request — master (#4310)
by Owen
15:27
created

RowRangeTest::testIssue4309()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 14
Code Lines 10

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 10
c 1
b 0
f 0
dl 0
loc 14
rs 9.9332
cc 1
nc 1
nop 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace PhpOffice\PhpSpreadsheetTests\Cell;
6
7
use PhpOffice\PhpSpreadsheet\Cell\RowRange;
8
use PhpOffice\PhpSpreadsheet\Spreadsheet;
9
use PHPUnit\Framework\TestCase;
10
11
class RowRangeTest extends TestCase
12
{
13
    public function testCreateRowRange(): void
14
    {
15
        $rowRange = new RowRange(3, 5);
16
        self::assertSame(3, $rowRange->from());
17
        self::assertSame(5, $rowRange->to());
18
        self::assertSame('3:5', (string) $rowRange);
19
        self::assertSame(3, $rowRange->rowCount());
20
        self::assertSame('A3:XFD5', (string) $rowRange->toCellRange());
21
    }
22
23
    public function testCreateSingleRowRange(): void
24
    {
25
        $rowRange = new RowRange(3);
26
        self::assertSame(3, $rowRange->from());
27
        self::assertSame(3, $rowRange->to());
28
        self::assertSame('3:3', (string) $rowRange);
29
        self::assertSame(1, $rowRange->rowCount());
30
    }
31
32
    public function testCreateRowRangeWithWorksheet(): void
33
    {
34
        $spreadsheet = new Spreadsheet();
35
        $worksheet = $spreadsheet->getActiveSheet();
36
        $worksheet->setTitle("Mark's Worksheet");
37
38
        $rowRange = new RowRange(3, 5, $worksheet);
39
        self::assertSame(3, $rowRange->from());
40
        self::assertSame(5, $rowRange->to());
41
        self::assertSame("'Mark''s Worksheet'!3:5", (string) $rowRange);
42
        $spreadsheet->disconnectWorksheets();
43
    }
44
45
    public function testCreateRowRangeFromArray(): void
46
    {
47
        $rowRange = RowRange::fromArray([3, 5]);
48
        self::assertSame(3, $rowRange->from());
49
        self::assertSame(5, $rowRange->to());
50
        self::assertSame('3:5', (string) $rowRange);
51
        self::assertSame(3, $rowRange->rowCount());
52
        self::assertSame('A3:XFD5', (string) $rowRange->toCellRange());
53
    }
54
55
    public function testRowRangeNext(): void
56
    {
57
        $rowRange = new RowRange(3, 5);
58
        $rowRangeNext = $rowRange->shiftRight(3);
59
60
        self::assertSame(6, $rowRangeNext->from());
61
        self::assertSame(8, $rowRangeNext->to());
62
63
        // Check that original Row Range isn't changed
64
        self::assertSame('3:5', (string) $rowRange);
65
    }
66
67
    public function testRowRangePrevious(): void
68
    {
69
        $rowRange = new RowRange(3, 5);
70
        $rowRangeNext = $rowRange->shiftLeft();
71
72
        self::assertSame(2, $rowRangeNext->from());
73
        self::assertSame(4, $rowRangeNext->to());
74
75
        // Check that original Row Range isn't changed
76
        self::assertSame('3:5', (string) $rowRange);
77
    }
78
79
    public function testIssue4309(): void
80
    {
81
        $spreadsheet = new Spreadsheet();
82
        $sheet = $spreadsheet->getActiveSheet();
83
        $rowRange = new RowRange(1, 1);
84
        $rowStyle = $sheet->getStyle($rowRange);
85
        $rowStyle->applyFromArray([
86
            'font' => ['name' => 'Arial'],
87
        ]);
88
        $rowXf = $sheet->getRowDimension(1)->getXfIndex();
89
        self::assertNotNull($rowXf);
90
        self::assertSame('Arial', $spreadsheet->getCellXfByIndex($rowXf)->getFont()->getName());
91
92
        $spreadsheet->disconnectWorksheets();
93
    }
94
}
95