Passed
Pull Request — master (#4360)
by Owen
11:16
created

Issue4356Test   A

Complexity

Total Complexity 1

Size/Duplication

Total Lines 31
Duplicated Lines 0 %

Importance

Changes 3
Bugs 0 Features 0
Metric Value
wmc 1
eloc 24
c 3
b 0
f 0
dl 0
loc 31
rs 10

1 Method

Rating   Name   Duplication   Size   Complexity  
A testIssue4356() 0 29 1
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