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

MergeCellsDeletedTest   A

Complexity

Total Complexity 2

Size/Duplication

Total Lines 34
Duplicated Lines 0 %

Importance

Changes 2
Bugs 0 Features 0
Metric Value
wmc 2
eloc 21
c 2
b 0
f 0
dl 0
loc 34
rs 10

2 Methods

Rating   Name   Duplication   Size   Complexity  
A testDeletedRows() 0 15 1
A testDeletedColumns() 0 15 1
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