You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
123 lines
3.9 KiB
123 lines
3.9 KiB
2 months ago
|
<?php
|
||
|
|
||
|
namespace PhpOffice\PhpSpreadsheetTests\Calculation;
|
||
|
|
||
|
use PhpOffice\PhpSpreadsheet\Calculation\Information\ExcelError;
|
||
|
use PhpOffice\PhpSpreadsheet\Exception as SpreadException;
|
||
|
use PhpOffice\PhpSpreadsheet\Spreadsheet;
|
||
|
use PhpOffice\PhpSpreadsheet\Worksheet\Worksheet;
|
||
|
use PHPUnit\Framework\TestCase;
|
||
|
|
||
|
class MergedCellTest extends TestCase
|
||
|
{
|
||
|
/**
|
||
|
* @param mixed $expectedResult
|
||
|
*
|
||
|
* @dataProvider providerWorksheetFormulaeColumns
|
||
|
*/
|
||
|
public function testMergedCellColumns(string $formula, $expectedResult): void
|
||
|
{
|
||
|
$spreadSheet = new Spreadsheet();
|
||
|
|
||
|
$dataSheet = $spreadSheet->getActiveSheet();
|
||
|
$dataSheet->setCellValue('A5', 3.3);
|
||
|
$dataSheet->setCellValue('A3', 3.3);
|
||
|
$dataSheet->setCellValue('A2', 2.2);
|
||
|
$dataSheet->setCellValue('A1', 1.1);
|
||
|
$dataSheet->setCellValue('B2', 2.2);
|
||
|
$dataSheet->setCellValue('B1', 1.1);
|
||
|
$dataSheet->setCellValue('C2', 4.4);
|
||
|
$dataSheet->setCellValue('C1', 3.3);
|
||
|
$dataSheet->mergeCells('A2:A4');
|
||
|
$dataSheet->mergeCells('B:B');
|
||
|
$worksheet = $spreadSheet->getActiveSheet();
|
||
|
|
||
|
$worksheet->setCellValue('A7', $formula);
|
||
|
|
||
|
$result = $worksheet->getCell('A7')->getCalculatedValue();
|
||
|
self::assertSame($expectedResult, $result);
|
||
|
$spreadSheet->disconnectWorksheets();
|
||
|
}
|
||
|
|
||
|
public static function providerWorksheetFormulaeColumns(): array
|
||
|
{
|
||
|
return [
|
||
|
['=SUM(A1:A5)', 6.6],
|
||
|
['=COUNT(A1:A5)', 3],
|
||
|
['=COUNTA(A1:A5)', 3],
|
||
|
['=SUM(A3:A4)', 0],
|
||
|
['=A2+A3+A4', 2.2],
|
||
|
['=A2/A3', ExcelError::DIV0()],
|
||
|
['=SUM(B1:C2)', 8.8],
|
||
|
];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param mixed $expectedResult
|
||
|
*
|
||
|
* @dataProvider providerWorksheetFormulaeRows
|
||
|
*/
|
||
|
public function testMergedCellRows(string $formula, $expectedResult): void
|
||
|
{
|
||
|
$spreadSheet = new Spreadsheet();
|
||
|
|
||
|
$dataSheet = $spreadSheet->getActiveSheet();
|
||
|
$dataSheet->setCellValue('A1', 1.1);
|
||
|
$dataSheet->setCellValue('B1', 2.2);
|
||
|
$dataSheet->setCellValue('C1', 3.3);
|
||
|
$dataSheet->setCellValue('E1', 3.3);
|
||
|
$dataSheet->setCellValue('A2', 1.1);
|
||
|
$dataSheet->setCellValue('B2', 2.2);
|
||
|
$dataSheet->setCellValue('A3', 3.3);
|
||
|
$dataSheet->setCellValue('B3', 4.4);
|
||
|
$dataSheet->mergeCells('B1:D1');
|
||
|
$dataSheet->mergeCells('A2:B2');
|
||
|
$worksheet = $spreadSheet->getActiveSheet();
|
||
|
|
||
|
$worksheet->setCellValue('A7', $formula);
|
||
|
|
||
|
$result = $worksheet->getCell('A7')->getCalculatedValue();
|
||
|
self::assertSame($expectedResult, $result);
|
||
|
$spreadSheet->disconnectWorksheets();
|
||
|
}
|
||
|
|
||
|
public static function providerWorksheetFormulaeRows(): array
|
||
|
{
|
||
|
return [
|
||
|
['=SUM(A1:E1)', 6.6],
|
||
|
['=COUNT(A1:E1)', 3],
|
||
|
['=COUNTA(A1:E1)', 3],
|
||
|
['=SUM(C1:D1)', 0],
|
||
|
['=B1+C1+D1', 2.2],
|
||
|
['=B1/C1', ExcelError::DIV0()],
|
||
|
['=SUM(A2:B3)', 8.8],
|
||
|
];
|
||
|
}
|
||
|
|
||
|
private function setBadRange(Worksheet $sheet, string $range): void
|
||
|
{
|
||
|
try {
|
||
|
$sheet->mergeCells($range);
|
||
|
self::fail("Expected invalid merge range $range");
|
||
|
} catch (SpreadException $e) {
|
||
|
self::assertSame('Merge must be on a valid range of cells.', $e->getMessage());
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function testMergedBadRange(): void
|
||
|
{
|
||
|
$spreadSheet = new Spreadsheet();
|
||
|
|
||
|
$dataSheet = $spreadSheet->getActiveSheet();
|
||
|
// TODO - Reinstate full validation and disallow single cell merging for version 2.0
|
||
|
// $this->setBadRange($dataSheet, 'B1');
|
||
|
$this->setBadRange($dataSheet, 'Invalid');
|
||
|
$this->setBadRange($dataSheet, '1');
|
||
|
$this->setBadRange($dataSheet, 'C');
|
||
|
$this->setBadRange($dataSheet, 'B1:C');
|
||
|
$this->setBadRange($dataSheet, 'B:C2');
|
||
|
|
||
|
$spreadSheet->disconnectWorksheets();
|
||
|
}
|
||
|
}
|