Passed
Pull Request — master (#4450)
by Owen
15:51 queued 10s
created

PageBreakTest::testCols()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 17
Code Lines 13

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 13
dl 0
loc 17
rs 9.8333
c 1
b 0
f 0
cc 1
nc 1
nop 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace PhpOffice\PhpSpreadsheetTests\Writer\Xlsx;
6
7
use PhpOffice\PhpSpreadsheet\Spreadsheet;
8
use PhpOffice\PhpSpreadsheet\Worksheet\Worksheet;
9
use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
10
use PHPUnit\Framework\TestCase;
11
12
class PageBreakTest extends TestCase
13
{
14
    public function testRows(): void
15
    {
16
        $spreadsheet = new Spreadsheet();
17
        $sheet = $spreadsheet->getActiveSheet();
18
        $sheet->setCellValue('B1', 'First Page');
19
        $sheet->setCellValue('B2', 'Second Page');
20
21
        $sheet->getPageSetup()->setPrintArea('B1:B2');
22
        $sheet->setBreak('B1', Worksheet::BREAK_ROW);
23
        $sheet->getColumnDimension('B')->setAutoSize(true);
24
25
        $writer = new Xlsx($spreadsheet);
26
        $writerWorksheet = new Xlsx\Worksheet($writer);
27
        $data = $writerWorksheet->writeWorksheet($sheet, []);
28
        self::assertStringContainsString('<rowBreaks count="1" manualBreakCount="1"><brk id="1" man="1" max="2"/></rowBreaks>', $data);
29
        $spreadsheet->disconnectWorksheets();
30
    }
31
32
    public function testRowsNoPrintArea(): void
33
    {
34
        $spreadsheet = new Spreadsheet();
35
        $sheet = $spreadsheet->getActiveSheet();
36
        $sheet->setCellValue('B1', 'First Page');
37
        $sheet->setCellValue('B2', 'Second Page');
38
39
        $sheet->setBreak('B1', Worksheet::BREAK_ROW);
40
        $sheet->getColumnDimension('B')->setAutoSize(true);
41
42
        $writer = new Xlsx($spreadsheet);
43
        $writerWorksheet = new Xlsx\Worksheet($writer);
44
        $data = $writerWorksheet->writeWorksheet($sheet, []);
45
        self::assertStringContainsString('<rowBreaks count="1" manualBreakCount="1"><brk id="1" man="1"/></rowBreaks>', $data);
46
        $spreadsheet->disconnectWorksheets();
47
    }
48
49
    public function testCols(): void
50
    {
51
        $spreadsheet = new Spreadsheet();
52
        $sheet = $spreadsheet->getActiveSheet();
53
        $sheet->setCellValue('B1', 'First Page');
54
        $sheet->setCellValue('C1', 'Second Page');
55
56
        $sheet->getPageSetup()->setPrintArea('B1:C1');
57
        $sheet->setBreak('C1', Worksheet::BREAK_COLUMN);
58
        $sheet->getColumnDimension('B')->setAutoSize(true);
59
        $sheet->getColumnDimension('C')->setAutoSize(true);
60
61
        $writer = new Xlsx($spreadsheet);
62
        $writerWorksheet = new Xlsx\Worksheet($writer);
63
        $data = $writerWorksheet->writeWorksheet($sheet, []);
64
        self::assertStringContainsString('<colBreaks count="1" manualBreakCount="1"><brk id="2" man="1" max="1"/></colBreaks>', $data);
65
        $spreadsheet->disconnectWorksheets();
66
    }
67
68
    public function testColsNoPrintArea(): void
69
    {
70
        $spreadsheet = new Spreadsheet();
71
        $sheet = $spreadsheet->getActiveSheet();
72
        $sheet->setCellValue('B1', 'First Page');
73
        $sheet->setCellValue('C1', 'Second Page');
74
75
        $sheet->setBreak('C1', Worksheet::BREAK_COLUMN);
76
        $sheet->getColumnDimension('B')->setAutoSize(true);
77
        $sheet->getColumnDimension('C')->setAutoSize(true);
78
79
        $writer = new Xlsx($spreadsheet);
80
        $writerWorksheet = new Xlsx\Worksheet($writer);
81
        $data = $writerWorksheet->writeWorksheet($sheet, []);
82
        self::assertStringContainsString('<colBreaks count="1" manualBreakCount="1"><brk id="2" man="1"/></colBreaks>', $data);
83
        $spreadsheet->disconnectWorksheets();
84
    }
85
}
86