Unit tests for correctly handling hidden merged cells in Readers
This commit is contained in:
parent
8ecf69a5c4
commit
84d6d98348
|
|
@ -0,0 +1,48 @@
|
|||
<?php
|
||||
|
||||
namespace PhpOffice\PhpSpreadsheetTests\Reader\Ods;
|
||||
|
||||
use PhpOffice\PhpSpreadsheet\Reader\Ods;
|
||||
use PhpOffice\PhpSpreadsheet\Spreadsheet;
|
||||
use PHPUnit\Framework\TestCase;
|
||||
|
||||
class HiddenMergeCellsTest extends TestCase
|
||||
{
|
||||
/**
|
||||
* @var Spreadsheet
|
||||
*/
|
||||
private $spreadsheet;
|
||||
|
||||
protected function setup(): void
|
||||
{
|
||||
$filename = 'tests/data/Reader/Ods/HiddenMergeCellsTest.ods';
|
||||
$reader = new Ods();
|
||||
$this->spreadsheet = $reader->load($filename);
|
||||
}
|
||||
|
||||
public function testHiddenMergeCells(): void
|
||||
{
|
||||
$c2InMergeRange = $this->spreadsheet->getActiveSheet()->getCell('C2')->isInMergeRange();
|
||||
self::assertTrue($c2InMergeRange);
|
||||
$a2InMergeRange = $this->spreadsheet->getActiveSheet()->getCell('A2')->isInMergeRange();
|
||||
self::assertTrue($a2InMergeRange);
|
||||
$a2MergeRangeValue = $this->spreadsheet->getActiveSheet()->getCell('A2')->isMergeRangeValueCell();
|
||||
self::assertTrue($a2MergeRangeValue);
|
||||
|
||||
$cellArray = $this->spreadsheet->getActiveSheet()->rangeToArray('A2:C2');
|
||||
self::assertSame([[12, 4, 3]], $cellArray);
|
||||
}
|
||||
|
||||
public function testUnmergeHiddenMergeCells(): void
|
||||
{
|
||||
$this->spreadsheet->getActiveSheet()->unmergeCells('A2:C2');
|
||||
|
||||
$c2InMergeRange = $this->spreadsheet->getActiveSheet()->getCell('C2')->isInMergeRange();
|
||||
self::assertFalse($c2InMergeRange);
|
||||
$a2InMergeRange = $this->spreadsheet->getActiveSheet()->getCell('A2')->isInMergeRange();
|
||||
self::assertFalse($a2InMergeRange);
|
||||
|
||||
$cellArray = $this->spreadsheet->getActiveSheet()->rangeToArray('A2:C2', null, false, false, false);
|
||||
self::assertSame([[12, '=6-B1', '=A2/B2']], $cellArray);
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,48 @@
|
|||
<?php
|
||||
|
||||
namespace PhpOffice\PhpSpreadsheetTests\Reader\Xls;
|
||||
|
||||
use PhpOffice\PhpSpreadsheet\Reader\Xls;
|
||||
use PhpOffice\PhpSpreadsheet\Spreadsheet;
|
||||
use PHPUnit\Framework\TestCase;
|
||||
|
||||
class HiddenMergeCellsTest extends TestCase
|
||||
{
|
||||
/**
|
||||
* @var Spreadsheet
|
||||
*/
|
||||
private $spreadsheet;
|
||||
|
||||
protected function setup(): void
|
||||
{
|
||||
$filename = 'tests/data/Reader/XLS/HiddenMergeCellsTest.xls';
|
||||
$reader = new Xls();
|
||||
$this->spreadsheet = $reader->load($filename);
|
||||
}
|
||||
|
||||
public function testHiddenMergeCells(): void
|
||||
{
|
||||
$c2InMergeRange = $this->spreadsheet->getActiveSheet()->getCell('C2')->isInMergeRange();
|
||||
self::assertTrue($c2InMergeRange);
|
||||
$a2InMergeRange = $this->spreadsheet->getActiveSheet()->getCell('A2')->isInMergeRange();
|
||||
self::assertTrue($a2InMergeRange);
|
||||
$a2MergeRangeValue = $this->spreadsheet->getActiveSheet()->getCell('A2')->isMergeRangeValueCell();
|
||||
self::assertTrue($a2MergeRangeValue);
|
||||
|
||||
$cellArray = $this->spreadsheet->getActiveSheet()->rangeToArray('A2:C2');
|
||||
self::assertSame([[12, 4, 3]], $cellArray);
|
||||
}
|
||||
|
||||
public function testUnmergeHiddenMergeCells(): void
|
||||
{
|
||||
$this->spreadsheet->getActiveSheet()->unmergeCells('A2:C2');
|
||||
|
||||
$c2InMergeRange = $this->spreadsheet->getActiveSheet()->getCell('C2')->isInMergeRange();
|
||||
self::assertFalse($c2InMergeRange);
|
||||
$a2InMergeRange = $this->spreadsheet->getActiveSheet()->getCell('A2')->isInMergeRange();
|
||||
self::assertFalse($a2InMergeRange);
|
||||
|
||||
$cellArray = $this->spreadsheet->getActiveSheet()->rangeToArray('A2:C2', null, false, false, false);
|
||||
self::assertSame([[12, '=6-B1', '=A2/B2']], $cellArray);
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,48 @@
|
|||
<?php
|
||||
|
||||
namespace PhpOffice\PhpSpreadsheetTests\Reader\Xlsx;
|
||||
|
||||
use PhpOffice\PhpSpreadsheet\Reader\Xlsx;
|
||||
use PhpOffice\PhpSpreadsheet\Spreadsheet;
|
||||
use PHPUnit\Framework\TestCase;
|
||||
|
||||
class HiddenMergeCellsTest extends TestCase
|
||||
{
|
||||
/**
|
||||
* @var Spreadsheet
|
||||
*/
|
||||
private $spreadsheet;
|
||||
|
||||
protected function setup(): void
|
||||
{
|
||||
$filename = 'tests/data/Reader/XLSX/HiddenMergeCellsTest.xlsx';
|
||||
$reader = new Xlsx();
|
||||
$this->spreadsheet = $reader->load($filename);
|
||||
}
|
||||
|
||||
public function testHiddenMergeCells(): void
|
||||
{
|
||||
$c2InMergeRange = $this->spreadsheet->getActiveSheet()->getCell('C2')->isInMergeRange();
|
||||
self::assertTrue($c2InMergeRange);
|
||||
$a2InMergeRange = $this->spreadsheet->getActiveSheet()->getCell('A2')->isInMergeRange();
|
||||
self::assertTrue($a2InMergeRange);
|
||||
$a2MergeRangeValue = $this->spreadsheet->getActiveSheet()->getCell('A2')->isMergeRangeValueCell();
|
||||
self::assertTrue($a2MergeRangeValue);
|
||||
|
||||
$cellArray = $this->spreadsheet->getActiveSheet()->rangeToArray('A2:C2');
|
||||
self::assertSame([[12, 4, 3]], $cellArray);
|
||||
}
|
||||
|
||||
public function testUnmergeHiddenMergeCells(): void
|
||||
{
|
||||
$this->spreadsheet->getActiveSheet()->unmergeCells('A2:C2');
|
||||
|
||||
$c2InMergeRange = $this->spreadsheet->getActiveSheet()->getCell('C2')->isInMergeRange();
|
||||
self::assertFalse($c2InMergeRange);
|
||||
$a2InMergeRange = $this->spreadsheet->getActiveSheet()->getCell('A2')->isInMergeRange();
|
||||
self::assertFalse($a2InMergeRange);
|
||||
|
||||
$cellArray = $this->spreadsheet->getActiveSheet()->rangeToArray('A2:C2', null, false, false, false);
|
||||
self::assertSame([[12, '=6-B1', '=A2/B2']], $cellArray);
|
||||
}
|
||||
}
|
||||
Binary file not shown.
Binary file not shown.
Binary file not shown.
Loading…
Reference in New Issue