Passed
Pull Request — master (#4465)
by Owen
16:39 queued 03:15
created

MergeCellsDeletedTest::testDeletedRows()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 15
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 15
rs 9.9332
cc 1
nc 1
nop 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace PhpOffice\PhpSpreadsheetTests\Worksheet;
6
7
use PhpOffice\PhpSpreadsheet\Reader\Xlsx as XlsxReader;
8
use PHPUnit\Framework\TestCase;
9
10
class MergeCellsDeletedTest extends TestCase
11
{
12
    public function testDeletedColumns(): void
13
    {
14
        $infile = 'tests/data/Reader/XLSX/issue.282.xlsx';
15
        $reader = new XlsxReader();
16
        $spreadsheet = $reader->load($infile);
17
        $sheet = $spreadsheet->getSheetByNameOrThrow('Sheet1');
18
19
        $mergeCells = $sheet->getMergeCells();
20
        self::assertSame(['B1:F1', 'G1:I1'], array_values($mergeCells));
21
22
        // Want to delete column B,C,D,E,F
23
        $sheet->removeColumnByIndex(2, 5);
24
        $mergeCells2 = $sheet->getMergeCells();
25
        self::assertSame(['B1:D1'], array_values($mergeCells2));
26
        $spreadsheet->disconnectWorksheets();
27
    }
28
29
    public function testDeletedRows(): void
30
    {
31
        $infile = 'tests/data/Reader/XLSX/issue.282.xlsx';
32
        $reader = new XlsxReader();
33
        $spreadsheet = $reader->load($infile);
34
        $sheet = $spreadsheet->getSheetByNameOrThrow('Sheet2');
35
36
        $mergeCells = $sheet->getMergeCells();
37
        self::assertSame(['A2:A6', 'A7:A9'], array_values($mergeCells));
38
39
        // Want to delete rows 2 to 4
40
        $sheet->removeRow(2, 3);
41
        $mergeCells2 = $sheet->getMergeCells();
42
        self::assertSame(['A4:A6'], array_values($mergeCells2));
43
        $spreadsheet->disconnectWorksheets();
44
    }
45
}
46