assertTrue($result); } } public function testSetExcelCalendarWithInvalidValue() { $unsupportedCalendar = '2012'; $result = call_user_func(array('PHPExcel_Shared_Date','setExcelCalendar'),$unsupportedCalendar); $this->assertFalse($result); } public function testSetTimezone() { $timezoneValues = array( 'Europe/Prague', 'Asia/Tokyo', 'America/Indiana/Indianapolis', 'Pacific/Honolulu', 'Atlantic/St_Helena', ); foreach($timezoneValues as $timezoneValue) { $result = call_user_func(array('PHPExcel_Shared_Date','setTimezone'),$timezoneValue); $this->assertTrue($result); } } public function testSetTimezoneWithInvalidValue() { $unsupportedTimezone = 'Etc/GMT+10'; $result = call_user_func(array('PHPExcel_Shared_Date','setTimezone'),$unsupportedTimezone); $this->assertFalse($result); } /** * @dataProvider providerDateTimeExcelToPHP1900 */ public function testDateTimeExcelToPHP1900() { $result = call_user_func( array('PHPExcel_Shared_Date','setExcelCalendar'), PHPExcel_Shared_Date::CALENDAR_WINDOWS_1900 ); $args = func_get_args(); $expectedResult = array_pop($args); if ($args[0] < 1) { $expectedResult += gmmktime(0,0,0); } $result = call_user_func_array(array('PHPExcel_Shared_Date','ExcelToPHP'),$args); $this->assertEquals($expectedResult, $result); } public function providerDateTimeExcelToPHP1900() { return new testDataFileIterator('rawTestData/Shared/DateTimeExcelToPHP1900.data'); } /** * @dataProvider providerDateTimePHPToExcel1900 */ public function testDateTimePHPToExcel1900() { $result = call_user_func( array('PHPExcel_Shared_Date','setExcelCalendar'), PHPExcel_Shared_Date::CALENDAR_WINDOWS_1900 ); $args = func_get_args(); $expectedResult = array_pop($args); $result = call_user_func_array(array('PHPExcel_Shared_Date','PHPToExcel'),$args); $this->assertEquals($expectedResult, $result, NULL, 1E-5); } public function providerDateTimePHPToExcel1900() { return new testDataFileIterator('rawTestData/Shared/DateTimePHPToExcel1900.data'); } /** * @dataProvider providerDateTimeFormattedPHPToExcel1900 */ public function testDateTimeFormattedPHPToExcel1900() { $result = call_user_func( array('PHPExcel_Shared_Date','setExcelCalendar'), PHPExcel_Shared_Date::CALENDAR_WINDOWS_1900 ); $args = func_get_args(); $expectedResult = array_pop($args); $result = call_user_func_array(array('PHPExcel_Shared_Date','FormattedPHPToExcel'),$args); $this->assertEquals($expectedResult, $result, NULL, 1E-5); } public function providerDateTimeFormattedPHPToExcel1900() { return new testDataFileIterator('rawTestData/Shared/DateTimeFormattedPHPToExcel1900.data'); } /** * @dataProvider providerDateTimeExcelToPHP1904 */ public function testDateTimeExcelToPHP1904() { $result = call_user_func( array('PHPExcel_Shared_Date','setExcelCalendar'), PHPExcel_Shared_Date::CALENDAR_MAC_1904 ); $args = func_get_args(); $expectedResult = array_pop($args); if ($args[0] < 1) { $expectedResult += gmmktime(0,0,0); } $result = call_user_func_array(array('PHPExcel_Shared_Date','ExcelToPHP'),$args); $this->assertEquals($expectedResult, $result); } public function providerDateTimeExcelToPHP1904() { return new testDataFileIterator('rawTestData/Shared/DateTimeExcelToPHP1904.data'); } /** * @dataProvider providerDateTimePHPToExcel1904 */ public function testDateTimePHPToExcel1904() { $result = call_user_func( array('PHPExcel_Shared_Date','setExcelCalendar'), PHPExcel_Shared_Date::CALENDAR_MAC_1904 ); $args = func_get_args(); $expectedResult = array_pop($args); $result = call_user_func_array(array('PHPExcel_Shared_Date','PHPToExcel'),$args); $this->assertEquals($expectedResult, $result, NULL, 1E-5); } public function providerDateTimePHPToExcel1904() { return new testDataFileIterator('rawTestData/Shared/DateTimePHPToExcel1904.data'); } /** * @dataProvider providerIsDateTimeFormatCode */ public function testIsDateTimeFormatCode() { $args = func_get_args(); $expectedResult = array_pop($args); $result = call_user_func_array(array('PHPExcel_Shared_Date','isDateTimeFormatCode'),$args); $this->assertEquals($expectedResult, $result); } public function providerIsDateTimeFormatCode() { return new testDataFileIterator('rawTestData/Shared/DateTimeFormatCodes.data'); } /** * @dataProvider providerDateTimeExcelToPHP1900Timezone */ public function testDateTimeExcelToPHP1900Timezone() { $result = call_user_func( array('PHPExcel_Shared_Date','setExcelCalendar'), PHPExcel_Shared_Date::CALENDAR_WINDOWS_1900 ); $args = func_get_args(); $expectedResult = array_pop($args); if ($args[0] < 1) { $expectedResult += gmmktime(0,0,0); } $result = call_user_func_array(array('PHPExcel_Shared_Date','ExcelToPHP'),$args); $this->assertEquals($expectedResult, $result); } public function providerDateTimeExcelToPHP1900Timezone() { return new testDataFileIterator('rawTestData/Shared/DateTimeExcelToPHP1900Timezone.data'); } }