PhpSpreadsheet/tests/PhpSpreadsheetTests/Calculation/Functions/LookupRef/RowsOnSpreadsheetTest.php

61 lines
2.2 KiB
PHP

<?php
namespace PhpOffice\PhpSpreadsheetTests\Calculation\Functions\LookupRef;
use PhpOffice\PhpSpreadsheet\NamedRange;
class RowsOnSpreadsheetTest extends AllSetupTeardown
{
/**
* @dataProvider providerROWSonSpreadsheet
*
* @param mixed $expectedResult
* @param string $cellReference
*/
public function testRowsOnSpreadsheet($expectedResult, $cellReference = 'omitted'): void
{
$this->mightHaveException($expectedResult);
$sheet = $this->getSheet();
$sheet->setTitle('ThisSheet');
$this->getSpreadsheet()->addNamedRange(new NamedRange('namedrangex', $sheet, '$E$2:$E$6'));
$this->getSpreadsheet()->addNamedRange(new NamedRange('namedrangey', $sheet, '$F$2:$H$2'));
$this->getSpreadsheet()->addNamedRange(new NamedRange('namedrange3', $sheet, '$F$4:$H$4'));
$this->getSpreadsheet()->addNamedRange(new NamedRange('namedrange5', $sheet, '$F$5:$H$5', true));
$sheet1 = $this->getSpreadsheet()->createSheet();
$sheet1->setTitle('OtherSheet');
$this->getSpreadsheet()->addNamedRange(new NamedRange('localname', $sheet1, '$F$6:$H$6', true));
if ($cellReference === 'omitted') {
$sheet->getCell('B3')->setValue('=ROWS()');
} else {
$sheet->getCell('B3')->setValue("=ROWS($cellReference)");
}
$result = $sheet->getCell('B3')->getCalculatedValue();
self::assertSame($expectedResult, $result);
}
public function providerROWSOnSpreadsheet(): array
{
return require 'tests/data/Calculation/LookupRef/ROWSonSpreadsheet.php';
}
public function testRowsLocalDefinedName(): void
{
$sheet = $this->getSheet();
$sheet1 = $this->getSpreadsheet()->createSheet();
$sheet1->setTitle('OtherSheet');
$this->getSpreadsheet()->addNamedRange(new NamedRange('newnr', $sheet1, '$F$5:$H$10', true)); // defined locally, only usable on sheet1
$sheet1->getCell('B3')->setValue('=ROWS(newnr)');
$result = $sheet1->getCell('B3')->getCalculatedValue();
self::assertSame(6, $result);
$sheet->getCell('B3')->setValue('=ROWS(newnr)');
$result = $sheet->getCell('B3')->getCalculatedValue();
self::assertSame('#NAME?', $result);
}
}