| Index: source/test/cintltst/cdateintervalformattest.c
|
| diff --git a/source/test/cintltst/cdateintervalformattest.c b/source/test/cintltst/cdateintervalformattest.c
|
| index ee63793f175f47fa00198fd950f6a1b06140e5c1..905c62bdf866a72047b409b6cdc65694badd093b 100644
|
| --- a/source/test/cintltst/cdateintervalformattest.c
|
| +++ b/source/test/cintltst/cdateintervalformattest.c
|
| @@ -1,5 +1,5 @@
|
| /********************************************************************
|
| - * Copyright (c) 2011-2014, International Business Machines Corporation
|
| + * Copyright (c) 2011-2015, International Business Machines Corporation
|
| * and others. All Rights Reserved.
|
| ********************************************************************/
|
| /* C API TEST FOR DATE INTERVAL FORMAT */
|
| @@ -16,6 +16,7 @@
|
| #include "cmemory.h"
|
|
|
| static void TestDateIntervalFormat(void);
|
| +static void TestFPos_SkelWithSeconds(void);
|
|
|
| #define LEN(a) (sizeof(a)/sizeof(a[0]))
|
|
|
| @@ -26,6 +27,7 @@ void addDateIntervalFormatTest(TestNode** root);
|
| void addDateIntervalFormatTest(TestNode** root)
|
| {
|
| TESTCASE(TestDateIntervalFormat);
|
| + TESTCASE(TestFPos_SkelWithSeconds);
|
| }
|
|
|
| static const char tzUSPacific[] = "US/Pacific";
|
| @@ -52,8 +54,8 @@ static const DateIntervalFormatTestItem testItems[] = {
|
| { "en", "yMMMEd", tzUSPacific, Date201009270800, Date201009270800 + 12.0*_HOUR, "Mon, Sep 27, 2010" },
|
| { "en", "yMMMEd", tzUSPacific, Date201009270800, Date201009270800 + 31.0*_DAY, "Mon, Sep 27 \\u2013 Thu, Oct 28, 2010" },
|
| { "en", "yMMMEd", tzUSPacific, Date201009270800, Date201009270800 + 410.0*_DAY, "Mon, Sep 27, 2010 \\u2013 Fri, Nov 11, 2011" },
|
| - { "de", "Hm", tzUSPacific, Date201009270800, Date201009270800 + 12.0*_HOUR, "08:00-20:00" },
|
| - { "de", "Hm", tzUSPacific, Date201009270800, Date201009270800 + 31.0*_DAY, "27.9.2010, 08:00 - 28.10.2010, 08:00" },
|
| + { "de", "Hm", tzUSPacific, Date201009270800, Date201009270800 + 12.0*_HOUR, "08:00\\u201320:00 Uhr" },
|
| + { "de", "Hm", tzUSPacific, Date201009270800, Date201009270800 + 31.0*_DAY, "27.9.2010, 08:00 \\u2013 28.10.2010, 08:00" },
|
| { "ja", "MMMd", tzUSPacific, Date201009270800, Date201009270800 + 1.0*_DAY, "9\\u670827\\u65E5\\uFF5E28\\u65E5" },
|
| { NULL, NULL, NULL, 0, 0, NULL }
|
| };
|
| @@ -114,4 +116,205 @@ static void TestDateIntervalFormat()
|
| ctest_resetTimeZone();
|
| }
|
|
|
| +/********************************************************************
|
| + * TestFPos_SkelWithSeconds and related data
|
| + ********************************************************************
|
| + */
|
| +
|
| +static UChar zoneGMT[] = { 0x47,0x4D,0x54,0 }; // GMT
|
| +static const UDate startTime = 1416474000000.0; // 2014 Nov 20 09:00 GMT
|
| +
|
| +static const double deltas[] = {
|
| + 0.0, // none
|
| + 200.0, // 200 millisec
|
| + 20000.0, // 20 sec
|
| + 1200000.0, // 20 min
|
| + 7200000.0, // 2 hrs
|
| + 43200000.0, // 12 hrs
|
| + 691200000.0, // 8 days
|
| + 1382400000.0, // 16 days,
|
| + 8640000000.0, // 100 days
|
| + -1.0
|
| +};
|
| +enum { kNumDeltas = sizeof(deltas)/sizeof(deltas[0]) - 1 };
|
| +
|
| +typedef struct {
|
| + int32_t posBegin;
|
| + int32_t posEnd;
|
| + const char * format;
|
| +} ExpectPosAndFormat;
|
| +
|
| +static const ExpectPosAndFormat exp_en_HHmm[kNumDeltas] = {
|
| + { 3, 5, "09:00" },
|
| + { 3, 5, "09:00" },
|
| + { 3, 5, "09:00" },
|
| + { 3, 5, "09:00 \\u2013 09:20" },
|
| + { 3, 5, "09:00 \\u2013 11:00" },
|
| + { 3, 5, "09:00 \\u2013 21:00" },
|
| + { 15, 17, "11/20/2014, 09:00 \\u2013 11/28/2014, 09:00" },
|
| + { 15, 17, "11/20/2014, 09:00 \\u2013 12/6/2014, 09:00" },
|
| + { 15, 17, "11/20/2014, 09:00 \\u2013 2/28/2015, 09:00" }
|
| +};
|
| +
|
| +static const ExpectPosAndFormat exp_en_HHmmss[kNumDeltas] = {
|
| + { 3, 5, "09:00:00" },
|
| + { 3, 5, "09:00:00" },
|
| + { 3, 5, "09:00:00 \\u2013 09:00:20" },
|
| + { 3, 5, "09:00:00 \\u2013 09:20:00" },
|
| + { 3, 5, "09:00:00 \\u2013 11:00:00" },
|
| + { 3, 5, "09:00:00 \\u2013 21:00:00" },
|
| + { 15, 17, "11/20/2014, 09:00:00 \\u2013 11/28/2014, 09:00:00" },
|
| + { 15, 17, "11/20/2014, 09:00:00 \\u2013 12/6/2014, 09:00:00" },
|
| + { 15, 17, "11/20/2014, 09:00:00 \\u2013 2/28/2015, 09:00:00" }
|
| +};
|
| +
|
| +static const ExpectPosAndFormat exp_en_yyMMdd[kNumDeltas] = {
|
| + { 0, 0, "11/20/14" },
|
| + { 0, 0, "11/20/14" },
|
| + { 0, 0, "11/20/14" },
|
| + { 0, 0, "11/20/14" },
|
| + { 0, 0, "11/20/14" },
|
| + { 0, 0, "11/20/14" },
|
| + { 0, 0, "11/20/14 \\u2013 11/28/14" },
|
| + { 0, 0, "11/20/14 \\u2013 12/6/14" },
|
| + { 0, 0, "11/20/14 \\u2013 2/28/15" }
|
| +};
|
| +
|
| +static const ExpectPosAndFormat exp_en_yyMMddHHmm[kNumDeltas] = {
|
| + { 13, 15, "11/20/14, 09:00" },
|
| + { 13, 15, "11/20/14, 09:00" },
|
| + { 13, 15, "11/20/14, 09:00" },
|
| + { 13, 15, "11/20/14, 09:00 \\u2013 09:20" },
|
| + { 13, 15, "11/20/14, 09:00 \\u2013 11:00" },
|
| + { 13, 15, "11/20/14, 09:00 \\u2013 21:00" },
|
| + { 13, 15, "11/20/14, 09:00 \\u2013 11/28/14, 09:00" },
|
| + { 13, 15, "11/20/14, 09:00 \\u2013 12/06/14, 09:00" },
|
| + { 13, 15, "11/20/14, 09:00 \\u2013 02/28/15, 09:00" }
|
| +};
|
| +
|
| +static const ExpectPosAndFormat exp_en_yyMMddHHmmss[kNumDeltas] = {
|
| + { 13, 15, "11/20/14, 09:00:00" },
|
| + { 13, 15, "11/20/14, 09:00:00" },
|
| + { 13, 15, "11/20/14, 09:00:00 \\u2013 09:00:20" },
|
| + { 13, 15, "11/20/14, 09:00:00 \\u2013 09:20:00" },
|
| + { 13, 15, "11/20/14, 09:00:00 \\u2013 11:00:00" },
|
| + { 13, 15, "11/20/14, 09:00:00 \\u2013 21:00:00" },
|
| + { 13, 15, "11/20/14, 09:00:00 \\u2013 11/28/14, 09:00:00" },
|
| + { 13, 15, "11/20/14, 09:00:00 \\u2013 12/06/14, 09:00:00" },
|
| + { 13, 15, "11/20/14, 09:00:00 \\u2013 02/28/15, 09:00:00" }
|
| +};
|
| +
|
| +static const ExpectPosAndFormat exp_en_yMMMdhmmssz[kNumDeltas] = {
|
| + { 16, 18, "Nov 20, 2014, 9:00:00 AM GMT" },
|
| + { 16, 18, "Nov 20, 2014, 9:00:00 AM GMT" },
|
| + { 16, 18, "Nov 20, 2014, 9:00:00 AM GMT \\u2013 9:00:20 AM GMT" },
|
| + { 16, 18, "Nov 20, 2014, 9:00:00 AM GMT \\u2013 9:20:00 AM GMT" },
|
| + { 16, 18, "Nov 20, 2014, 9:00:00 AM GMT \\u2013 11:00:00 AM GMT" },
|
| + { 16, 18, "Nov 20, 2014, 9:00:00 AM GMT \\u2013 9:00:00 PM GMT" },
|
| + { 16, 18, "Nov 20, 2014, 9:00:00 AM GMT \\u2013 Nov 28, 2014, 9:00:00 AM GMT" },
|
| + { 16, 18, "Nov 20, 2014, 9:00:00 AM GMT \\u2013 Dec 6, 2014, 9:00:00 AM GMT" },
|
| + { 16, 18, "Nov 20, 2014, 9:00:00 AM GMT \\u2013 Feb 28, 2015, 9:00:00 AM GMT" }
|
| +};
|
| +
|
| +static const ExpectPosAndFormat exp_ja_yyMMddHHmm[kNumDeltas] = {
|
| + { 11, 13, "14/11/20 9:00" },
|
| + { 11, 13, "14/11/20 9:00" },
|
| + { 11, 13, "14/11/20 9:00" },
|
| + { 11, 13, "14/11/20 9\\u664200\\u5206\\uFF5E9\\u664220\\u5206" },
|
| + { 11, 13, "14/11/20 9\\u664200\\u5206\\uFF5E11\\u664200\\u5206" },
|
| + { 11, 13, "14/11/20 9\\u664200\\u5206\\uFF5E21\\u664200\\u5206" },
|
| + { 11, 13, "14/11/20 9:00\\uFF5E14/11/28 9:00" },
|
| + { 11, 13, "14/11/20 9:00\\uFF5E14/12/06 9:00" },
|
| + { 11, 13, "14/11/20 9:00\\uFF5E15/02/28 9:00" }
|
| +};
|
| +
|
| +static const ExpectPosAndFormat exp_ja_yyMMddHHmmss[kNumDeltas] = {
|
| + { 11, 13, "14/11/20 9:00:00" },
|
| + { 11, 13, "14/11/20 9:00:00" },
|
| + { 11, 13, "14/11/20 9:00:00\\uFF5E9:00:20" },
|
| + { 11, 13, "14/11/20 9:00:00\\uFF5E9:20:00" },
|
| + { 11, 13, "14/11/20 9:00:00\\uFF5E11:00:00" },
|
| + { 11, 13, "14/11/20 9:00:00\\uFF5E21:00:00" },
|
| + { 11, 13, "14/11/20 9:00:00\\uFF5E14/11/28 9:00:00" },
|
| + { 11, 13, "14/11/20 9:00:00\\uFF5E14/12/06 9:00:00" },
|
| + { 11, 13, "14/11/20 9:00:00\\uFF5E15/02/28 9:00:00" }
|
| +};
|
| +
|
| +static const ExpectPosAndFormat exp_ja_yMMMdHHmmss[kNumDeltas] = {
|
| + { 14, 16, "2014\\u5E7411\\u670820\\u65E5 9:00:00" },
|
| + { 14, 16, "2014\\u5E7411\\u670820\\u65E5 9:00:00" },
|
| + { 14, 16, "2014\\u5E7411\\u670820\\u65E5 9:00:00\\uFF5E9:00:20" },
|
| + { 14, 16, "2014\\u5E7411\\u670820\\u65E5 9:00:00\\uFF5E9:20:00" },
|
| + { 14, 16, "2014\\u5E7411\\u670820\\u65E5 9:00:00\\uFF5E11:00:00" },
|
| + { 14, 16, "2014\\u5E7411\\u670820\\u65E5 9:00:00\\uFF5E21:00:00" },
|
| + { 14, 16, "2014\\u5E7411\\u670820\\u65E5 9:00:00\\uFF5E2014\\u5E7411\\u670828\\u65E5 9:00:00" },
|
| + { 14, 16, "2014\\u5E7411\\u670820\\u65E5 9:00:00\\uFF5E2014\\u5E7412\\u67086\\u65E5 9:00:00" },
|
| + { 14, 16, "2014\\u5E7411\\u670820\\u65E5 9:00:00\\uFF5E2015\\u5E742\\u670828\\u65E5 9:00:00" }
|
| +};
|
| +
|
| +typedef struct {
|
| + const char * locale;
|
| + const char * skeleton;
|
| + UDateFormatField fieldToCheck;
|
| + const ExpectPosAndFormat * expected;
|
| +} LocaleAndSkeletonItem;
|
| +
|
| +static const LocaleAndSkeletonItem locSkelItems[] = {
|
| + { "en", "HHmm", UDAT_MINUTE_FIELD, exp_en_HHmm },
|
| + { "en", "HHmmss", UDAT_MINUTE_FIELD, exp_en_HHmmss },
|
| + { "en", "yyMMdd", UDAT_MINUTE_FIELD, exp_en_yyMMdd },
|
| + { "en", "yyMMddHHmm", UDAT_MINUTE_FIELD, exp_en_yyMMddHHmm },
|
| + { "en", "yyMMddHHmmss", UDAT_MINUTE_FIELD, exp_en_yyMMddHHmmss },
|
| + { "en", "yMMMdhmmssz", UDAT_MINUTE_FIELD, exp_en_yMMMdhmmssz },
|
| + { "ja", "yyMMddHHmm", UDAT_MINUTE_FIELD, exp_ja_yyMMddHHmm },
|
| + { "ja", "yyMMddHHmmss", UDAT_MINUTE_FIELD, exp_ja_yyMMddHHmmss },
|
| + { "ja", "yMMMdHHmmss", UDAT_MINUTE_FIELD, exp_ja_yMMMdHHmmss },
|
| + { NULL, NULL, (UDateFormatField)0, NULL }
|
| +};
|
| +
|
| +enum { kSizeUBuf = 96, kSizeBBuf = 192 };
|
| +
|
| +static void TestFPos_SkelWithSeconds()
|
| +{
|
| + const LocaleAndSkeletonItem * locSkelItemPtr;
|
| + for (locSkelItemPtr = locSkelItems; locSkelItemPtr->locale != NULL; locSkelItemPtr++) {
|
| + UDateIntervalFormat* udifmt;
|
| + UChar ubuf[kSizeUBuf];
|
| + int32_t ulen, uelen;
|
| + UErrorCode status = U_ZERO_ERROR;
|
| +
|
| + u_strFromUTF8(ubuf, kSizeUBuf, &ulen, locSkelItemPtr->skeleton, -1, &status);
|
| + udifmt = udtitvfmt_open(locSkelItemPtr->locale, ubuf, ulen, zoneGMT, -1, &status);
|
| + if ( U_FAILURE(status) ) {
|
| + log_data_err("FAIL: udtitvfmt_open for locale %s, skeleton %s: %s\n",
|
| + locSkelItemPtr->locale, locSkelItemPtr->skeleton, u_errorName(status));
|
| + } else {
|
| + const double * deltasPtr = deltas;
|
| + const ExpectPosAndFormat * expectedPtr = locSkelItemPtr->expected;
|
| + for (; *deltasPtr >= 0.0; deltasPtr++, expectedPtr++) {
|
| + UFieldPosition fpos = { locSkelItemPtr->fieldToCheck, 0, 0 };
|
| + UChar uebuf[kSizeUBuf];
|
| + char bbuf[kSizeBBuf];
|
| + char bebuf[kSizeBBuf];
|
| + status = U_ZERO_ERROR;
|
| + uelen = u_unescape(expectedPtr->format, uebuf, kSizeUBuf);
|
| + ulen = udtitvfmt_format(udifmt, startTime, startTime + *deltasPtr, ubuf, kSizeUBuf, &fpos, &status);
|
| + if ( U_FAILURE(status) ) {
|
| + log_err("FAIL: udtitvfmt_format for locale %s, skeleton %s, delta %.1f: %s\n",
|
| + locSkelItemPtr->locale, locSkelItemPtr->skeleton, *deltasPtr, u_errorName(status));
|
| + } else if ( ulen != uelen || u_strncmp(ubuf,uebuf,uelen) != 0 ||
|
| + fpos.beginIndex != expectedPtr->posBegin || fpos.endIndex != expectedPtr->posEnd ) {
|
| + u_strToUTF8(bbuf, kSizeBBuf, NULL, ubuf, ulen, &status);
|
| + u_strToUTF8(bebuf, kSizeBBuf, NULL, uebuf, uelen, &status); // convert back to get unescaped string
|
| + log_err("FAIL: udtitvfmt_format for locale %s, skeleton %s, delta %12.1f, expect %d-%d \"%s\", get %d-%d \"%s\"\n",
|
| + locSkelItemPtr->locale, locSkelItemPtr->skeleton, *deltasPtr,
|
| + expectedPtr->posBegin, expectedPtr->posEnd, bebuf,
|
| + fpos.beginIndex, fpos.endIndex, bbuf);
|
| + }
|
| + }
|
| + udtitvfmt_close(udifmt);
|
| + }
|
| + }
|
| +}
|
| +
|
| #endif /* #if !UCONFIG_NO_FORMATTING */
|
|
|