40 lines
1.3 KiB
PHP
40 lines
1.3 KiB
PHP
<?php
|
|
|
|
namespace PhpOffice\PhpSpreadsheetTests\Calculation\Functions\LookupRef;
|
|
|
|
use PhpOffice\PhpSpreadsheet\Calculation\LookupRef;
|
|
|
|
class ColumnTest extends AllSetupTeardown
|
|
{
|
|
/**
|
|
* @dataProvider providerCOLUMN
|
|
*
|
|
* @param mixed $expectedResult
|
|
* @param null|array|string $cellReference
|
|
*/
|
|
public function testCOLUMN($expectedResult, $cellReference = null): void
|
|
{
|
|
$result = LookupRef\RowColumnInformation::COLUMN($cellReference);
|
|
self::assertSame($expectedResult, $result);
|
|
}
|
|
|
|
public function providerCOLUMN(): array
|
|
{
|
|
return require 'tests/data/Calculation/LookupRef/COLUMN.php';
|
|
}
|
|
|
|
public function testCOLUMNwithNull(): void
|
|
{
|
|
$sheet = $this->getSheet();
|
|
$sheet->getCell('D1')->setValue('=COLUMN()');
|
|
self::assertSame(4, $sheet->getCell('D1')->getCalculatedValue());
|
|
$sheet->getCell('D2')->setValue('=COLUMN(C13)');
|
|
self::assertSame(3, $sheet->getCell('D2')->getCalculatedValue());
|
|
// Sheetnames don't have to exist
|
|
$sheet->getCell('D3')->setValue('=COLUMN(Sheet17!E15)');
|
|
self::assertSame(5, $sheet->getCell('D3')->getCalculatedValue());
|
|
$sheet->getCell('D4')->setValue("=COLUMN('Worksheet #5'!X500)");
|
|
self::assertSame(24, $sheet->getCell('D4')->getCalculatedValue());
|
|
}
|
|
}
|