Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(14)

Unified Diff: source/test/cintltst/cdateintervalformattest.c

Issue 1621843002: ICU 56 update step 1 (Closed) Base URL: https://chromium.googlesource.com/chromium/deps/icu.git@561
Patch Set: Created 4 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « source/test/cintltst/ccapitst.c ('k') | source/test/cintltst/cdattst.c » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 */
« no previous file with comments | « source/test/cintltst/ccapitst.c ('k') | source/test/cintltst/cdattst.c » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698