PhpSpreadsheet/tests/PhpSpreadsheetTests/Shared/DateTest.php

192 lines
5.5 KiB
PHP
Raw Normal View History

2012-06-24 21:33:33 +00:00
<?php
namespace PhpSpreadsheetTests\Shared;
2012-06-24 21:33:33 +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()
{
$calendarValues = [
Date::CALENDAR_MAC_1904,
Date::CALENDAR_WINDOWS_1900,
];
2015-05-17 13:00:02 +00:00
foreach ($calendarValues as $calendarValue) {
$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';
$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
{
2016-08-26 06:05:40 +00:00
call_user_func(
[Date::class, 'setExcelCalendar'],
Date::CALENDAR_WINDOWS_1900
2015-05-17 13:00:02 +00:00
);
$args = func_get_args();
$expectedResult = array_pop($args);
$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
{
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
/**
* @dataProvider providerDateTimeTimestampToExcel1900
2012-07-24 12:21:31 +00:00
*/
public function testDateTimeTimestampToExcel1900()
2015-05-17 13:00:02 +00:00
{
2016-08-26 06:05:40 +00:00
call_user_func(
[Date::class, 'setExcelCalendar'],
Date::CALENDAR_WINDOWS_1900
2015-05-17 13:00:02 +00:00
);
$args = func_get_args();
$expectedResult = array_pop($args);
$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
public function providerDateTimeTimestampToExcel1900()
2012-07-24 12:21:31 +00:00
{
return require 'data/Shared/Date/TimestampToExcel1900.php';
}
/**
* @dataProvider providerDateTimeDateTimeToExcel
*/
public function testDateTimeDateTimeToExcel()
{
2016-08-26 06:05:40 +00:00
call_user_func(
[Date::class, 'setExcelCalendar'],
Date::CALENDAR_WINDOWS_1900
);
$args = func_get_args();
$expectedResult = array_pop($args);
$result = call_user_func_array([Date::class, 'dateTimeToExcel'], $args);
$this->assertEquals($expectedResult, $result, null, 1E-5);
}
public function providerDateTimeDateTimeToExcel()
{
return require 'data/Shared/Date/DateTimeToExcel.php';
2015-05-17 13:00:02 +00:00
}
2012-07-24 12:21:31 +00:00
/**
* @dataProvider providerDateTimeFormattedPHPToExcel1900
2012-07-24 12:21:31 +00:00
*/
public function testDateTimeFormattedPHPToExcel1900()
2015-05-17 13:00:02 +00:00
{
2016-08-26 06:05:40 +00:00
call_user_func(
[Date::class, 'setExcelCalendar'],
Date::CALENDAR_WINDOWS_1900
2015-05-17 13:00:02 +00:00
);
$args = func_get_args();
$expectedResult = array_pop($args);
$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
public function providerDateTimeFormattedPHPToExcel1900()
2012-07-24 12:21:31 +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
{
2016-08-26 06:05:40 +00:00
call_user_func(
[Date::class, 'setExcelCalendar'],
Date::CALENDAR_MAC_1904
2015-05-17 13:00:02 +00:00
);
$args = func_get_args();
$expectedResult = array_pop($args);
$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
{
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
/**
* @dataProvider providerDateTimeTimestampToExcel1904
2012-07-24 12:21:31 +00:00
*/
public function testDateTimeTimestampToExcel1904()
2015-05-17 13:00:02 +00:00
{
2016-08-26 06:05:40 +00:00
call_user_func(
[Date::class, 'setExcelCalendar'],
Date::CALENDAR_MAC_1904
2015-05-17 13:00:02 +00:00
);
$args = func_get_args();
$expectedResult = array_pop($args);
$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
public function providerDateTimeTimestampToExcel1904()
2012-07-24 12:21:31 +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);
$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()
{
return require 'data/Shared/Date/FormatCodes.php';
2015-05-17 13:00:02 +00:00
}
2012-06-24 21:33:33 +00:00
/**
2016-08-13 19:21:45 +00:00
* @dataProvider providerDateTimeExcelToTimestamp1900Timezone
*/
2016-08-13 19:21:45 +00:00
public function testDateTimeExcelToTimestamp1900Timezone()
2015-05-17 13:00:02 +00:00
{
2016-08-26 06:05:40 +00:00
call_user_func(
[Date::class, 'setExcelCalendar'],
Date::CALENDAR_WINDOWS_1900
2015-05-17 13:00:02 +00:00
);
$args = func_get_args();
$expectedResult = array_pop($args);
$result = call_user_func_array([Date::class, 'excelToTimestamp'], $args);
2015-05-17 13:00:02 +00:00
$this->assertEquals($expectedResult, $result);
}
2016-08-13 19:21:45 +00:00
public function providerDateTimeExcelToTimestamp1900Timezone()
{
return require 'data/Shared/Date/ExcelToTimestamp1900Timezone.php';
2015-05-17 13:00:02 +00:00
}
2012-06-24 21:33:33 +00:00
}