| 
									
										
										
										
											2012-06-24 21:33:33 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-22 14:35:50 +00:00
										 |  |  | namespace PHPExcel\Shared; | 
					
						
							| 
									
										
										
										
											2012-06-24 21:33:33 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | require_once 'testDataFileIterator.php'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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 = array( | 
					
						
							| 
									
										
										
										
											2016-03-22 14:19:00 +00:00
										 |  |  |             \PHPExcel\Shared\Date::CALENDAR_MAC_1904, | 
					
						
							|  |  |  |             \PHPExcel\Shared\Date::CALENDAR_WINDOWS_1900, | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         foreach ($calendarValues as $calendarValue) { | 
					
						
							| 
									
										
										
										
											2016-03-22 14:19:00 +00:00
										 |  |  |             $result = call_user_func(array('\PHPExcel\Shared\Date','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-03-22 14:19:00 +00:00
										 |  |  |         $result = call_user_func(array('\PHPExcel\Shared\Date','setExcelCalendar'), $unsupportedCalendar); | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |         $this->assertFalse($result); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-06-24 21:33:33 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @dataProvider providerDateTimeExcelToPHP1900 | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |     public function testDateTimeExcelToPHP1900() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $result = call_user_func( | 
					
						
							| 
									
										
										
										
											2016-03-22 14:19:00 +00:00
										 |  |  |             array('\PHPExcel\Shared\Date','setExcelCalendar'), | 
					
						
							|  |  |  |             \PHPExcel\Shared\Date::CALENDAR_WINDOWS_1900 | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $args = func_get_args(); | 
					
						
							|  |  |  |         $expectedResult = array_pop($args); | 
					
						
							|  |  |  |         if ($args[0] < 1) { | 
					
						
							| 
									
										
										
										
											2015-05-17 17:26:34 +00:00
										 |  |  |             $expectedResult += gmmktime(0, 0, 0); | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-03-22 14:19:00 +00:00
										 |  |  |         $result = call_user_func_array(array('\PHPExcel\Shared\Date', 'ExcelToPHP'), $args); | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |         $this->assertEquals($expectedResult, $result); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-06-24 21:33:33 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     public function providerDateTimeExcelToPHP1900() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-05-18 11:37:00 +00:00
										 |  |  |         return new \PhpSpreadhsheet\unitTests\TestDataFileIterator('rawTestData/Shared/DateTimeExcelToPHP1900.data'); | 
					
						
							| 
									
										
										
										
											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 providerDateTimePHPToExcel1900 | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |     public function testDateTimePHPToExcel1900() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $result = call_user_func( | 
					
						
							| 
									
										
										
										
											2016-03-22 14:19:00 +00:00
										 |  |  |             array('\PHPExcel\Shared\Date','setExcelCalendar'), | 
					
						
							|  |  |  |             \PHPExcel\Shared\Date::CALENDAR_WINDOWS_1900 | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $args = func_get_args(); | 
					
						
							|  |  |  |         $expectedResult = array_pop($args); | 
					
						
							| 
									
										
										
										
											2016-03-22 14:19:00 +00:00
										 |  |  |         $result = call_user_func_array(array('\PHPExcel\Shared\Date','PHPToExcel'), $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 providerDateTimePHPToExcel1900() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-05-18 11:37:00 +00:00
										 |  |  |         return new \PhpSpreadhsheet\unitTests\TestDataFileIterator('rawTestData/Shared/DateTimePHPToExcel1900.data'); | 
					
						
							| 
									
										
										
										
											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-03-22 14:19:00 +00:00
										 |  |  |             array('\PHPExcel\Shared\Date','setExcelCalendar'), | 
					
						
							|  |  |  |             \PHPExcel\Shared\Date::CALENDAR_WINDOWS_1900 | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $args = func_get_args(); | 
					
						
							|  |  |  |         $expectedResult = array_pop($args); | 
					
						
							| 
									
										
										
										
											2016-03-22 21:20:22 +00:00
										 |  |  |         $result = call_user_func_array(array('\PHPExcel\Shared\Date','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-05-18 11:37:00 +00:00
										 |  |  |         return new \PhpSpreadhsheet\unitTests\TestDataFileIterator('rawTestData/Shared/DateTimeFormattedPHPToExcel1900.data'); | 
					
						
							| 
									
										
										
										
											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 providerDateTimeExcelToPHP1904 | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |     public function testDateTimeExcelToPHP1904() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $result = call_user_func( | 
					
						
							| 
									
										
										
										
											2016-03-22 14:19:00 +00:00
										 |  |  |             array('\PHPExcel\Shared\Date','setExcelCalendar'), | 
					
						
							|  |  |  |             \PHPExcel\Shared\Date::CALENDAR_MAC_1904 | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $args = func_get_args(); | 
					
						
							|  |  |  |         $expectedResult = array_pop($args); | 
					
						
							|  |  |  |         if ($args[0] < 1) { | 
					
						
							| 
									
										
										
										
											2015-05-17 17:26:34 +00:00
										 |  |  |             $expectedResult += gmmktime(0, 0, 0); | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-03-22 14:19:00 +00:00
										 |  |  |         $result = call_user_func_array(array('\PHPExcel\Shared\Date','ExcelToPHP'), $args); | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |         $this->assertEquals($expectedResult, $result); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-06-24 21:33:33 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     public function providerDateTimeExcelToPHP1904() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-05-18 11:37:00 +00:00
										 |  |  |         return new \PhpSpreadhsheet\unitTests\TestDataFileIterator('rawTestData/Shared/DateTimeExcelToPHP1904.data'); | 
					
						
							| 
									
										
										
										
											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 providerDateTimePHPToExcel1904 | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |     public function testDateTimePHPToExcel1904() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $result = call_user_func( | 
					
						
							| 
									
										
										
										
											2016-03-22 14:19:00 +00:00
										 |  |  |             array('\PHPExcel\Shared\Date','setExcelCalendar'), | 
					
						
							|  |  |  |             \PHPExcel\Shared\Date::CALENDAR_MAC_1904 | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $args = func_get_args(); | 
					
						
							|  |  |  |         $expectedResult = array_pop($args); | 
					
						
							| 
									
										
										
										
											2016-03-22 14:19:00 +00:00
										 |  |  |         $result = call_user_func_array(array('\PHPExcel\Shared\Date','PHPToExcel'), $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 providerDateTimePHPToExcel1904() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-05-18 11:37:00 +00:00
										 |  |  |         return new \PhpSpreadhsheet\unitTests\TestDataFileIterator('rawTestData/Shared/DateTimePHPToExcel1904.data'); | 
					
						
							| 
									
										
										
										
											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-03-22 14:19:00 +00:00
										 |  |  |         $result = call_user_func_array(array('\PHPExcel\Shared\Date','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-05-18 11:37:00 +00:00
										 |  |  |         return new \PhpSpreadhsheet\unitTests\TestDataFileIterator('rawTestData/Shared/DateTimeFormatCodes.data'); | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-06-24 21:33:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-02 23:07:01 +00:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @dataProvider providerDateTimeExcelToPHP1900Timezone | 
					
						
							| 
									
										
										
										
											2016-05-19 10:31:40 +00:00
										 |  |  |      * @group fail19 | 
					
						
							| 
									
										
										
										
											2012-11-02 23:07:01 +00:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |     public function testDateTimeExcelToPHP1900Timezone() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $result = call_user_func( | 
					
						
							| 
									
										
										
										
											2016-03-22 14:19:00 +00:00
										 |  |  |             array('\PHPExcel\Shared\Date','setExcelCalendar'), | 
					
						
							|  |  |  |             \PHPExcel\Shared\Date::CALENDAR_WINDOWS_1900 | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $args = func_get_args(); | 
					
						
							|  |  |  |         $expectedResult = array_pop($args); | 
					
						
							|  |  |  |         if ($args[0] < 1) { | 
					
						
							| 
									
										
										
										
											2015-05-17 17:26:34 +00:00
										 |  |  |             $expectedResult += gmmktime(0, 0, 0); | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-03-22 14:19:00 +00:00
										 |  |  |         $result = call_user_func_array(array('\PHPExcel\Shared\Date','ExcelToPHP'), $args); | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |         $this->assertEquals($expectedResult, $result); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-11-02 23:07:01 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     public function providerDateTimeExcelToPHP1900Timezone() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-05-18 11:37:00 +00:00
										 |  |  |         return new \PhpSpreadhsheet\unitTests\TestDataFileIterator('rawTestData/Shared/DateTimeExcelToPHP1900Timezone.data'); | 
					
						
							| 
									
										
										
										
											2015-05-17 13:00:02 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-06-24 21:33:33 +00:00
										 |  |  | } |