MergedCellTest.php 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. <?php
  2. namespace PhpOffice\PhpSpreadsheetTests\Calculation;
  3. use PhpOffice\PhpSpreadsheet\Calculation\Information\ExcelError;
  4. use PhpOffice\PhpSpreadsheet\Exception as SpreadException;
  5. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  6. use PhpOffice\PhpSpreadsheet\Worksheet\Worksheet;
  7. use PHPUnit\Framework\TestCase;
  8. class MergedCellTest extends TestCase
  9. {
  10. /**
  11. * @param mixed $expectedResult
  12. *
  13. * @dataProvider providerWorksheetFormulaeColumns
  14. */
  15. public function testMergedCellColumns(string $formula, $expectedResult): void
  16. {
  17. $spreadSheet = new Spreadsheet();
  18. $dataSheet = $spreadSheet->getActiveSheet();
  19. $dataSheet->setCellValue('A5', 3.3);
  20. $dataSheet->setCellValue('A3', 3.3);
  21. $dataSheet->setCellValue('A2', 2.2);
  22. $dataSheet->setCellValue('A1', 1.1);
  23. $dataSheet->setCellValue('B2', 2.2);
  24. $dataSheet->setCellValue('B1', 1.1);
  25. $dataSheet->setCellValue('C2', 4.4);
  26. $dataSheet->setCellValue('C1', 3.3);
  27. $dataSheet->mergeCells('A2:A4');
  28. $dataSheet->mergeCells('B:B');
  29. $worksheet = $spreadSheet->getActiveSheet();
  30. $worksheet->setCellValue('A7', $formula);
  31. $result = $worksheet->getCell('A7')->getCalculatedValue();
  32. self::assertSame($expectedResult, $result);
  33. $spreadSheet->disconnectWorksheets();
  34. }
  35. public function providerWorksheetFormulaeColumns(): array
  36. {
  37. return [
  38. ['=SUM(A1:A5)', 6.6],
  39. ['=COUNT(A1:A5)', 3],
  40. ['=COUNTA(A1:A5)', 3],
  41. ['=SUM(A3:A4)', 0],
  42. ['=A2+A3+A4', 2.2],
  43. ['=A2/A3', ExcelError::DIV0()],
  44. ['=SUM(B1:C2)', 8.8],
  45. ];
  46. }
  47. /**
  48. * @param mixed $expectedResult
  49. *
  50. * @dataProvider providerWorksheetFormulaeRows
  51. */
  52. public function testMergedCellRows(string $formula, $expectedResult): void
  53. {
  54. $spreadSheet = new Spreadsheet();
  55. $dataSheet = $spreadSheet->getActiveSheet();
  56. $dataSheet->setCellValue('A1', 1.1);
  57. $dataSheet->setCellValue('B1', 2.2);
  58. $dataSheet->setCellValue('C1', 3.3);
  59. $dataSheet->setCellValue('E1', 3.3);
  60. $dataSheet->setCellValue('A2', 1.1);
  61. $dataSheet->setCellValue('B2', 2.2);
  62. $dataSheet->setCellValue('A3', 3.3);
  63. $dataSheet->setCellValue('B3', 4.4);
  64. $dataSheet->mergeCells('B1:D1');
  65. $dataSheet->mergeCells('A2:B2');
  66. $worksheet = $spreadSheet->getActiveSheet();
  67. $worksheet->setCellValue('A7', $formula);
  68. $result = $worksheet->getCell('A7')->getCalculatedValue();
  69. self::assertSame($expectedResult, $result);
  70. $spreadSheet->disconnectWorksheets();
  71. }
  72. public function providerWorksheetFormulaeRows(): array
  73. {
  74. return [
  75. ['=SUM(A1:E1)', 6.6],
  76. ['=COUNT(A1:E1)', 3],
  77. ['=COUNTA(A1:E1)', 3],
  78. ['=SUM(C1:D1)', 0],
  79. ['=B1+C1+D1', 2.2],
  80. ['=B1/C1', ExcelError::DIV0()],
  81. ['=SUM(A2:B3)', 8.8],
  82. ];
  83. }
  84. private function setBadRange(Worksheet $sheet, string $range): void
  85. {
  86. try {
  87. $sheet->mergeCells($range);
  88. self::fail("Expected invalid merge range $range");
  89. } catch (SpreadException $e) {
  90. self::assertSame('Merge must be on a valid range of cells.', $e->getMessage());
  91. }
  92. }
  93. public function testMergedBadRange(): void
  94. {
  95. $spreadSheet = new Spreadsheet();
  96. $dataSheet = $spreadSheet->getActiveSheet();
  97. // TODO - Reinstate full validation and disallow single cell merging for version 2.0
  98. // $this->setBadRange($dataSheet, 'B1');
  99. $this->setBadRange($dataSheet, 'Invalid');
  100. $this->setBadRange($dataSheet, '1');
  101. $this->setBadRange($dataSheet, 'C');
  102. $this->setBadRange($dataSheet, 'B1:C');
  103. $this->setBadRange($dataSheet, 'B:C2');
  104. $spreadSheet->disconnectWorksheets();
  105. }
  106. }