Passed
Push — master ( 51b1d1...408838 )
by Owen
14:42
created

NavigationBadTitleTest::testNavigationTitle()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 21
Code Lines 18

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 18
c 1
b 0
f 0
dl 0
loc 21
rs 9.6666
cc 1
nc 1
nop 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace PhpOffice\PhpSpreadsheetTests\Writer\Html;
6
7
use PhpOffice\PhpSpreadsheet\Spreadsheet;
8
use PhpOffice\PhpSpreadsheet\Writer\Html as HtmlWriter;
9
use PHPUnit\Framework\TestCase;
10
11
class NavigationBadTitleTest extends TestCase
12
{
13
    public function testNavigationTitle(): void
14
    {
15
        $spreadsheet = new Spreadsheet();
16
        $sheet = $spreadsheet->getActiveSheet();
17
        $sheet->getCell('A1')->setValue(1);
18
        $sheet2 = $spreadsheet->createSheet();
19
        $sheet2->setTitle('<img src=x onerror=alert(1)>');
20
        $sheet2->getCell('A2')->setValue(2);
21
22
        $writer = new HtmlWriter($spreadsheet);
23
        $writer->writeAllSheets();
24
        $html = $writer->generateHTMLAll();
25
        $expected = '<ul class="navigation">'
26
            . PHP_EOL
27
            . '  <li class="sheet0"><a href="#sheet0">Worksheet</a></li>'
28
            . PHP_EOL
29
            . '  <li class="sheet1"><a href="#sheet1">&lt;img src=x onerror=alert(1)&gt;</a></li>'
30
            . PHP_EOL
31
            . '</ul>';
32
        self::assertStringContainsString($expected, $html, 'appropriate characters are escaped');
33
        $spreadsheet->disconnectWorksheets();
34
    }
35
}
36