p2 project
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

<?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'],
];
}
}