157 lines
5.5 KiB
PHP
157 lines
5.5 KiB
PHP
<?php
|
|
|
|
namespace PhpOffice\PhpSpreadsheetTests\Calculation\Functions\DateTime;
|
|
|
|
use PhpOffice\PhpSpreadsheet\Calculation\Calculation;
|
|
use PhpOffice\PhpSpreadsheet\Calculation\DateTimeExcel\Time;
|
|
use PhpOffice\PhpSpreadsheet\Calculation\Exception;
|
|
|
|
class TimeTest extends AllSetupTeardown
|
|
{
|
|
/**
|
|
* @dataProvider providerTIME
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testTIME($expectedResult, string $formula): void
|
|
{
|
|
$this->mightHaveException($expectedResult);
|
|
$sheet = $this->getSheet();
|
|
$sheet->getCell('B1')->setValue('15');
|
|
$sheet->getCell('B2')->setValue('32');
|
|
$sheet->getCell('B3')->setValue('50');
|
|
$sheet->getCell('A1')->setValue("=TIME($formula)");
|
|
self::assertEqualsWithDelta($expectedResult, $sheet->getCell('A1')->getCalculatedValue(), 1E-8);
|
|
}
|
|
|
|
public function providerTIME(): array
|
|
{
|
|
return require 'tests/data/Calculation/DateTime/TIME.php';
|
|
}
|
|
|
|
public function testTIMEtoUnixTimestamp(): void
|
|
{
|
|
self::setUnixReturn();
|
|
|
|
$result = Time::fromHMS(7, 30, 20);
|
|
self::assertEqualsWithDelta(27020, $result, 1E-8);
|
|
}
|
|
|
|
public function testTIMEtoDateTimeObject(): void
|
|
{
|
|
self::setObjectReturn();
|
|
|
|
$result = Time::fromHMS(7, 30, 20);
|
|
// Must return an object...
|
|
self::assertIsObject($result);
|
|
// ... of the correct type
|
|
self::assertTrue(is_a($result, 'DateTimeInterface'));
|
|
// ... with the correct value
|
|
self::assertEquals($result->format('H:i:s'), '07:30:20');
|
|
}
|
|
|
|
public function testTIME1904(): void
|
|
{
|
|
self::setMac1904();
|
|
$result = Time::fromHMS(0, 0, 0);
|
|
self::assertEquals(0, $result);
|
|
}
|
|
|
|
public function testTIME1900(): void
|
|
{
|
|
$result = Time::fromHMS(0, 0, 0);
|
|
self::assertEquals(0, $result);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerTimeArray
|
|
*/
|
|
public function testTimeArray(array $expectedResult, string $hour, string $minute, string $second): void
|
|
{
|
|
$calculation = Calculation::getInstance();
|
|
|
|
$formula = "=TIME({$hour}, {$minute}, {$second})";
|
|
$result = $calculation->_calculateFormulaValue($formula);
|
|
self::assertEqualsWithDelta($expectedResult, $result, 1.0e-14);
|
|
}
|
|
|
|
public function providerTimeArray(): array
|
|
{
|
|
return [
|
|
'row vector hour' => [[[0.250706018518519, 0.50070601851852, 0.75070601851852]], '{6,12,18}', '1', '1'],
|
|
'column vector hour' => [[[0.250706018518519], [0.50070601851852], [0.75070601851852]], '{6;12;18}', '1', '1'],
|
|
'matrix hour' => [[[0.250706018518519, 0.50070601851852], [0.75070601851852, 0.95903935185185]], '{6,12;18,23}', '1', '1'],
|
|
'row vector minute' => [[[0.96667824074074, 0.97501157407407, 0.98334490740741, 0.99931712962963]], '23', '{12, 24, 36, 59}', '1'],
|
|
'column vector minute' => [[[0.96734953703704], [0.97568287037037], [0.98401620370370], [0.99998842592593]], '23', '{12; 24; 36; 59}', '59'],
|
|
'matrix minute' => [[[0.50833333333333, 0.51666666666667], [0.52083333333333, 0.5]], '12', '{12, 24; 30, 0}', '0'],
|
|
'row vector second' => [[[0.50069444444444, 0.50137731481481]], '12', '1', '{0,59}'],
|
|
'column vector second' => [[[0.99930555555556], [0.99998842592593]], '23', '59', '{0;59}'],
|
|
'vectors hour and minute' => [
|
|
[
|
|
[0.87570601851852, 0.88473379629630, 0.89376157407407, 0.90626157407407],
|
|
[0.91737268518519, 0.92640046296296, 0.93542824074074, 0.94792824074074],
|
|
[0.95903935185185, 0.96806712962963, 0.97709490740741, 0.98959490740741],
|
|
],
|
|
'{21;22;23}',
|
|
'{1, 14, 27, 45}',
|
|
'1',
|
|
],
|
|
'vectors hour and second' => [
|
|
[
|
|
[0.126041666666667, 0.126215277777778],
|
|
[0.334375, 0.33454861111111],
|
|
[0.584375, 0.58454861111111],
|
|
],
|
|
'{3;8;14}',
|
|
'1',
|
|
'{30,45}',
|
|
],
|
|
'vectors minute and second' => [
|
|
[
|
|
[0.75833333333333, 0.75834490740741],
|
|
[0.76041666666667, 0.76042824074074],
|
|
[0.77083333333333, 0.77084490740741],
|
|
[0.75, 0.750011574074074],
|
|
],
|
|
'18',
|
|
'{12; 15; 30; 0}',
|
|
'{0,1}',
|
|
],
|
|
'matrices hour and minute' => [
|
|
[
|
|
[0.25070601851852, 0.50278935185185],
|
|
[0.75487268518519, 0.96528935185185],
|
|
],
|
|
'{6, 12; 18, 23}',
|
|
'{1, 4; 7, 10}',
|
|
'1',
|
|
],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerTimeArrayException
|
|
*/
|
|
public function testTimeArrayException(string $hour, string $minute, string $second): void
|
|
{
|
|
$calculation = Calculation::getInstance();
|
|
|
|
$this->expectException(Exception::class);
|
|
$this->expectExceptionMessage('Formulae with more than two array arguments are not supported');
|
|
|
|
$formula = "=TIME({$hour}, {$minute}, {$second})";
|
|
$calculation->_calculateFormulaValue($formula);
|
|
}
|
|
|
|
public function providerTimeArrayException(): array
|
|
{
|
|
return [
|
|
'matrix arguments with 3 array values' => [
|
|
'{6, 12; 16, 23}',
|
|
'{1, 4; 7, 10}',
|
|
'{0,1}',
|
|
],
|
|
];
|
|
}
|
|
}
|