Passed
Pull Request — master (#4240)
by Owen
13:17
created

DataValidationTest   A

Complexity

Total Complexity 2

Size/Duplication

Total Lines 56
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
wmc 2
eloc 47
dl 0
loc 56
rs 10
c 1
b 0
f 0

2 Methods

Rating   Name   Duplication   Size   Complexity  
A testWholeRow() 0 25 1
A testWholeColumn() 0 27 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace PhpOffice\PhpSpreadsheetTests\Writer\Xlsx;
6
7
use PhpOffice\PhpSpreadsheet\Cell\DataValidation;
8
use PhpOffice\PhpSpreadsheet\Spreadsheet;
9
use PhpOffice\PhpSpreadsheetTests\Functional\AbstractFunctional;
10
11
class DataValidationTest extends AbstractFunctional
12
{
13
    public function testWholeRow(): void
14
    {
15
        $spreadsheet = new Spreadsheet();
16
        $sheet = $spreadsheet->getActiveSheet();
17
        $dv = new DataValidation();
18
        $dv->setType(DataValidation::TYPE_NONE);
19
        $sheet->setDataValidation('C1:F1', $dv);
20
        $dv = new DataValidation();
21
        $dv->setType(DataValidation::TYPE_LIST)
22
            ->setShowDropDown(true)
23
            ->setFormula1('"Item A,Item B,Item C"')
24
            ->setErrorStyle(DataValidation::STYLE_STOP)
25
            ->setShowErrorMessage(true)
26
            ->setErrorTitle('Input Error')
27
            ->setError('Value is not a member of allowed list');
28
        $sheet->setDataValidation('1:1', $dv);
29
        $dv = new DataValidation();
30
        $dv->setType(DataValidation::TYPE_NONE);
31
        $sheet->setDataValidation('H1', $dv);
32
33
        $robj = $this->writeAndReload($spreadsheet, 'Xlsx');
34
        $spreadsheet->disconnectWorksheets();
35
        $sheet0 = $robj->getActiveSheet();
36
        self::assertSame(['H1', 'C1:F1', '1:1'], array_keys($sheet0->getDataValidationCollection()));
37
        $robj->disconnectWorksheets();
38
    }
39
40
    public function testWholeColumn(): void
41
    {
42
        $spreadsheet = new Spreadsheet();
43
        $sheet = $spreadsheet->getActiveSheet();
44
        $sheet->getCell('C1')->setValue(1);
45
        $sheet->getCell('C2')->setValue(2);
46
        $sheet->getCell('C3')->setValue(3);
47
        $dv = $sheet->getDataValidation('A5:A7');
48
        $dv->setType(DataValidation::TYPE_NONE);
49
        $dv = new DataValidation();
50
        $dv->setType(DataValidation::TYPE_LIST)
51
            ->setShowDropDown(true)
52
            ->setFormula1('$C$1:$C$3')
53
            ->setErrorStyle(DataValidation::STYLE_STOP)
54
            ->setShowErrorMessage(true)
55
            ->setErrorTitle('Input Error')
56
            ->setError('Value is not a member of allowed list');
57
        $sheet->setDataValidation('A:A', $dv);
58
        $dv = new DataValidation();
59
        $dv->setType(DataValidation::TYPE_NONE);
60
        $sheet->setDataValidation('A9', $dv);
61
62
        $robj = $this->writeAndReload($spreadsheet, 'Xlsx');
63
        $spreadsheet->disconnectWorksheets();
64
        $sheet0 = $robj->getActiveSheet();
65
        self::assertSame(['A9', 'A5:A7', 'A:A'], array_keys($sheet0->getDataValidationCollection()));
66
        $robj->disconnectWorksheets();
67
    }
68
}
69