172 lines
4.7 KiB
PHP
172 lines
4.7 KiB
PHP
<?php
|
|
|
|
namespace PhpOffice\PhpSpreadsheetTests\Shared;
|
|
|
|
use PhpOffice\PhpSpreadsheet\Shared\Date;
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
class DateTest extends TestCase
|
|
{
|
|
public function testSetExcelCalendar()
|
|
{
|
|
$calendarValues = [
|
|
Date::CALENDAR_MAC_1904,
|
|
Date::CALENDAR_WINDOWS_1900,
|
|
];
|
|
|
|
foreach ($calendarValues as $calendarValue) {
|
|
$result = Date::setExcelCalendar($calendarValue);
|
|
self::assertTrue($result);
|
|
}
|
|
}
|
|
|
|
public function testSetExcelCalendarWithInvalidValue()
|
|
{
|
|
$unsupportedCalendar = '2012';
|
|
$result = Date::setExcelCalendar($unsupportedCalendar);
|
|
self::assertFalse($result);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerDateTimeExcelToTimestamp1900
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testDateTimeExcelToTimestamp1900($expectedResult, ...$args)
|
|
{
|
|
Date::setExcelCalendar(Date::CALENDAR_WINDOWS_1900);
|
|
|
|
$result = Date::excelToTimestamp(...$args);
|
|
self::assertEquals($expectedResult, $result);
|
|
}
|
|
|
|
public function providerDateTimeExcelToTimestamp1900()
|
|
{
|
|
return require 'data/Shared/Date/ExcelToTimestamp1900.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerDateTimeTimestampToExcel1900
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testDateTimeTimestampToExcel1900($expectedResult, ...$args)
|
|
{
|
|
Date::setExcelCalendar(Date::CALENDAR_WINDOWS_1900);
|
|
|
|
$result = Date::timestampToExcel(...$args);
|
|
self::assertEquals($expectedResult, $result, null, 1E-5);
|
|
}
|
|
|
|
public function providerDateTimeTimestampToExcel1900()
|
|
{
|
|
return require 'data/Shared/Date/TimestampToExcel1900.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerDateTimeDateTimeToExcel
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testDateTimeDateTimeToExcel($expectedResult, ...$args)
|
|
{
|
|
Date::setExcelCalendar(Date::CALENDAR_WINDOWS_1900);
|
|
|
|
$result = Date::dateTimeToExcel(...$args);
|
|
self::assertEquals($expectedResult, $result, null, 1E-5);
|
|
}
|
|
|
|
public function providerDateTimeDateTimeToExcel()
|
|
{
|
|
return require 'data/Shared/Date/DateTimeToExcel.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerDateTimeFormattedPHPToExcel1900
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testDateTimeFormattedPHPToExcel1900($expectedResult, ...$args)
|
|
{
|
|
Date::setExcelCalendar(Date::CALENDAR_WINDOWS_1900);
|
|
|
|
$result = Date::formattedPHPToExcel(...$args);
|
|
self::assertEquals($expectedResult, $result, null, 1E-5);
|
|
}
|
|
|
|
public function providerDateTimeFormattedPHPToExcel1900()
|
|
{
|
|
return require 'data/Shared/Date/FormattedPHPToExcel1900.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerDateTimeExcelToTimestamp1904
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testDateTimeExcelToTimestamp1904($expectedResult, ...$args)
|
|
{
|
|
Date::setExcelCalendar(Date::CALENDAR_MAC_1904);
|
|
|
|
$result = Date::excelToTimestamp(...$args);
|
|
self::assertEquals($expectedResult, $result);
|
|
}
|
|
|
|
public function providerDateTimeExcelToTimestamp1904()
|
|
{
|
|
return require 'data/Shared/Date/ExcelToTimestamp1904.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerDateTimeTimestampToExcel1904
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testDateTimeTimestampToExcel1904($expectedResult, ...$args)
|
|
{
|
|
Date::setExcelCalendar(Date::CALENDAR_MAC_1904);
|
|
|
|
$result = Date::timestampToExcel(...$args);
|
|
self::assertEquals($expectedResult, $result, null, 1E-5);
|
|
}
|
|
|
|
public function providerDateTimeTimestampToExcel1904()
|
|
{
|
|
return require 'data/Shared/Date/TimestampToExcel1904.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerIsDateTimeFormatCode
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testIsDateTimeFormatCode($expectedResult, ...$args)
|
|
{
|
|
$result = Date::isDateTimeFormatCode(...$args);
|
|
self::assertEquals($expectedResult, $result);
|
|
}
|
|
|
|
public function providerIsDateTimeFormatCode()
|
|
{
|
|
return require 'data/Shared/Date/FormatCodes.php';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerDateTimeExcelToTimestamp1900Timezone
|
|
*
|
|
* @param mixed $expectedResult
|
|
*/
|
|
public function testDateTimeExcelToTimestamp1900Timezone($expectedResult, ...$args)
|
|
{
|
|
Date::setExcelCalendar(Date::CALENDAR_WINDOWS_1900);
|
|
|
|
$result = Date::excelToTimestamp(...$args);
|
|
self::assertEquals($expectedResult, $result);
|
|
}
|
|
|
|
public function providerDateTimeExcelToTimestamp1900Timezone()
|
|
{
|
|
return require 'data/Shared/Date/ExcelToTimestamp1900Timezone.php';
|
|
}
|
|
}
|