2012-06-24 21:33:33 +00:00
|
|
|
<?php
|
|
|
|
|
2016-08-25 04:53:15 +00:00
|
|
|
namespace PhpSpreadsheetTests\Shared;
|
2012-06-24 21:33:33 +00:00
|
|
|
|
2016-08-16 14:24:47 +00:00
|
|
|
use PhpSpreadsheet\Shared\Date;
|
2012-06-24 21:33:33 +00:00
|
|
|
|
2016-03-22 14:35:50 +00:00
|
|
|
class DateTest extends \PHPUnit_Framework_TestCase
|
2012-06-24 21:33:33 +00:00
|
|
|
{
|
2015-05-17 13:00:02 +00:00
|
|
|
public function testSetExcelCalendar()
|
|
|
|
{
|
2016-08-16 15:33:57 +00:00
|
|
|
$calendarValues = [
|
2016-08-14 04:08:43 +00:00
|
|
|
Date::CALENDAR_MAC_1904,
|
|
|
|
Date::CALENDAR_WINDOWS_1900,
|
2016-08-16 15:33:57 +00:00
|
|
|
];
|
2015-05-17 13:00:02 +00:00
|
|
|
|
|
|
|
foreach ($calendarValues as $calendarValue) {
|
2016-08-16 15:33:57 +00:00
|
|
|
$result = call_user_func([Date::class, 'setExcelCalendar'], $calendarValue);
|
2015-05-17 13:00:02 +00:00
|
|
|
$this->assertTrue($result);
|
|
|
|
}
|
|
|
|
}
|
2012-06-24 21:33:33 +00:00
|
|
|
|
|
|
|
public function testSetExcelCalendarWithInvalidValue()
|
2015-05-17 13:00:02 +00:00
|
|
|
{
|
|
|
|
$unsupportedCalendar = '2012';
|
2016-08-16 15:33:57 +00:00
|
|
|
$result = call_user_func([Date::class, 'setExcelCalendar'], $unsupportedCalendar);
|
2015-05-17 13:00:02 +00:00
|
|
|
$this->assertFalse($result);
|
|
|
|
}
|
2012-06-24 21:33:33 +00:00
|
|
|
|
|
|
|
/**
|
2016-08-13 19:21:45 +00:00
|
|
|
* @dataProvider providerDateTimeExcelToTimestamp1900
|
2012-06-24 21:33:33 +00:00
|
|
|
*/
|
2016-08-13 19:21:45 +00:00
|
|
|
public function testDateTimeExcelToTimestamp1900()
|
2015-05-17 13:00:02 +00:00
|
|
|
{
|
|
|
|
$result = call_user_func(
|
2016-08-16 15:33:57 +00:00
|
|
|
[Date::class, 'setExcelCalendar'],
|
2016-08-14 04:08:43 +00:00
|
|
|
Date::CALENDAR_WINDOWS_1900
|
2015-05-17 13:00:02 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
$args = func_get_args();
|
|
|
|
$expectedResult = array_pop($args);
|
2016-08-16 15:33:57 +00:00
|
|
|
$result = call_user_func_array([Date::class, 'excelToTimestamp'], $args);
|
2015-05-17 13:00:02 +00:00
|
|
|
$this->assertEquals($expectedResult, $result);
|
|
|
|
}
|
2012-06-24 21:33:33 +00:00
|
|
|
|
2016-08-13 19:21:45 +00:00
|
|
|
public function providerDateTimeExcelToTimestamp1900()
|
2012-06-24 21:33:33 +00:00
|
|
|
{
|
2016-08-16 12:00:19 +00:00
|
|
|
return require 'data/Shared/Date/ExcelToTimestamp1900.php';
|
2015-05-17 13:00:02 +00:00
|
|
|
}
|
2012-06-24 21:33:33 +00:00
|
|
|
|
2012-07-24 12:21:31 +00:00
|
|
|
/**
|
2016-08-14 21:36:30 +00:00
|
|
|
* @dataProvider providerDateTimeTimestampToExcel1900
|
2012-07-24 12:21:31 +00:00
|
|
|
*/
|
2016-08-14 21:36:30 +00:00
|
|
|
public function testDateTimeTimestampToExcel1900()
|
2015-05-17 13:00:02 +00:00
|
|
|
{
|
|
|
|
$result = call_user_func(
|
2016-08-16 15:33:57 +00:00
|
|
|
[Date::class, 'setExcelCalendar'],
|
2016-08-14 04:08:43 +00:00
|
|
|
Date::CALENDAR_WINDOWS_1900
|
2015-05-17 13:00:02 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
$args = func_get_args();
|
|
|
|
$expectedResult = array_pop($args);
|
2016-08-16 15:33:57 +00:00
|
|
|
$result = call_user_func_array([Date::class, 'timestampToExcel'], $args);
|
2015-05-17 13:00:02 +00:00
|
|
|
$this->assertEquals($expectedResult, $result, null, 1E-5);
|
|
|
|
}
|
2012-07-24 12:21:31 +00:00
|
|
|
|
2016-08-14 21:36:30 +00:00
|
|
|
public function providerDateTimeTimestampToExcel1900()
|
2012-07-24 12:21:31 +00:00
|
|
|
{
|
2016-08-16 12:00:19 +00:00
|
|
|
return require 'data/Shared/Date/TimestampToExcel1900.php';
|
2016-08-14 21:36:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @dataProvider providerDateTimeDateTimeToExcel
|
|
|
|
*/
|
|
|
|
public function testDateTimeDateTimeToExcel()
|
|
|
|
{
|
|
|
|
$result = call_user_func(
|
2016-08-16 15:33:57 +00:00
|
|
|
[Date::class, 'setExcelCalendar'],
|
2016-08-14 21:36:30 +00:00
|
|
|
Date::CALENDAR_WINDOWS_1900
|
|
|
|
);
|
|
|
|
|
|
|
|
$args = func_get_args();
|
|
|
|
$expectedResult = array_pop($args);
|
2016-08-16 15:33:57 +00:00
|
|
|
$result = call_user_func_array([Date::class, 'dateTimeToExcel'], $args);
|
2016-08-14 21:36:30 +00:00
|
|
|
$this->assertEquals($expectedResult, $result, null, 1E-5);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function providerDateTimeDateTimeToExcel()
|
|
|
|
{
|
2016-08-16 12:00:19 +00:00
|
|
|
return require 'data/Shared/Date/DateTimeToExcel.php';
|
2015-05-17 13:00:02 +00:00
|
|
|
}
|
2012-07-24 12:21:31 +00:00
|
|
|
|
|
|
|
/**
|
2016-03-22 21:26:17 +00:00
|
|
|
* @dataProvider providerDateTimeFormattedPHPToExcel1900
|
2012-07-24 12:21:31 +00:00
|
|
|
*/
|
2016-03-22 21:26:17 +00:00
|
|
|
public function testDateTimeFormattedPHPToExcel1900()
|
2015-05-17 13:00:02 +00:00
|
|
|
{
|
|
|
|
$result = call_user_func(
|
2016-08-16 15:33:57 +00:00
|
|
|
[Date::class, 'setExcelCalendar'],
|
2016-08-14 04:08:43 +00:00
|
|
|
Date::CALENDAR_WINDOWS_1900
|
2015-05-17 13:00:02 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
$args = func_get_args();
|
|
|
|
$expectedResult = array_pop($args);
|
2016-08-16 15:33:57 +00:00
|
|
|
$result = call_user_func_array([Date::class, 'formattedPHPToExcel'], $args);
|
2015-05-17 13:00:02 +00:00
|
|
|
$this->assertEquals($expectedResult, $result, null, 1E-5);
|
|
|
|
}
|
2012-07-24 12:21:31 +00:00
|
|
|
|
2016-03-22 21:26:17 +00:00
|
|
|
public function providerDateTimeFormattedPHPToExcel1900()
|
2012-07-24 12:21:31 +00:00
|
|
|
{
|
2016-08-16 12:00:19 +00:00
|
|
|
return require 'data/Shared/Date/FormattedPHPToExcel1900.php';
|
2015-05-17 13:00:02 +00:00
|
|
|
}
|
2012-07-24 12:21:31 +00:00
|
|
|
|
2012-06-24 21:33:33 +00:00
|
|
|
/**
|
2016-08-13 19:21:45 +00:00
|
|
|
* @dataProvider providerDateTimeExcelToTimestamp1904
|
2012-06-24 21:33:33 +00:00
|
|
|
*/
|
2016-08-13 19:21:45 +00:00
|
|
|
public function testDateTimeExcelToTimestamp1904()
|
2015-05-17 13:00:02 +00:00
|
|
|
{
|
|
|
|
$result = call_user_func(
|
2016-08-16 15:33:57 +00:00
|
|
|
[Date::class, 'setExcelCalendar'],
|
2016-08-14 04:08:43 +00:00
|
|
|
Date::CALENDAR_MAC_1904
|
2015-05-17 13:00:02 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
$args = func_get_args();
|
|
|
|
$expectedResult = array_pop($args);
|
2016-08-16 15:33:57 +00:00
|
|
|
$result = call_user_func_array([Date::class, 'excelToTimestamp'], $args);
|
2015-05-17 13:00:02 +00:00
|
|
|
$this->assertEquals($expectedResult, $result);
|
|
|
|
}
|
2012-06-24 21:33:33 +00:00
|
|
|
|
2016-08-13 19:21:45 +00:00
|
|
|
public function providerDateTimeExcelToTimestamp1904()
|
2012-06-24 21:33:33 +00:00
|
|
|
{
|
2016-08-16 12:00:19 +00:00
|
|
|
return require 'data/Shared/Date/ExcelToTimestamp1904.php';
|
2015-05-17 13:00:02 +00:00
|
|
|
}
|
2012-06-24 21:33:33 +00:00
|
|
|
|
2012-07-24 12:21:31 +00:00
|
|
|
/**
|
2016-08-14 21:36:30 +00:00
|
|
|
* @dataProvider providerDateTimeTimestampToExcel1904
|
2012-07-24 12:21:31 +00:00
|
|
|
*/
|
2016-08-14 21:36:30 +00:00
|
|
|
public function testDateTimeTimestampToExcel1904()
|
2015-05-17 13:00:02 +00:00
|
|
|
{
|
|
|
|
$result = call_user_func(
|
2016-08-16 15:33:57 +00:00
|
|
|
[Date::class, 'setExcelCalendar'],
|
2016-08-14 04:08:43 +00:00
|
|
|
Date::CALENDAR_MAC_1904
|
2015-05-17 13:00:02 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
$args = func_get_args();
|
|
|
|
$expectedResult = array_pop($args);
|
2016-08-16 15:33:57 +00:00
|
|
|
$result = call_user_func_array([Date::class, 'timestampToExcel'], $args);
|
2015-05-17 13:00:02 +00:00
|
|
|
$this->assertEquals($expectedResult, $result, null, 1E-5);
|
|
|
|
}
|
2012-07-24 12:21:31 +00:00
|
|
|
|
2016-08-14 21:36:30 +00:00
|
|
|
public function providerDateTimeTimestampToExcel1904()
|
2012-07-24 12:21:31 +00:00
|
|
|
{
|
2016-08-16 12:00:19 +00:00
|
|
|
return require 'data/Shared/Date/TimestampToExcel1904.php';
|
2015-05-17 13:00:02 +00:00
|
|
|
}
|
2012-07-24 12:21:31 +00:00
|
|
|
|
2012-06-24 21:33:33 +00:00
|
|
|
/**
|
|
|
|
* @dataProvider providerIsDateTimeFormatCode
|
|
|
|
*/
|
2015-05-17 13:00:02 +00:00
|
|
|
public function testIsDateTimeFormatCode()
|
|
|
|
{
|
|
|
|
$args = func_get_args();
|
|
|
|
$expectedResult = array_pop($args);
|
2016-08-16 15:33:57 +00:00
|
|
|
$result = call_user_func_array([Date::class, 'isDateTimeFormatCode'], $args);
|
2015-05-17 13:00:02 +00:00
|
|
|
$this->assertEquals($expectedResult, $result);
|
|
|
|
}
|
2012-06-24 21:33:33 +00:00
|
|
|
|
|
|
|
public function providerIsDateTimeFormatCode()
|
|
|
|
{
|
2016-08-16 12:00:19 +00:00
|
|
|
return require 'data/Shared/Date/FormatCodes.php';
|
2015-05-17 13:00:02 +00:00
|
|
|
}
|
2012-06-24 21:33:33 +00:00
|
|
|
|
2012-11-02 23:07:01 +00:00
|
|
|
/**
|
2016-08-13 19:21:45 +00:00
|
|
|
* @dataProvider providerDateTimeExcelToTimestamp1900Timezone
|
2012-11-02 23:07:01 +00:00
|
|
|
*/
|
2016-08-13 19:21:45 +00:00
|
|
|
public function testDateTimeExcelToTimestamp1900Timezone()
|
2015-05-17 13:00:02 +00:00
|
|
|
{
|
|
|
|
$result = call_user_func(
|
2016-08-16 15:33:57 +00:00
|
|
|
[Date::class, 'setExcelCalendar'],
|
2016-08-14 04:08:43 +00:00
|
|
|
Date::CALENDAR_WINDOWS_1900
|
2015-05-17 13:00:02 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
$args = func_get_args();
|
|
|
|
$expectedResult = array_pop($args);
|
2016-08-16 15:33:57 +00:00
|
|
|
$result = call_user_func_array([Date::class, 'excelToTimestamp'], $args);
|
2015-05-17 13:00:02 +00:00
|
|
|
$this->assertEquals($expectedResult, $result);
|
|
|
|
}
|
2012-11-02 23:07:01 +00:00
|
|
|
|
2016-08-13 19:21:45 +00:00
|
|
|
public function providerDateTimeExcelToTimestamp1900Timezone()
|
2012-11-02 23:07:01 +00:00
|
|
|
{
|
2016-08-16 12:00:19 +00:00
|
|
|
return require 'data/Shared/Date/ExcelToTimestamp1900Timezone.php';
|
2015-05-17 13:00:02 +00:00
|
|
|
}
|
2012-06-24 21:33:33 +00:00
|
|
|
}
|