* * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\Intl\Tests\DateFormatter; use PHPUnit\Framework\TestCase; use Symfony\Component\Intl\DateFormatter\IntlDateFormatter; use Symfony\Component\Intl\Globals\IntlGlobals; use Symfony\Component\Intl\Intl; use Symfony\Component\Intl\Util\IcuVersion; /** * Test case for IntlDateFormatter implementations. * * @author Bernhard Schussek */ abstract class AbstractIntlDateFormatterTest extends TestCase { protected function setUp() { \Locale::setDefault('en'); } /** * When a time zone is not specified, it uses the system default however it returns null in the getter method. * * @see StubIntlDateFormatterTest::testDefaultTimeZoneIntl() */ public function testConstructorDefaultTimeZone() { $formatter = $this->getDateFormatter('en', IntlDateFormatter::MEDIUM, IntlDateFormatter::SHORT); $this->assertEquals(date_default_timezone_get(), $formatter->getTimeZoneId()); $this->assertEquals( $this->getDateTime(0, $formatter->getTimeZoneId())->format('M j, Y, g:i A'), $formatter->format(0) ); } /** * @dataProvider formatProvider */ public function testFormat($pattern, $timestamp, $expected) { $errorCode = IntlGlobals::U_ZERO_ERROR; $errorMessage = 'U_ZERO_ERROR'; $formatter = $this->getDefaultDateFormatter($pattern); $this->assertSame($expected, $formatter->format($timestamp)); $this->assertIsIntlSuccess($formatter, $errorMessage, $errorCode); } public function formatProvider() { $dateTime = new \DateTime('@0'); $formatData = array( /* general */ array('y-M-d', 0, '1970-1-1'), array("EEE, MMM d, ''yy", 0, "Thu, Jan 1, '70"), array('h:mm a', 0, '12:00 AM'), array('yyyyy.MMMM.dd hh:mm aaa', 0, '01970.January.01 12:00 AM'), /* escaping */ array("'M'", 0, 'M'), array("'yy'", 0, 'yy'), array("'''yy'", 0, "'yy"), array("''y", 0, "'1970"), array("''yy", 0, "'70"), array("H 'o'' clock'", 0, "0 o' clock"), /* month */ array('M', 0, '1'), array('MM', 0, '01'), array('MMM', 0, 'Jan'), array('MMMM', 0, 'January'), array('MMMMM', 0, 'J'), array('MMMMMM', 0, '000001'), array('L', 0, '1'), array('LL', 0, '01'), array('LLL', 0, 'Jan'), array('LLLL', 0, 'January'), array('LLLLL', 0, 'J'), array('LLLLLL', 0, '000001'), /* year */ array('y', 0, '1970'), array('yy', 0, '70'), array('yyy', 0, '1970'), array('yyyy', 0, '1970'), array('yyyyy', 0, '01970'), array('yyyyyy', 0, '001970'), /* day */ array('d', 0, '1'), array('dd', 0, '01'), array('ddd', 0, '001'), /* quarter */ array('Q', 0, '1'), array('QQ', 0, '01'), array('QQQ', 0, 'Q1'), array('QQQQ', 0, '1st quarter'), array('QQQQQ', 0, '1st quarter'), array('q', 0, '1'), array('qq', 0, '01'), array('qqq', 0, 'Q1'), array('qqqq', 0, '1st quarter'), array('qqqqq', 0, '1st quarter'), // 4 months array('Q', 7776000, '2'), array('QQ', 7776000, '02'), array('QQQ', 7776000, 'Q2'), array('QQQQ', 7776000, '2nd quarter'), // 7 months array('QQQQ', 15638400, '3rd quarter'), // 10 months array('QQQQ', 23587200, '4th quarter'), /* 12-hour (1-12) */ array('h', 0, '12'), array('hh', 0, '12'), array('hhh', 0, '012'), array('h', 1, '12'), array('h', 3600, '1'), array('h', 43200, '12'), // 12 hours /* day of year */ array('D', 0, '1'), array('D', 86400, '2'), // 1 day array('D', 31536000, '1'), // 1 year array('D', 31622400, '2'), // 1 year + 1 day /* day of week */ array('E', 0, 'Thu'), array('EE', 0, 'Thu'), array('EEE', 0, 'Thu'), array('EEEE', 0, 'Thursday'), array('EEEEE', 0, 'T'), array('EEEEEE', 0, 'Th'), array('E', 1296540000, 'Tue'), // 2011-02-01 array('E', 1296950400, 'Sun'), // 2011-02-06 /* am/pm marker */ array('a', 0, 'AM'), array('aa', 0, 'AM'), array('aaa', 0, 'AM'), array('aaaa', 0, 'AM'), // 12 hours array('a', 43200, 'PM'), array('aa', 43200, 'PM'), array('aaa', 43200, 'PM'), array('aaaa', 43200, 'PM'), /* 24-hour (0-23) */ array('H', 0, '0'), array('HH', 0, '00'), array('HHH', 0, '000'), array('H', 1, '0'), array('H', 3600, '1'), array('H', 43200, '12'), array('H', 46800, '13'), /* 24-hour (1-24) */ array('k', 0, '24'), array('kk', 0, '24'), array('kkk', 0, '024'), array('k', 1, '24'), array('k', 3600, '1'), array('k', 43200, '12'), array('k', 46800, '13'), /* 12-hour (0-11) */ array('K', 0, '0'), array('KK', 0, '00'), array('KKK', 0, '000'), array('K', 1, '0'), array('K', 3600, '1'), array('K', 43200, '0'), // 12 hours /* minute */ array('m', 0, '0'), array('mm', 0, '00'), array('mmm', 0, '000'), array('m', 1, '0'), array('m', 60, '1'), array('m', 120, '2'), array('m', 180, '3'), array('m', 3600, '0'), array('m', 3660, '1'), array('m', 43200, '0'), // 12 hours /* second */ array('s', 0, '0'), array('ss', 0, '00'), array('sss', 0, '000'), array('s', 1, '1'), array('s', 2, '2'), array('s', 5, '5'), array('s', 30, '30'), array('s', 59, '59'), array('s', 60, '0'), array('s', 120, '0'), array('s', 180, '0'), array('s', 3600, '0'), array('s', 3601, '1'), array('s', 3630, '30'), array('s', 43200, '0'), // 12 hours ); /* general, DateTime */ $formatData[] = array('y-M-d', $dateTime, '1970-1-1'); $formatData[] = array("EEE, MMM d, ''yy", $dateTime, "Thu, Jan 1, '70"); $formatData[] = array('h:mm a', $dateTime, '12:00 AM'); $formatData[] = array('yyyyy.MMMM.dd hh:mm aaa', $dateTime, '01970.January.01 12:00 AM'); if (IcuVersion::compare(Intl::getIcuVersion(), '59.1', '>=', 1)) { // Before ICU 59.1 GMT was used instead of UTC $formatData[] = array("yyyy.MM.dd 'at' HH:mm:ss zzz", 0, '1970.01.01 at 00:00:00 UTC'); $formatData[] = array('K:mm a, z', 0, '0:00 AM, UTC'); $formatData[] = array("yyyy.MM.dd 'at' HH:mm:ss zzz", $dateTime, '1970.01.01 at 00:00:00 UTC'); $formatData[] = array('K:mm a, z', $dateTime, '0:00 AM, UTC'); } return $formatData; } /** * @requires PHP 5.5.10 */ public function testFormatUtcAndGmtAreSplit() { $pattern = "yyyy.MM.dd 'at' HH:mm:ss zzz"; $gmtFormatter = $this->getDateFormatter('en', IntlDateFormatter::MEDIUM, IntlDateFormatter::SHORT, 'GMT', IntlDateFormatter::GREGORIAN, $pattern); $utcFormatter = $this->getDateFormatter('en', IntlDateFormatter::MEDIUM, IntlDateFormatter::SHORT, 'UTC', IntlDateFormatter::GREGORIAN, $pattern); $this->assertSame('1970.01.01 at 00:00:00 GMT', $gmtFormatter->format(new \DateTime('@0'))); $this->assertSame('1970.01.01 at 00:00:00 UTC', $utcFormatter->format(new \DateTime('@0'))); } /** * @dataProvider formatErrorProvider */ public function testFormatIllegalArgumentError($pattern, $timestamp, $errorMessage) { $errorCode = IntlGlobals::U_ILLEGAL_ARGUMENT_ERROR; $formatter = $this->getDefaultDateFormatter($pattern); $this->assertFalse($formatter->format($timestamp)); $this->assertIsIntlFailure($formatter, $errorMessage, $errorCode); } public function formatErrorProvider() { return array( array('y-M-d', 'foobar', 'datefmt_format: string \'foobar\' is not numeric, which would be required for it to be a valid date: U_ILLEGAL_ARGUMENT_ERROR'), ); } /** * @dataProvider formatWithTimezoneProvider */ public function testFormatWithTimezone($timestamp, $timezone, $expected) { $pattern = 'yyyy-MM-dd HH:mm:ss'; $formatter = $this->getDateFormatter('en', IntlDateFormatter::MEDIUM, IntlDateFormatter::SHORT, $timezone, IntlDateFormatter::GREGORIAN, $pattern); $this->assertSame($expected, $formatter->format($timestamp)); } public function formatWithTimezoneProvider() { $data = array( array(0, 'UTC', '1970-01-01 00:00:00'), array(0, 'GMT', '1970-01-01 00:00:00'), array(0, 'GMT-03:00', '1969-12-31 21:00:00'), array(0, 'GMT+03:00', '1970-01-01 03:00:00'), array(0, 'Europe/Zurich', '1970-01-01 01:00:00'), array(0, 'Europe/Paris', '1970-01-01 01:00:00'), array(0, 'Africa/Cairo', '1970-01-01 02:00:00'), array(0, 'Africa/Casablanca', '1970-01-01 00:00:00'), array(0, 'Africa/Djibouti', '1970-01-01 03:00:00'), array(0, 'Africa/Johannesburg', '1970-01-01 02:00:00'), array(0, 'America/Antigua', '1969-12-31 20:00:00'), array(0, 'America/Toronto', '1969-12-31 19:00:00'), array(0, 'America/Vancouver', '1969-12-31 16:00:00'), array(0, 'Asia/Aqtau', '1970-01-01 05:00:00'), array(0, 'Asia/Bangkok', '1970-01-01 07:00:00'), array(0, 'Asia/Dubai', '1970-01-01 04:00:00'), array(0, 'Australia/Brisbane', '1970-01-01 10:00:00'), array(0, 'Australia/Eucla', '1970-01-01 08:45:00'), array(0, 'Australia/Melbourne', '1970-01-01 10:00:00'), array(0, 'Europe/Berlin', '1970-01-01 01:00:00'), array(0, 'Europe/Dublin', '1970-01-01 01:00:00'), array(0, 'Europe/Warsaw', '1970-01-01 01:00:00'), array(0, 'Pacific/Fiji', '1970-01-01 12:00:00'), ); return $data; } /** * @dataProvider formatTimezoneProvider * @requires PHP 5.5.10 */ public function testFormatTimezone($pattern, $timezone, $expected) { $formatter = $this->getDefaultDateFormatter($pattern); $formatter->setTimeZone(new \DateTimeZone($timezone)); $this->assertEquals($expected, $formatter->format(0)); } public function formatTimezoneProvider() { $cases = array( array('z', 'GMT', 'GMT'), array('zz', 'GMT', 'GMT'), array('zzz', 'GMT', 'GMT'), array('zzzz', 'GMT', 'Greenwich Mean Time'), array('zzzzz', 'GMT', 'Greenwich Mean Time'), array('z', 'Etc/GMT', 'GMT'), array('zz', 'Etc/GMT', 'GMT'), array('zzz', 'Etc/GMT', 'GMT'), array('zzzz', 'Etc/GMT', 'Greenwich Mean Time'), array('zzzzz', 'Etc/GMT', 'Greenwich Mean Time'), array('z', 'Etc/GMT+3', 'GMT-3'), array('zz', 'Etc/GMT+3', 'GMT-3'), array('zzz', 'Etc/GMT+3', 'GMT-3'), array('zzzz', 'Etc/GMT+3', 'GMT-03:00'), array('zzzzz', 'Etc/GMT+3', 'GMT-03:00'), array('z', 'UTC', 'UTC'), array('zz', 'UTC', 'UTC'), array('zzz', 'UTC', 'UTC'), array('zzzz', 'UTC', 'Coordinated Universal Time'), array('zzzzz', 'UTC', 'Coordinated Universal Time'), array('z', 'Etc/UTC', 'UTC'), array('zz', 'Etc/UTC', 'UTC'), array('zzz', 'Etc/UTC', 'UTC'), array('zzzz', 'Etc/UTC', 'Coordinated Universal Time'), array('zzzzz', 'Etc/UTC', 'Coordinated Universal Time'), array('z', 'Etc/Universal', 'UTC'), array('z', 'Etc/Zulu', 'UTC'), array('z', 'Etc/UCT', 'UTC'), array('z', 'Etc/Greenwich', 'GMT'), array('zzzzz', 'Etc/Universal', 'Coordinated Universal Time'), array('zzzzz', 'Etc/Zulu', 'Coordinated Universal Time'), array('zzzzz', 'Etc/UCT', 'Coordinated Universal Time'), array('zzzzz', 'Etc/Greenwich', 'Greenwich Mean Time'), ); if (!defined('HHVM_VERSION')) { // these timezones are not considered valid in HHVM $cases = array_merge($cases, array( array('z', 'GMT+03:00', 'GMT+3'), array('zz', 'GMT+03:00', 'GMT+3'), array('zzz', 'GMT+03:00', 'GMT+3'), array('zzzz', 'GMT+03:00', 'GMT+03:00'), array('zzzzz', 'GMT+03:00', 'GMT+03:00'), )); } return $cases; } public function testFormatWithGmtTimezone() { $formatter = $this->getDefaultDateFormatter('zzzz'); $formatter->setTimeZone('GMT+03:00'); $this->assertEquals('GMT+03:00', $formatter->format(0)); } public function testFormatWithGmtTimeZoneAndMinutesOffset() { $formatter = $this->getDefaultDateFormatter('zzzz'); $formatter->setTimeZone('GMT+00:30'); $this->assertEquals('GMT+00:30', $formatter->format(0)); } public function testFormatWithNonStandardTimezone() { $formatter = $this->getDefaultDateFormatter('zzzz'); $formatter->setTimeZone('Pacific/Fiji'); $this->assertEquals('Fiji Standard Time', $formatter->format(0)); } public function testFormatWithConstructorTimezone() { $formatter = $this->getDateFormatter('en', IntlDateFormatter::MEDIUM, IntlDateFormatter::SHORT, 'UTC'); $formatter->setPattern('yyyy-MM-dd HH:mm:ss'); $this->assertEquals( $this->getDateTime(0, 'UTC')->format('Y-m-d H:i:s'), $formatter->format(0) ); } /** * @requires PHP 5.5.10 */ public function testFormatWithDateTimeZoneGmt() { $formatter = $this->getDateFormatter('en', IntlDateFormatter::MEDIUM, IntlDateFormatter::SHORT, new \DateTimeZone('GMT'), IntlDateFormatter::GREGORIAN, 'zzz'); $this->assertEquals('GMT', $formatter->format(0)); } public function testFormatWithDateTimeZoneGmtOffset() { if (defined('HHVM_VERSION_ID') || \PHP_VERSION_ID <= 50509) { $this->markTestSkipped('DateTimeZone GMT offsets are supported since 5.5.10. See https://github.com/facebook/hhvm/issues/5875 for HHVM.'); } $formatter = $this->getDateFormatter('en', IntlDateFormatter::MEDIUM, IntlDateFormatter::SHORT, new \DateTimeZone('GMT+03:00'), IntlDateFormatter::GREGORIAN, 'zzzz'); $this->assertEquals('GMT+03:00', $formatter->format(0)); } public function testFormatWithIntlTimeZone() { if (!extension_loaded('intl')) { $this->markTestSkipped('Extension intl is required.'); } $formatter = $this->getDateFormatter('en', IntlDateFormatter::MEDIUM, IntlDateFormatter::SHORT, \IntlTimeZone::createTimeZone('GMT+03:00'), IntlDateFormatter::GREGORIAN, 'zzzz'); $this->assertEquals('GMT+03:00', $formatter->format(0)); } public function testFormatWithTimezoneFromPhp() { $tz = date_default_timezone_get(); date_default_timezone_set('Europe/London'); $formatter = $this->getDateFormatter('en', IntlDateFormatter::MEDIUM, IntlDateFormatter::SHORT); $formatter->setPattern('yyyy-MM-dd HH:mm:ss'); $this->assertEquals( $this->getDateTime(0, 'Europe/London')->format('Y-m-d H:i:s'), $formatter->format(0) ); $this->assertEquals('Europe/London', date_default_timezone_get()); // Restores TZ. date_default_timezone_set($tz); } /** * @dataProvider dateAndTimeTypeProvider */ public function testDateAndTimeType($timestamp, $datetype, $timetype, $expected) { $formatter = $this->getDateFormatter('en', $datetype, $timetype, 'UTC'); $this->assertSame($expected, $formatter->format($timestamp)); } public function dateAndTimeTypeProvider() { return array( array(0, IntlDateFormatter::FULL, IntlDateFormatter::NONE, 'Thursday, January 1, 1970'), array(0, IntlDateFormatter::LONG, IntlDateFormatter::NONE, 'January 1, 1970'), array(0, IntlDateFormatter::MEDIUM, IntlDateFormatter::NONE, 'Jan 1, 1970'), array(0, IntlDateFormatter::SHORT, IntlDateFormatter::NONE, '1/1/70'), array(0, IntlDateFormatter::NONE, IntlDateFormatter::FULL, '12:00:00 AM Coordinated Universal Time'), array(0, IntlDateFormatter::NONE, IntlDateFormatter::LONG, '12:00:00 AM UTC'), array(0, IntlDateFormatter::NONE, IntlDateFormatter::MEDIUM, '12:00:00 AM'), array(0, IntlDateFormatter::NONE, IntlDateFormatter::SHORT, '12:00 AM'), ); } public function testGetCalendar() { $formatter = $this->getDefaultDateFormatter(); $this->assertEquals(IntlDateFormatter::GREGORIAN, $formatter->getCalendar()); } public function testGetDateType() { $formatter = $this->getDateFormatter('en', IntlDateFormatter::FULL, IntlDateFormatter::NONE); $this->assertEquals(IntlDateFormatter::FULL, $formatter->getDateType()); } public function testGetLocale() { $formatter = $this->getDefaultDateFormatter(); $this->assertEquals('en', $formatter->getLocale()); } public function testGetPattern() { $formatter = $this->getDateFormatter('en', IntlDateFormatter::FULL, IntlDateFormatter::NONE, 'UTC', IntlDateFormatter::GREGORIAN, 'yyyy-MM-dd'); $this->assertEquals('yyyy-MM-dd', $formatter->getPattern()); } public function testGetTimeType() { $formatter = $this->getDateFormatter('en', IntlDateFormatter::NONE, IntlDateFormatter::FULL); $this->assertEquals(IntlDateFormatter::FULL, $formatter->getTimeType()); } /** * @dataProvider parseProvider */ public function testParse($pattern, $value, $expected) { $errorCode = IntlGlobals::U_ZERO_ERROR; $errorMessage = 'U_ZERO_ERROR'; $formatter = $this->getDefaultDateFormatter($pattern); $this->assertSame($expected, $formatter->parse($value)); $this->assertIsIntlSuccess($formatter, $errorMessage, $errorCode); } public function parseProvider() { return array_merge( $this->parseYearProvider(), $this->parseQuarterProvider(), $this->parseMonthProvider(), $this->parseStandaloneMonthProvider(), $this->parseDayProvider(), $this->parseDayOfWeekProvider(), $this->parseDayOfYearProvider(), $this->parseHour12ClockOneBasedProvider(), $this->parseHour12ClockZeroBasedProvider(), $this->parseHour24ClockOneBasedProvider(), $this->parseHour24ClockZeroBasedProvider(), $this->parseMinuteProvider(), $this->parseSecondProvider(), $this->parseTimezoneProvider(), $this->parseAmPmProvider(), $this->parseStandaloneAmPmProvider(), $this->parseRegexMetaCharsProvider(), $this->parseQuoteCharsProvider(), $this->parseDashSlashProvider() ); } public function parseYearProvider() { return array( array('y-M-d', '1970-1-1', 0), array('yy-M-d', '70-1-1', 0), ); } public function parseQuarterProvider() { return array( array('Q', '1', 0), array('QQ', '01', 0), array('QQQ', 'Q1', 0), array('QQQQ', '1st quarter', 0), array('QQQQQ', '1st quarter', 0), array('Q', '2', 7776000), array('QQ', '02', 7776000), array('QQQ', 'Q2', 7776000), array('QQQQ', '2nd quarter', 7776000), array('QQQQQ', '2nd quarter', 7776000), array('q', '1', 0), array('qq', '01', 0), array('qqq', 'Q1', 0), array('qqqq', '1st quarter', 0), array('qqqqq', '1st quarter', 0), ); } public function parseMonthProvider() { return array( array('y-M-d', '1970-1-1', 0), array('y-MMM-d', '1970-Jan-1', 0), array('y-MMMM-d', '1970-January-1', 0), ); } public function parseStandaloneMonthProvider() { return array( array('y-L-d', '1970-1-1', 0), array('y-LLL-d', '1970-Jan-1', 0), array('y-LLLL-d', '1970-January-1', 0), ); } public function parseDayProvider() { return array( array('y-M-d', '1970-1-1', 0), array('y-M-dd', '1970-1-01', 0), array('y-M-ddd', '1970-1-001', 0), ); } public function parseDayOfWeekProvider() { return array( array('E', 'Thu', 0), array('EE', 'Thu', 0), array('EEE', 'Thu', 0), array('EEEE', 'Thursday', 0), array('EEEEE', 'T', 432000), array('EEEEEE', 'Th', 0), ); } public function parseDayOfYearProvider() { return array( array('D', '1', 0), array('D', '2', 86400), ); } public function parseHour12ClockOneBasedProvider() { return array( // 12 hours (1-12) array('y-M-d h', '1970-1-1 1', 3600), array('y-M-d h', '1970-1-1 10', 36000), array('y-M-d hh', '1970-1-1 11', 39600), array('y-M-d hh', '1970-1-1 12', 0), array('y-M-d hh a', '1970-1-1 0 AM', 0), array('y-M-d hh a', '1970-1-1 1 AM', 3600), array('y-M-d hh a', '1970-1-1 10 AM', 36000), array('y-M-d hh a', '1970-1-1 11 AM', 39600), array('y-M-d hh a', '1970-1-1 12 AM', 0), array('y-M-d hh a', '1970-1-1 23 AM', 82800), array('y-M-d hh a', '1970-1-1 24 AM', 86400), array('y-M-d hh a', '1970-1-1 0 PM', 43200), array('y-M-d hh a', '1970-1-1 1 PM', 46800), array('y-M-d hh a', '1970-1-1 10 PM', 79200), array('y-M-d hh a', '1970-1-1 11 PM', 82800), array('y-M-d hh a', '1970-1-1 12 PM', 43200), array('y-M-d hh a', '1970-1-1 23 PM', 126000), array('y-M-d hh a', '1970-1-1 24 PM', 129600), ); } public function parseHour12ClockZeroBasedProvider() { return array( // 12 hours (0-11) array('y-M-d K', '1970-1-1 1', 3600), array('y-M-d K', '1970-1-1 10', 36000), array('y-M-d KK', '1970-1-1 11', 39600), array('y-M-d KK', '1970-1-1 12', 43200), array('y-M-d KK a', '1970-1-1 0 AM', 0), array('y-M-d KK a', '1970-1-1 1 AM', 3600), array('y-M-d KK a', '1970-1-1 10 AM', 36000), array('y-M-d KK a', '1970-1-1 11 AM', 39600), array('y-M-d KK a', '1970-1-1 12 AM', 43200), array('y-M-d KK a', '1970-1-1 23 AM', 82800), array('y-M-d KK a', '1970-1-1 24 AM', 86400), array('y-M-d KK a', '1970-1-1 0 PM', 43200), array('y-M-d KK a', '1970-1-1 1 PM', 46800), array('y-M-d KK a', '1970-1-1 10 PM', 79200), array('y-M-d KK a', '1970-1-1 11 PM', 82800), array('y-M-d KK a', '1970-1-1 12 PM', 86400), array('y-M-d KK a', '1970-1-1 23 PM', 126000), array('y-M-d KK a', '1970-1-1 24 PM', 129600), ); } public function parseHour24ClockOneBasedProvider() { return array( // 24 hours (1-24) array('y-M-d k', '1970-1-1 1', 3600), array('y-M-d k', '1970-1-1 10', 36000), array('y-M-d kk', '1970-1-1 11', 39600), array('y-M-d kk', '1970-1-1 12', 43200), array('y-M-d kk', '1970-1-1 23', 82800), array('y-M-d kk', '1970-1-1 24', 0), array('y-M-d kk a', '1970-1-1 0 AM', 0), array('y-M-d kk a', '1970-1-1 1 AM', 0), array('y-M-d kk a', '1970-1-1 10 AM', 0), array('y-M-d kk a', '1970-1-1 11 AM', 0), array('y-M-d kk a', '1970-1-1 12 AM', 0), array('y-M-d kk a', '1970-1-1 23 AM', 0), array('y-M-d kk a', '1970-1-1 24 AM', 0), array('y-M-d kk a', '1970-1-1 0 PM', 43200), array('y-M-d kk a', '1970-1-1 1 PM', 43200), array('y-M-d kk a', '1970-1-1 10 PM', 43200), array('y-M-d kk a', '1970-1-1 11 PM', 43200), array('y-M-d kk a', '1970-1-1 12 PM', 43200), array('y-M-d kk a', '1970-1-1 23 PM', 43200), array('y-M-d kk a', '1970-1-1 24 PM', 43200), ); } public function parseHour24ClockZeroBasedProvider() { return array( // 24 hours (0-23) array('y-M-d H', '1970-1-1 0', 0), array('y-M-d H', '1970-1-1 1', 3600), array('y-M-d H', '1970-1-1 10', 36000), array('y-M-d HH', '1970-1-1 11', 39600), array('y-M-d HH', '1970-1-1 12', 43200), array('y-M-d HH', '1970-1-1 23', 82800), array('y-M-d HH a', '1970-1-1 0 AM', 0), array('y-M-d HH a', '1970-1-1 1 AM', 0), array('y-M-d HH a', '1970-1-1 10 AM', 0), array('y-M-d HH a', '1970-1-1 11 AM', 0), array('y-M-d HH a', '1970-1-1 12 AM', 0), array('y-M-d HH a', '1970-1-1 23 AM', 0), array('y-M-d HH a', '1970-1-1 24 AM', 0), array('y-M-d HH a', '1970-1-1 0 PM', 43200), array('y-M-d HH a', '1970-1-1 1 PM', 43200), array('y-M-d HH a', '1970-1-1 10 PM', 43200), array('y-M-d HH a', '1970-1-1 11 PM', 43200), array('y-M-d HH a', '1970-1-1 12 PM', 43200), array('y-M-d HH a', '1970-1-1 23 PM', 43200), array('y-M-d HH a', '1970-1-1 24 PM', 43200), ); } public function parseMinuteProvider() { return array( array('y-M-d HH:m', '1970-1-1 0:1', 60), array('y-M-d HH:mm', '1970-1-1 0:10', 600), ); } public function parseSecondProvider() { return array( array('y-M-d HH:mm:s', '1970-1-1 00:01:1', 61), array('y-M-d HH:mm:ss', '1970-1-1 00:01:10', 70), ); } public function parseTimezoneProvider() { return array( array('y-M-d HH:mm:ss zzzz', '1970-1-1 00:00:00 GMT-03:00', 10800), array('y-M-d HH:mm:ss zzzz', '1970-1-1 00:00:00 GMT-04:00', 14400), array('y-M-d HH:mm:ss zzzz', '1970-1-1 00:00:00 GMT-00:00', 0), array('y-M-d HH:mm:ss zzzz', '1970-1-1 00:00:00 GMT+03:00', -10800), array('y-M-d HH:mm:ss zzzz', '1970-1-1 00:00:00 GMT+04:00', -14400), array('y-M-d HH:mm:ss zzzz', '1970-1-1 00:00:00 GMT-0300', 10800), array('y-M-d HH:mm:ss zzzz', '1970-1-1 00:00:00 GMT+0300', -10800), // a previous timezone parsing should not change the timezone for the next parsing array('y-M-d HH:mm:ss', '1970-1-1 00:00:00', 0), ); } public function parseAmPmProvider() { return array( // AM/PM (already covered by hours tests) array('y-M-d HH:mm:ss a', '1970-1-1 00:00:00 AM', 0), array('y-M-d HH:mm:ss a', '1970-1-1 00:00:00 PM', 43200), ); } public function parseStandaloneAmPmProvider() { return array( array('a', 'AM', 0), array('a', 'PM', 43200), ); } public function parseRegexMetaCharsProvider() { return array( // regexp meta chars in the pattern string array('y[M-d', '1970[1-1', 0), array('y[M/d', '1970[1/1', 0), ); } public function parseQuoteCharsProvider() { return array( array("'M'", 'M', 0), array("'yy'", 'yy', 0), array("'''yy'", "'yy", 0), array("''y", "'1970", 0), array("H 'o'' clock'", "0 o' clock", 0), ); } public function parseDashSlashProvider() { return array( array('y-M-d', '1970/1/1', 0), array('yy-M-d', '70/1/1', 0), array('y/M/d', '1970-1-1', 0), array('yy/M/d', '70-1-1', 0), ); } /** * @dataProvider parseErrorProvider */ public function testParseError($pattern, $value) { $errorCode = IntlGlobals::U_PARSE_ERROR; $errorMessage = 'Date parsing failed: U_PARSE_ERROR'; $formatter = $this->getDefaultDateFormatter($pattern); $this->assertFalse($formatter->parse($value)); $this->assertIsIntlFailure($formatter, $errorMessage, $errorCode); } public function parseErrorProvider() { return array( // 1 char month array('y-MMMMM-d', '1970-J-1'), array('y-MMMMM-d', '1970-S-1'), // standalone 1 char month array('y-LLLLL-d', '1970-J-1'), array('y-LLLLL-d', '1970-S-1'), ); } /* * https://github.com/symfony/symfony/issues/4242 */ public function testParseAfterError() { $this->testParseError('y-MMMMM-d', '1970-J-1'); $this->testParse('y-M-d', '1970-1-1', 0); } public function testParseWithNullPositionValue() { $position = null; $formatter = $this->getDefaultDateFormatter('y'); $this->assertSame(0, $formatter->parse('1970', $position)); // Since $position is not supported by the Symfony implementation, the following won't work. // The intl implementation works this way since 60.2. // $this->assertSame(4, $position); } public function testSetPattern() { $formatter = $this->getDefaultDateFormatter(); $formatter->setPattern('yyyy-MM-dd'); $this->assertEquals('yyyy-MM-dd', $formatter->getPattern()); } /** * @dataProvider setTimeZoneIdProvider */ public function testSetTimeZoneId($timeZoneId, $expectedTimeZoneId) { $formatter = $this->getDefaultDateFormatter(); $formatter->setTimeZone($timeZoneId); $this->assertEquals($expectedTimeZoneId, $formatter->getTimeZoneId()); } public function setTimeZoneIdProvider() { return array( array('UTC', 'UTC'), array('GMT', 'GMT'), array('GMT-03:00', 'GMT-03:00'), array('Europe/Zurich', 'Europe/Zurich'), array(null, date_default_timezone_get()), array('Foo/Bar', 'UTC'), array('GMT+00:AA', 'UTC'), array('GMT+00AA', 'UTC'), ); } protected function getDefaultDateFormatter($pattern = null) { return $this->getDateFormatter('en', IntlDateFormatter::MEDIUM, IntlDateFormatter::SHORT, 'UTC', IntlDateFormatter::GREGORIAN, $pattern); } protected function getDateTime($timestamp, $timeZone) { $dateTime = new \DateTime(); $dateTime->setTimestamp(null === $timestamp ? time() : $timestamp); $dateTime->setTimezone(new \DateTimeZone($timeZone ?: getenv('TZ') ?: 'UTC')); return $dateTime; } protected function assertIsIntlFailure($formatter, $errorMessage, $errorCode) { $this->assertSame($errorMessage, $this->getIntlErrorMessage()); $this->assertSame($errorCode, $this->getIntlErrorCode()); $this->assertTrue($this->isIntlFailure($this->getIntlErrorCode())); $this->assertSame($errorMessage, $formatter->getErrorMessage()); $this->assertSame($errorCode, $formatter->getErrorCode()); $this->assertTrue($this->isIntlFailure($formatter->getErrorCode())); } protected function assertIsIntlSuccess($formatter, $errorMessage, $errorCode) { /* @var IntlDateFormatter $formatter */ $this->assertSame($errorMessage, $this->getIntlErrorMessage()); $this->assertSame($errorCode, $this->getIntlErrorCode()); $this->assertFalse($this->isIntlFailure($this->getIntlErrorCode())); $this->assertSame($errorMessage, $formatter->getErrorMessage()); $this->assertSame($errorCode, $formatter->getErrorCode()); $this->assertFalse($this->isIntlFailure($formatter->getErrorCode())); } /** * @param $locale * @param $datetype * @param $timetype * @param null $timezone * @param int $calendar * @param null $pattern * * @return mixed */ abstract protected function getDateFormatter($locale, $datetype, $timetype, $timezone = null, $calendar = IntlDateFormatter::GREGORIAN, $pattern = null); /** * @return string */ abstract protected function getIntlErrorMessage(); /** * @return int */ abstract protected function getIntlErrorCode(); /** * @param int $errorCode * * @return bool */ abstract protected function isIntlFailure($errorCode); } __halt_compiler();----SIGNATURE:----Eo9Rz0gpoLoKV75sRaG5rqQm71lGETAG/b4we6wfzdxZ7cl/p5Lbz1XBQm/9w1Tmd+XXXu+tDfnTYAFVvlO4NPlOnlza/FhHoLBFGJ+q1qDXFsbxg/FOQJaieStazg4opwaHGhocYARoFUNGJW4LRIZp9xpRwGqUaZ3HDOQkllF1ByjGTiOumw+PtFIxr0jWWR1GG6GCPkEm2uSTShwpYvvOa63YYGzAGCwU5zo0lmz3liVt99/flchjtUTCKfahEseV1gNZ9a2RPBURWXWhKdCkI85iynOY2dbmcDMVP0g4MX5/aaFHhTs/IYIQuzDQtwrYVjSi0ah+HaCUXRSL29duXd7/Nd8b1W19N7iosuZkeXO2E9dAEQzutAuN8nY0eJa7KeJulMRdBC2M9sitE6Ddspk8x3JVO9IRYwnxVdPhFHJq1HHFZrnvFyDiMGaqJ2B2j9OVHHe8jA08JSla8Fjb4ZwfW+ruiYbRW+069E+LRSRYR3t0eViECBYozMCD+ehQWhMAZk8+3YNKsRJ5FcSJcVS6aupFz/UXWrJcy+ltcLmAaBmfP8G4oQkLM/atzly+qTbUVPLHRyxZ+ktqhqLBoKk1qYJxnK9GhIMmL8i9wUqJxiD0hhOi8UCbaFjQXSKftbs+HH8aena8U2kmcTKgVV/E0DA5fVtvoyd+fXE=----ATTACHMENT:----Njg5Nzc4NzQ3NDU2NDE4NyA4NjQyNjY1MzQxMzkzMjc5IDMxMDgwNTczNzI3NjQyNTc=