Passed
Pull Request — master (#4360)
by Owen
14:10
created

Issue4356Test::testIssue4356()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 29
Code Lines 23

Duplication

Lines 0
Ratio 0 %

Importance

Changes 3
Bugs 0 Features 0
Metric Value
eloc 23
c 3
b 0
f 0
dl 0
loc 29
rs 9.552
cc 1
nc 1
nop 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace PhpOffice\PhpSpreadsheetTests\Reader\Xlsx;
6
7
use PhpOffice\PhpSpreadsheet\NamedRange;
8
use PhpOffice\PhpSpreadsheet\Spreadsheet;
9
use PhpOffice\PhpSpreadsheetTests\Functional\AbstractFunctional;
10
11
class Issue4356Test extends AbstractFunctional
12
{
13
    public function testIssue4356(): void
14
    {
15
        // Reader couldn't handle sheet title with apostrophe for defined name
16
        $nameDefined = 'CELLNAME';
17
        $originalSpreadsheet = new Spreadsheet();
18
        $originalSheet = $originalSpreadsheet->getActiveSheet();
19
        $originalSheet->setTitle("Goodn't sheet name");
20
        $originalSpreadsheet->addNamedRange(
21
            new NamedRange($nameDefined, $originalSheet, '$A$1')
22
        );
23
        $originalSheet->setCellValue('A1', 'This is a named cell.');
24
        $originalSheet->getStyle($nameDefined)
25
            ->getFont()
26
            ->setItalic(true);
27
        $spreadsheet = $this->writeAndReload($originalSpreadsheet, 'Xlsx');
28
        $originalSpreadsheet->disconnectWorksheets();
29
30
        $sheet = $spreadsheet->getActiveSheet();
31
        $sheet->setCellValue('C1', "=$nameDefined");
32
        self::assertSame('This is a named cell.', $sheet->getCell('C1')->getCalculatedValue());
33
        $namedRange2 = $spreadsheet->getNamedRange($nameDefined);
34
        self::assertNotNull($namedRange2);
35
        $sheetx = $namedRange2->getWorksheet();
36
        self::assertNotNull($sheetx);
37
        $style = $sheetx->getStyle($nameDefined);
38
        self::assertTrue($style->getFont()->getItalic());
39
        $style->getFont()->setItalic(false);
40
41
        $spreadsheet->disconnectWorksheets();
42
    }
43
}
44