<?php


require_once 'testDataFileIterator.php';

class DateTest extends PHPUnit_Framework_TestCase
{

    public function setUp()
    {
        if (!defined('PHPEXCEL_ROOT')) {
            define('PHPEXCEL_ROOT', APPLICATION_PATH . '/');
        }
        require_once(PHPEXCEL_ROOT . 'PHPExcel/Autoloader.php');
	}

	public function testSetExcelCalendar()
	{
		$calendarValues = array(
			PHPExcel_Shared_Date::CALENDAR_MAC_1904,
			PHPExcel_Shared_Date::CALENDAR_WINDOWS_1900,
		);

		foreach($calendarValues as $calendarValue) {
			$result = call_user_func(array('PHPExcel_Shared_Date','setExcelCalendar'),$calendarValue);
			$this->assertTrue($result);
		}
	}

    public function testSetExcelCalendarWithInvalidValue()
	{
		$unsupportedCalendar = '2012';
		$result = call_user_func(array('PHPExcel_Shared_Date','setExcelCalendar'),$unsupportedCalendar);
		$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');
	}

}