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.
78 lines
2.2 KiB
78 lines
2.2 KiB
<?php
|
|
|
|
namespace PhpOffice\PhpSpreadsheetTests\Cell;
|
|
|
|
use PhpOffice\PhpSpreadsheet\Cell\Cell;
|
|
use PhpOffice\PhpSpreadsheet\Exception as SpreadsheetException;
|
|
use PhpOffice\PhpSpreadsheet\Spreadsheet;
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
class CellDetachTest extends TestCase
|
|
{
|
|
/** @var ?Spreadsheet */
|
|
private $spreadsheet;
|
|
|
|
protected function tearDown(): void
|
|
{
|
|
if ($this->spreadsheet !== null) {
|
|
$this->spreadsheet->disconnectWorksheets();
|
|
$this->spreadsheet = null;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerMethodName
|
|
*/
|
|
public function testDetach(string $method): void
|
|
{
|
|
$this->expectException(SpreadsheetException::class);
|
|
$this->expectExceptionMessage('is not bound to a worksheet');
|
|
$this->spreadsheet = new Spreadsheet();
|
|
$sheet = $this->spreadsheet->getActiveSheet();
|
|
$sheet->getCell('A1')->detach();
|
|
if (method_exists(Cell::class, $method)) {
|
|
$sheet->getCell('A1')->$method();
|
|
} else {
|
|
self::fail("Cell method $method does not exist");
|
|
}
|
|
}
|
|
|
|
public static function providerMethodName(): array
|
|
{
|
|
return [
|
|
['updateInCollection'],
|
|
['getColumn'],
|
|
['getRow'],
|
|
['hasDataValidation'],
|
|
['getDataValidation'],
|
|
['hasHyperlink'],
|
|
['getHyperlink'],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerMethodNameSet
|
|
*/
|
|
public function testDetachSet(string $method): void
|
|
{
|
|
$this->expectException(SpreadsheetException::class);
|
|
$this->expectExceptionMessage('is not bound to a worksheet');
|
|
$this->spreadsheet = new Spreadsheet();
|
|
$sheet = $this->spreadsheet->getActiveSheet();
|
|
$sheet->getCell('A1')->detach();
|
|
if (method_exists(Cell::class, $method)) {
|
|
$sheet->getCell('A1')->$method(null);
|
|
} else {
|
|
self::fail("Cell method $method does not exist");
|
|
}
|
|
}
|
|
|
|
public static function providerMethodNameSet(): array
|
|
{
|
|
return [
|
|
['setDataValidation'],
|
|
['setHyperlink'],
|
|
['setValue'],
|
|
];
|
|
}
|
|
}
|
|
|