| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122 |
- <?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 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 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();
- }
- }
|