99 lines
3.4 KiB
PHP
99 lines
3.4 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace PhpOffice\PhpSpreadsheetTests\Calculation;
|
||
|
|
||
|
use PhpOffice\PhpSpreadsheet\IOFactory;
|
||
|
use PHPUnit\Framework\TestCase;
|
||
|
|
||
|
class DefinedNamesCalculationTest extends TestCase
|
||
|
{
|
||
|
/**
|
||
|
* @dataProvider namedRangeCalculationTest1
|
||
|
*/
|
||
|
public function testNamedRangeCalculations1(string $cellAddress, float $expectedValue): void
|
||
|
{
|
||
|
$inputFileType = 'Xlsx';
|
||
|
$inputFileName = __DIR__ . '/../../data/Calculation/DefinedNames/NamedRanges.xlsx';
|
||
|
|
||
|
$reader = IOFactory::createReader($inputFileType);
|
||
|
$spreadsheet = $reader->load($inputFileName);
|
||
|
|
||
|
$calculatedCellValue = $spreadsheet->getActiveSheet()->getCell($cellAddress)->getCalculatedValue();
|
||
|
self::assertSame($expectedValue, $calculatedCellValue, "Failed calculation for cell {$cellAddress}");
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @dataProvider namedRangeCalculationTest2
|
||
|
*/
|
||
|
public function testNamedRangeCalculationsWithAdjustedRateValue(string $cellAddress, float $expectedValue): void
|
||
|
{
|
||
|
$inputFileType = 'Xlsx';
|
||
|
$inputFileName = __DIR__ . '/../../data/Calculation/DefinedNames/NamedRanges.xlsx';
|
||
|
|
||
|
$reader = IOFactory::createReader($inputFileType);
|
||
|
$spreadsheet = $reader->load($inputFileName);
|
||
|
|
||
|
$spreadsheet->getActiveSheet()->getCell('B1')->setValue(12.5);
|
||
|
|
||
|
$calculatedCellValue = $spreadsheet->getActiveSheet()->getCell($cellAddress)->getCalculatedValue();
|
||
|
self::assertSame($expectedValue, $calculatedCellValue, "Failed calculation for cell {$cellAddress}");
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @dataProvider namedRangeCalculationTest1
|
||
|
*/
|
||
|
public function testNamedFormulaCalculations1(string $cellAddress, float $expectedValue): void
|
||
|
{
|
||
|
$inputFileType = 'Xlsx';
|
||
|
$inputFileName = __DIR__ . '/../../data/Calculation/DefinedNames/NamedFormulae.xlsx';
|
||
|
|
||
|
$reader = IOFactory::createReader($inputFileType);
|
||
|
$spreadsheet = $reader->load($inputFileName);
|
||
|
|
||
|
$calculatedCellValue = $spreadsheet->getActiveSheet()->getCell($cellAddress)->getCalculatedValue();
|
||
|
self::assertSame($expectedValue, $calculatedCellValue, "Failed calculation for cell {$cellAddress}");
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @dataProvider namedRangeCalculationTest2
|
||
|
*/
|
||
|
public function testNamedFormulaeCalculationsWithAdjustedRateValue(string $cellAddress, float $expectedValue): void
|
||
|
{
|
||
|
$inputFileType = 'Xlsx';
|
||
|
$inputFileName = __DIR__ . '/../../data/Calculation/DefinedNames/NamedFormulae.xlsx';
|
||
|
|
||
|
$reader = IOFactory::createReader($inputFileType);
|
||
|
$spreadsheet = $reader->load($inputFileName);
|
||
|
|
||
|
$spreadsheet->getActiveSheet()->getCell('B1')->setValue(12.5);
|
||
|
|
||
|
$calculatedCellValue = $spreadsheet->getActiveSheet()->getCell($cellAddress)->getCalculatedValue();
|
||
|
self::assertSame($expectedValue, $calculatedCellValue, "Failed calculation for cell {$cellAddress}");
|
||
|
}
|
||
|
|
||
|
public function namedRangeCalculationTest1(): array
|
||
|
{
|
||
|
return [
|
||
|
['C4', 56.25],
|
||
|
['C5', 54.375],
|
||
|
['C6', 48.75],
|
||
|
['C7', 52.5],
|
||
|
['C8', 41.25],
|
||
|
['B10', 33.75],
|
||
|
['C10', 253.125],
|
||
|
];
|
||
|
}
|
||
|
|
||
|
public function namedRangeCalculationTest2(): array
|
||
|
{
|
||
|
return [
|
||
|
['C4', 93.75],
|
||
|
['C5', 90.625],
|
||
|
['C6', 81.25],
|
||
|
['C7', 87.5],
|
||
|
['C8', 68.75],
|
||
|
['C10', 421.875],
|
||
|
];
|
||
|
}
|
||
|
}
|