PhpSpreadsheet/tests/PhpSpreadsheetTests/Cell/AddressHelperTest.php
Mark Baker a264cafe4c
Helper class for the conversion of cell addresses between A1 and R1C1 formats, and vice-versa (#1558)
* Helper class for the conversion of cell addresses between A1 and R1C1 formats, and vice-versa
2020-06-27 23:03:25 +02:00

109 lines
3.0 KiB
PHP

<?php
namespace PhpOffice\PhpSpreadsheetTests\Cell;
use PhpOffice\PhpSpreadsheet\Cell\AddressHelper;
use PhpOffice\PhpSpreadsheet\Exception;
use PHPUnit\Framework\TestCase;
class AddressHelperTest extends TestCase
{
/**
* @dataProvider providerR1C1ConversionToA1Absolute
*/
public function testR1C1ConversionToA1Absolute(string $expectedValue, string $address): void
{
$actualValue = AddressHelper::convertToA1($address);
self::assertSame($expectedValue, $actualValue);
}
public function providerR1C1ConversionToA1Absolute()
{
return require 'tests/data/Cell/R1C1ConversionToA1Absolute.php';
}
/**
* @dataProvider providerR1C1ConversionToA1Relative
*/
public function testR1C1ConversionToA1Relative(string $expectedValue, string $address, ?int $row = null, ?int $column = null): void
{
$args = [$address];
if ($row !== null) {
$args[] = $row;
}
if ($column !== null) {
$args[] = $column;
}
$actualValue = AddressHelper::convertToA1(...$args);
self::assertSame($expectedValue, $actualValue);
}
public function providerR1C1ConversionToA1Relative()
{
return require 'tests/data/Cell/R1C1ConversionToA1Relative.php';
}
/**
* @dataProvider providerR1C1ConversionToA1Exception
*/
public function testR1C1ConversionToA1Exception(string $address): void
{
$this->expectException(Exception::class);
AddressHelper::convertToA1($address);
}
public function providerR1C1ConversionToA1Exception()
{
return require 'tests/data/Cell/R1C1ConversionToA1Exception.php';
}
/**
* @dataProvider providerA1ConversionToR1C1Absolute
*/
public function testA1ConversionToR1C1Absolute(string $expectedValue, string $address): void
{
$actualValue = AddressHelper::convertToR1C1($address);
self::assertSame($expectedValue, $actualValue);
}
public function providerA1ConversionToR1C1Absolute()
{
return require 'tests/data/Cell/A1ConversionToR1C1Absolute.php';
}
/**
* @dataProvider providerA1ConversionToR1C1Relative
*/
public function testA1ConversionToR1C1Relative(string $expectedValue, string $address, ?int $row = null, ?int $column = null): void
{
$actualValue = AddressHelper::convertToR1C1($address, $row, $column);
self::assertSame($expectedValue, $actualValue);
}
public function providerA1ConversionToR1C1Relative()
{
return require 'tests/data/Cell/A1ConversionToR1C1Relative.php';
}
/**
* @dataProvider providerA1ConversionToR1C1Exception
*/
public function testA1ConversionToR1C1Exception(string $address): void
{
$this->expectException(Exception::class);
AddressHelper::convertToR1C1($address);
}
public function providerA1ConversionToR1C1Exception()
{
return require 'tests/data/Cell/A1ConversionToR1C1Exception.php';
}
}