]> git.saurik.com Git - apple/icu.git/blobdiff - icuSources/test/intltest/dtptngts.cpp
ICU-400.37.tar.gz
[apple/icu.git] / icuSources / test / intltest / dtptngts.cpp
diff --git a/icuSources/test/intltest/dtptngts.cpp b/icuSources/test/intltest/dtptngts.cpp
new file mode 100644 (file)
index 0000000..18eae2f
--- /dev/null
@@ -0,0 +1,706 @@
+/********************************************************************
+ * COPYRIGHT: 
+ * Copyright (c) 2008-2009, International Business Machines Corporation and
+ * others. All Rights Reserved.
+ ********************************************************************/
+
+#include "unicode/utypes.h"
+
+#if !UCONFIG_NO_FORMATTING
+
+#include <stdio.h>
+#include <stdlib.h>
+#include "dtptngts.h" 
+
+#include "unicode/calendar.h"
+#include "unicode/smpdtfmt.h"
+#include "unicode/dtfmtsym.h"
+#include "unicode/dtptngen.h"
+#include "loctest.h"
+
+
+// This is an API test, not a unit test.  It doesn't test very many cases, and doesn't
+// try to test the full functionality.  It just calls each function in the class and
+// verifies that it works on a basic level.
+
+void IntlTestDateTimePatternGeneratorAPI::runIndexedTest( int32_t index, UBool exec, const char* &name, char* /*par*/ )
+{
+    if (exec) logln("TestSuite DateTimePatternGeneratorAPI");
+    switch (index) {
+        TESTCASE(0, testAPI);
+        default: name = ""; break;
+    }
+}
+
+#define MAX_LOCALE   8  
+
+/**
+ * Test various generic API methods of DateTimePatternGenerator for API coverage.
+ */
+void IntlTestDateTimePatternGeneratorAPI::testAPI(/*char *par*/)
+{
+    UnicodeString patternData[] = {
+        UnicodeString("yM"),
+        UnicodeString("yMMM"),
+        UnicodeString("yMd"),
+        UnicodeString("yMMMd"),
+        UnicodeString("Md"),
+        UnicodeString("MMMd"),
+        UnicodeString("yQQQ"),
+        UnicodeString("hhmm"),
+        UnicodeString("HHmm"),
+        UnicodeString("jjmm"),
+        UnicodeString("mmss"),
+        UnicodeString("yyyyMMMM"),
+        UnicodeString(),
+     };
+     
+    const char* testLocale[MAX_LOCALE][4] = {
+        {"en", "US", "", ""},
+        {"en", "US", "", "calendar=japanese"},
+        {"zh", "Hans", "CN", ""},
+        {"de", "DE", "", ""},
+        {"fi", "", "", ""},
+        {"ja", "", "", ""},
+        {"ja", "", "", "calendar=japanese"},
+        {"zh", "TW", "", "calendar=roc"},
+     };
+     
+    UnicodeString patternResults[] = {
+        UnicodeString("1/1999"),                              // en_US
+        UnicodeString("Jan 1999"),
+        UnicodeString("1/13/1999"),
+        UnicodeString("Jan 13, 1999"),
+        UnicodeString("1/13"),
+        UnicodeString("Jan 13"),
+        UnicodeString("Q1 1999"),
+        UnicodeString("11:58 PM"),
+        UnicodeString("23:58"),
+        UnicodeString("11:58 PM"),                            // en_US  9: jjmm
+        UnicodeString("58:59"),
+        UnicodeString("January 1999"),                        // en_US 11: yyyyMMMM
+
+        // currently the following for en_US@calendar=japanese just verify the correct fallback behavior for ticket:5702;
+        // however some are not the "correct" results. To fix that, root needs better DateTimePatterns/availableFormats
+        // data; cldrbug #1994 is for that.
+        UnicodeString("H 11-01"),                             // en_US@calendar=japanese  0: yM
+        UnicodeString("H 11 Jan"),                            // en_US@calendar=japanese  1: yMMM
+        UnicodeString("H 11-01-13"),                          // en_US@calendar=japanese  2: yMd
+        UnicodeString("H 11 Jan 13"),                         // en_US@calendar=japanese  3: yMMMd
+        UnicodeString("1-13"),                                // en_US@calendar=japanese  4: Md
+        UnicodeString("Jan 13"),                              // en_US@calendar=japanese  5: MMMd
+        UnicodeString("H 11 Q1"),                             // en_US@calendar=japanese  6: yQQQ
+        UnicodeString("11:58 PM"),                            // en_US@calendar=japanese  7: hhmm
+        UnicodeString("23:58"),                               // en_US@calendar=japanese  8: HHmm
+        UnicodeString("23:58"),                               // en_US@calendar=japanese  9: jjmm
+        UnicodeString("58:59"),                               // en_US@calendar=japanese 10: mmss
+        UnicodeString("H 11 January"),                        // en_US@calendar=japanese 11: yyyyMMMM
+
+        UnicodeString("1999-1", -1, US_INV),                  // zh_Hans_CN: yM
+        CharsToUnicodeString("1999\\u5E741\\u6708"),          // zh_Hans_CN: yMMM  -> yyyy\u5E74MMM (fixed expected result per ticket:6626:)
+        CharsToUnicodeString("1999\\u5E741\\u670813\\u65E5"),
+        CharsToUnicodeString("1999\\u5E741\\u670813\\u65E5"), // zh_Hans_CN: yMMMd -> yyyy\u5E74MMMd\u65E5 (fixed expected result per ticket:6626:)
+        UnicodeString("1-13"),
+        CharsToUnicodeString("1\\u670813\\u65E5"),            // zh_Hans_CN: MMMd  -> MMMd\u65E5 (fixed expected result per ticket:6626:)
+        CharsToUnicodeString("1999\\u5E741\\u5B63"),
+        CharsToUnicodeString("\\u4E0B\\u534811:58"),
+        UnicodeString("23:58"),
+        CharsToUnicodeString("\\u4E0B\\u534811:58"),          // zh_Hans_CN  9: jjmm
+        UnicodeString("58:59"),
+        CharsToUnicodeString("1999\\u5E741\\u6708"),          // zh_Hans_CN 11: yyyyMMMM  -> yyyy\u5E74MMM
+
+        UnicodeString("1999-1"),  // de_DE
+        UnicodeString("Jan 1999"),
+        UnicodeString("13.1.1999"),
+        UnicodeString("13. Jan 1999"),
+        UnicodeString("13.1."),
+        UnicodeString("13. Jan"),
+        UnicodeString("Q1 1999"),
+        UnicodeString("11:58 nachm."),
+        UnicodeString("23:58"),
+        UnicodeString("23:58"),                               // de  9: jjmm
+        UnicodeString("58:59"),
+        UnicodeString("Januar 1999"),                         // de 11: yyyyMMMM
+
+        UnicodeString("1.1999"),                              // fi  0: yM (fixed expected result per ticket:6626:)
+        UnicodeString("tammi 1999"),                          // fi  1: yMMM
+        UnicodeString("13.1.1999"),
+        UnicodeString("13. tammikuuta 1999"),                 // fi  3: yMMMd
+        UnicodeString("13.1."),
+        UnicodeString("13. tammikuuta"),                      // fi  5: MMMd
+        UnicodeString("1. nelj. 1999"),
+        UnicodeString("11.58 ip."),                           // fi  7: hhmm
+        UnicodeString("23.58"),
+        UnicodeString("23.58"),                               // fi  9: jjmm
+        UnicodeString("58.59"),
+        UnicodeString("tammikuu 1999"),                       // fi 11: yyyyMMMM
+
+        UnicodeString("1999/1"),                              // ja 0: yM    -> y/M
+        CharsToUnicodeString("1999\\u5E741\\u6708"),          // ja 1: yMMM  -> y\u5E74M\u6708
+        UnicodeString("1999/1/13"),                           // ja 2: yMd   -> y/M/d
+        CharsToUnicodeString("1999\\u5E741\\u670813\\u65E5"), // ja 3: yMMMd -> y\u5E74M\u6708d\u65E5
+        UnicodeString("1/13"),                                // ja 4: Md    -> M/d
+        CharsToUnicodeString("1\\u670813\\u65E5"),            // ja 5: MMMd  -> M\u6708d\u65E5
+        UnicodeString("1999Q1"),                              // ja 6: yQQQ  -> yQQQ
+        CharsToUnicodeString("\\u5348\\u5F8C11:58"),          // ja 7: hhmm
+        UnicodeString("23:58"),                               // ja 8: HHmm  -> HH:mm
+        UnicodeString("23:58"),                               // ja 9: jjmm
+        UnicodeString("58:59"),                               // ja 10: mmss  -> mm:ss
+        CharsToUnicodeString("1999\\u5E741\\u6708"),          // ja 11: yyyyMMMM  -> y\u5E74M\u6708
+
+        CharsToUnicodeString("\\u5E73\\u621011/1"),                       // ja@japanese 0: yM    -> Gy/m
+        CharsToUnicodeString("\\u5E73\\u621011\\u5E741\\u6708"),          // ja@japanese 1: yMMM  -> Gy\u5E74M\u6708
+        CharsToUnicodeString("\\u5E73\\u621011/1/13"),                    // ja@japanese 2: yMd   -> Gy/m/d
+        CharsToUnicodeString("\\u5E73\\u621011\\u5E741\\u670813\\u65E5"), // ja@japanese 3: yMMMd -> Gy\u5E74M\u6708d\u65E5
+        UnicodeString("1/13"),                                            // ja@japanese 4: Md    -> M/d
+        CharsToUnicodeString("1\\u670813\\u65E5"),                        // ja@japanese 5: MMMd  -> M\u6708d\u65E5
+        CharsToUnicodeString("\\u5E73\\u621011/Q1"),                      // ja@japanese 6: yQQQ  -> Gy/QQQ
+        CharsToUnicodeString("\\u5348\\u5F8C11:58"),                      // ja@japanese 7: hhmm  ->
+        UnicodeString("23:58"),                                           // ja@japanese 8: HHmm  -> HH:mm          (as for ja)
+        UnicodeString("23:58"),                                           // ja@japanese 9: jjmm
+        UnicodeString("58:59"),                                           // ja@japanese 10: mmss  -> mm:ss          (as for ja)
+        CharsToUnicodeString("\\u5E73\\u621011\\u5E741\\u6708"),          // ja@japanese 11: yyyyMMMM  -> Gyyyy\u5E74M\u6708
+
+        CharsToUnicodeString("\\u6C11\\u570B88/1"),                       // zh_TW@roc 0: yM    -> Gy/M
+        CharsToUnicodeString("\\u6C11\\u570B88\\u5E741\\u6708"),          // zh_TW@roc 1: yMMM  -> Gy\u5E74M\u6708
+        CharsToUnicodeString("\\u6C11\\u570B88/1/13"),                    // zh_TW@roc 2: yMd   -> Gy/M/d
+        CharsToUnicodeString("\\u6C11\\u570B88\\u5E741\\u670813\\u65E5"), // zh_TW@roc 3: yMMMd -> Gy\u5E74M\u6708d\u65E5
+        UnicodeString("1/13"),                                            // zh_TW@roc 4: Md    -> M/d
+        CharsToUnicodeString("1\\u670813\\u65E5"),                        // zh_TW@roc 5: MMMd  ->M\u6708d\u65E5
+        CharsToUnicodeString("\\u6C11\\u570B88 1\\u5B63"),                // zh_TW@roc 6: yQQQ  -> Gy QQQ
+        CharsToUnicodeString("\\u4E0B\\u534811:58"),                      // zh_TW@roc 7: hhmm  ->
+        UnicodeString("23:58"),                                           // zh_TW@roc 8: HHmm  ->
+        CharsToUnicodeString("\\u4E0B\\u534811:58"),                      // zh_TW@roc 9: jjmm
+        UnicodeString("58:59"),                                           // zh_TW@roc 10: mmss  ->
+        CharsToUnicodeString("\\u6C11\\u570B88\\u5E741\\u6708"),          // zh_TW@roc 11: yyyyMMMM  -> Gy\u5E74M\u670
+
+        UnicodeString(),
+    };
+
+    UnicodeString patternTests2[] = {
+        UnicodeString("yyyyMMMdd"),
+        UnicodeString("yMMMdd"),
+        UnicodeString("EyyyyMMMdd"),
+        UnicodeString("yyyyMMdd"),
+        UnicodeString("yyyyMMM"),
+        UnicodeString("yyyyMM"),
+        UnicodeString("yyMM"),
+        UnicodeString("yMMMMMd"),
+        UnicodeString("EEEEEMMMMMd"),
+        UnicodeString("MMMd"),
+        UnicodeString("MMMdhmm"),
+        UnicodeString("EMMMdhmms"),
+        UnicodeString("MMdhmm"),
+        UnicodeString("EEEEMMMdhmms"),
+        UnicodeString("yyyyMMMddhhmmss"),
+        UnicodeString("EyyyyMMMddhhmmss"),
+        UnicodeString("hmm"),
+        UnicodeString("hhmm"),
+        UnicodeString(""),
+    };
+    UnicodeString patternResults2[] = {
+        UnicodeString("Oct 14, 1999"),
+        UnicodeString("Oct 14, 1999"),
+        UnicodeString("Thu, Oct 14, 1999"),
+        UnicodeString("10/14/1999"),
+        UnicodeString("Oct 1999"),
+        UnicodeString("10/1999"),
+        UnicodeString("10/99"),
+        UnicodeString("O 14, 1999"),
+        UnicodeString("T, O 14"),
+        UnicodeString("Oct 14"),
+        UnicodeString("Oct 14 6:58 AM"),
+        UnicodeString("Thu, Oct 14 6:58:59 AM"),
+        UnicodeString("10/14 6:58 AM"),
+        UnicodeString("Thursday, Oct 14 6:58:59 AM"),
+        UnicodeString("Oct 14, 1999 06:58:59 AM"),
+        UnicodeString("Thu, Oct 14, 1999 06:58:59 AM"),
+        UnicodeString("6:58 AM"),
+        UnicodeString("06:58 AM"),
+        UnicodeString(""),
+    };
+    
+    // results for getSkeletons() and getPatternForSkeleton()
+    const UnicodeString testSkeletonsResults[] = { 
+        UnicodeString("HH:mm"), 
+        UnicodeString("MMMMd"), 
+        UnicodeString("MMMMMd"), 
+    };
+          
+    const UnicodeString testBaseSkeletonsResults[] = {        
+        UnicodeString("Hm"),  
+        UnicodeString("MMMd"), 
+        UnicodeString("MMMd"),
+    };
+
+    UnicodeString newDecimal(" "); // space
+    UnicodeString newAppendItemName("hrs.");
+    UnicodeString newAppendItemFormat("{1} {0}");
+    UnicodeString newDateTimeFormat("{1} {0}");
+    UErrorCode status = U_ZERO_ERROR;
+    UnicodeString conflictingPattern;
+    UDateTimePatternConflict conflictingStatus;
+
+    // ======= Test CreateInstance with default locale
+    logln("Testing DateTimePatternGenerator createInstance from default locale");
+    
+    DateTimePatternGenerator *instFromDefaultLocale=DateTimePatternGenerator::createInstance(status);
+    if (U_FAILURE(status)) {
+        dataerrln("ERROR: Could not create DateTimePatternGenerator (default) - exitting");
+        return;
+    }
+    else {
+        delete instFromDefaultLocale;
+    }
+
+    // ======= Test CreateInstance with given locale    
+    logln("Testing DateTimePatternGenerator createInstance from French locale");
+    status = U_ZERO_ERROR;
+    DateTimePatternGenerator *instFromLocale=DateTimePatternGenerator::createInstance(Locale::getFrench(), status);
+    if (U_FAILURE(status)) {
+        dataerrln("ERROR: Could not create DateTimePatternGenerator (Locale::getFrench()) - exitting");
+        return;
+    }
+
+    // ======= Test clone DateTimePatternGenerator    
+    logln("Testing DateTimePatternGenerator::clone()");
+    status = U_ZERO_ERROR;
+    
+
+    UnicodeString decimalSymbol = instFromLocale->getDecimal();
+    UnicodeString newDecimalSymbol = UnicodeString("*");
+    decimalSymbol = instFromLocale->getDecimal();
+    instFromLocale->setDecimal(newDecimalSymbol);
+    DateTimePatternGenerator *cloneDTPatternGen=instFromLocale->clone();
+    decimalSymbol = cloneDTPatternGen->getDecimal();
+    if (decimalSymbol != newDecimalSymbol) {
+        errln("ERROR: inconsistency is found in cloned object.");
+    }
+    if ( !(*cloneDTPatternGen == *instFromLocale) ) {
+        errln("ERROR: inconsistency is found in cloned object.");
+    }
+    
+    if ( *cloneDTPatternGen != *instFromLocale ) {
+        errln("ERROR: inconsistency is found in cloned object.");
+    }
+    
+    delete instFromLocale;
+    delete cloneDTPatternGen;
+    
+    // ======= Test simple use cases    
+    logln("Testing simple use cases");
+    status = U_ZERO_ERROR;
+    Locale deLocale=Locale::getGermany();
+    UDate sampleDate=LocaleTest::date(99, 9, 13, 23, 58, 59);
+    DateTimePatternGenerator *gen = DateTimePatternGenerator::createInstance(deLocale, status);
+    if (U_FAILURE(status)) {
+        dataerrln("ERROR: Could not create DateTimePatternGenerator (Locale::getGermany()) - exitting");
+        return;
+    }
+    UnicodeString findPattern = gen->getBestPattern(UnicodeString("MMMddHmm"), status);
+    SimpleDateFormat *format = new SimpleDateFormat(findPattern, deLocale, status);
+    if (U_FAILURE(status)) {
+        dataerrln("ERROR: Could not create SimpleDateFormat (Locale::getGermany())");
+        delete gen;
+        return;
+    }
+    TimeZone *zone = TimeZone::createTimeZone(UnicodeString("ECT"));
+    if (zone==NULL) {
+        dataerrln("ERROR: Could not create TimeZone ECT");
+        delete gen;
+        delete format;
+        return;
+    }
+    format->setTimeZone(*zone);
+    UnicodeString dateReturned, expectedResult;
+    dateReturned.remove();
+    dateReturned = format->format(sampleDate, dateReturned, status);
+    expectedResult=UnicodeString("14. Okt 8:58", -1, US_INV);
+    if ( dateReturned != expectedResult ) {
+        errln("ERROR: Simple test in getBestPattern with Locale::getGermany()).");
+    }
+    // add new pattern
+    status = U_ZERO_ERROR;
+    conflictingStatus = gen->addPattern(UnicodeString("d'. von' MMMM", -1, US_INV), true, conflictingPattern, status); 
+    if (U_FAILURE(status)) {
+        errln("ERROR: Could not addPattern - d\'. von\' MMMM");
+    }
+    status = U_ZERO_ERROR;
+    UnicodeString testPattern=gen->getBestPattern(UnicodeString("MMMMdd"), status);
+    testPattern=gen->getBestPattern(UnicodeString("MMMddHmm"), status);
+    format->applyPattern(gen->getBestPattern(UnicodeString("MMMMddHmm"), status));
+    dateReturned.remove();
+    dateReturned = format->format(sampleDate, dateReturned, status);
+    expectedResult=UnicodeString("14. von Oktober 8:58", -1, US_INV);
+    if ( dateReturned != expectedResult ) {
+        errln("ERROR: Simple test addPattern failed!: d\'. von\' MMMM  ");
+    }
+    delete format;
+    
+    // get a pattern and modify it
+    format = (SimpleDateFormat *)DateFormat::createDateTimeInstance(DateFormat::kFull, DateFormat::kFull, 
+                                                                  deLocale);
+    format->setTimeZone(*zone);
+    UnicodeString pattern;
+    pattern = format->toPattern(pattern);
+    dateReturned.remove();
+    dateReturned = format->format(sampleDate, dateReturned, status);
+    expectedResult=UnicodeString("Donnerstag, 14. Oktober 1999 08:58:59 Frankreich");
+    if ( dateReturned != expectedResult ) {
+        errln("ERROR: Simple test uses full date format.");
+        errln(UnicodeString(" Got: ") + dateReturned + UnicodeString(" Expected: ") + expectedResult);
+    }
+     
+    // modify it to change the zone.  
+    UnicodeString newPattern = gen->replaceFieldTypes(pattern, UnicodeString("vvvv"), status);
+    format->applyPattern(newPattern);
+    dateReturned.remove();
+    dateReturned = format->format(sampleDate, dateReturned, status);
+    expectedResult=UnicodeString("Donnerstag, 14. Oktober 1999 08:58:59 Frankreich");
+    if ( dateReturned != expectedResult ) {
+        errln("ERROR: Simple test modify the timezone!");
+        errln(UnicodeString(" Got: ")+ dateReturned + UnicodeString(" Expected: ") + expectedResult);
+    }
+    
+    // setDeciaml(), getDeciaml()
+    gen->setDecimal(newDecimal);
+    if (newDecimal != gen->getDecimal()) {
+        errln("ERROR: unexpected result from setDecimal() and getDecimal()!.\n");
+    }
+    
+    // setAppenItemName() , getAppendItemName()
+    gen->setAppendItemName(UDATPG_HOUR_FIELD, newAppendItemName);
+    if (newAppendItemName != gen->getAppendItemName(UDATPG_HOUR_FIELD)) {
+        errln("ERROR: unexpected result from setAppendItemName() and getAppendItemName()!.\n");
+    }
+    
+    // setAppenItemFormat() , getAppendItemFormat()
+    gen->setAppendItemFormat(UDATPG_HOUR_FIELD, newAppendItemFormat);
+    if (newAppendItemFormat != gen->getAppendItemFormat(UDATPG_HOUR_FIELD)) {
+        errln("ERROR: unexpected result from setAppendItemFormat() and getAppendItemFormat()!.\n");
+    }
+    
+    // setDateTimeFormat() , getDateTimeFormat()
+    gen->setDateTimeFormat(newDateTimeFormat);
+    if (newDateTimeFormat != gen->getDateTimeFormat()) {
+        errln("ERROR: unexpected result from setDateTimeFormat() and getDateTimeFormat()!.\n");
+    }
+    
+    // ======== Test getSkeleton and getBaseSkeleton
+    status = U_ZERO_ERROR;
+    pattern = UnicodeString("dd-MMM");
+    UnicodeString expectedSkeleton = UnicodeString("MMMdd");
+    UnicodeString expectedBaseSkeleton = UnicodeString("MMMd");
+    UnicodeString retSkeleton = gen->getSkeleton(pattern, status);
+    if(U_FAILURE(status) || retSkeleton != expectedSkeleton ) {
+         errln("ERROR: Unexpected result from getSkeleton().\n");
+         errln(UnicodeString(" Got: ") + retSkeleton + UnicodeString(" Expected: ") + expectedSkeleton );
+    }
+    retSkeleton = gen->getBaseSkeleton(pattern, status);
+    if(U_FAILURE(status) || retSkeleton !=  expectedBaseSkeleton) {
+         errln("ERROR: Unexpected result from getBaseSkeleton().\n");
+         errln(UnicodeString(" Got: ") + retSkeleton + UnicodeString(" Expected:")+ expectedBaseSkeleton);
+    }
+
+    pattern = UnicodeString("dd/MMMM/yy");
+    expectedSkeleton = UnicodeString("yyMMMMdd");
+    expectedBaseSkeleton = UnicodeString("yMMMd");
+    retSkeleton = gen->getSkeleton(pattern, status);
+    if(U_FAILURE(status) || retSkeleton != expectedSkeleton ) {
+         errln("ERROR: Unexpected result from getSkeleton().\n");
+         errln(UnicodeString(" Got: ") + retSkeleton + UnicodeString(" Expected: ") + expectedSkeleton );
+    }
+    retSkeleton = gen->getBaseSkeleton(pattern, status);
+    if(U_FAILURE(status) || retSkeleton !=  expectedBaseSkeleton) {
+         errln("ERROR: Unexpected result from getBaseSkeleton().\n");
+         errln(UnicodeString(" Got: ") + retSkeleton + UnicodeString(" Expected:")+ expectedBaseSkeleton);
+    }
+    delete format;
+    delete zone;
+    delete gen;
+    
+    {
+        // Trac# 6104
+        status = U_ZERO_ERROR;
+        pattern = UnicodeString("YYYYMMM");
+        UnicodeString expR = CharsToUnicodeString("1999\\u5E741\\u6708"); // fixed expected result per ticket:6626:
+        Locale loc("ja");
+        UDate testDate1= LocaleTest::date(99, 0, 13, 23, 58, 59);
+        DateTimePatternGenerator *patGen=DateTimePatternGenerator::createInstance(loc, status);
+        if(U_FAILURE(status)) {
+            dataerrln("ERROR: Could not create DateTimePatternGenerator");
+            return;
+        }
+        UnicodeString bPattern = patGen->getBestPattern(pattern, status);
+        UnicodeString rDate;
+        SimpleDateFormat sdf(bPattern, loc, status);
+        rDate.remove();
+        rDate = sdf.format(testDate1, rDate);
+
+        logln(UnicodeString(" ja locale with skeleton: YYYYMMM  Best Pattern:") + bPattern);
+        logln(UnicodeString("  Formatted date:") + rDate);
+
+        if ( expR!= rDate ) {
+            errln(UnicodeString("\nERROR: Test Japanese month hack Got: ") + rDate + 
+                  UnicodeString(" Expected: ") + expR );
+        }
+        
+        delete patGen;
+    }
+    {   // Trac# 6104
+        Locale loc("zh");
+        UnicodeString expR = CharsToUnicodeString("1999\\u5E741\\u6708"); // fixed expected result per ticket:6626:
+        UDate testDate1= LocaleTest::date(99, 0, 13, 23, 58, 59);
+        DateTimePatternGenerator *patGen=DateTimePatternGenerator::createInstance(loc, status);
+        if(U_FAILURE(status)) {
+            dataerrln("ERROR: Could not create DateTimePatternGenerator");
+            return;
+        }
+        UnicodeString bPattern = patGen->getBestPattern(pattern, status);
+        UnicodeString rDate;
+        SimpleDateFormat sdf(bPattern, loc, status);
+        rDate.remove();
+        rDate = sdf.format(testDate1, rDate);
+
+        logln(UnicodeString(" zh locale with skeleton: YYYYMMM  Best Pattern:") + bPattern);
+        logln(UnicodeString("  Formatted date:") + rDate);
+        if ( expR!= rDate ) {
+            errln(UnicodeString("\nERROR: Test Chinese month hack Got: ") + rDate + 
+                  UnicodeString(" Expected: ") + expR );
+        }
+        delete patGen;   
+    }
+
+    {
+         // Trac# 6172 duplicate time pattern
+         status = U_ZERO_ERROR;
+         pattern = UnicodeString("hmv");
+         UnicodeString expR = UnicodeString("h:mm a v"); // avail formats has hm -> "h:mm a" (fixed expected result per ticket:6626:)
+         Locale loc("en");
+         DateTimePatternGenerator *patGen=DateTimePatternGenerator::createInstance(loc, status);
+         if(U_FAILURE(status)) {
+             dataerrln("ERROR: Could not create DateTimePatternGenerator");
+             return;
+         }
+         UnicodeString bPattern = patGen->getBestPattern(pattern, status);
+         logln(UnicodeString(" en locale with skeleton: hmv  Best Pattern:") + bPattern);
+
+         if ( expR!= bPattern ) {
+             errln(UnicodeString("\nERROR: Test EN time format Got: ") + bPattern + 
+                   UnicodeString(" Expected: ") + expR );
+         }
+         
+         delete patGen;
+     }
+     
+    
+    // ======= Test various skeletons.
+    logln("Testing DateTimePatternGenerator with various skeleton");
+   
+    status = U_ZERO_ERROR;
+    int32_t localeIndex=0;
+    int32_t resultIndex=0;
+    UnicodeString resultDate;
+    UDate testDate= LocaleTest::date(99, 0, 13, 23, 58, 59);
+    while (localeIndex < MAX_LOCALE )
+    {       
+        int32_t dataIndex=0;
+        UnicodeString bestPattern;
+        
+        Locale loc(testLocale[localeIndex][0], testLocale[localeIndex][1], testLocale[localeIndex][2], testLocale[localeIndex][3]);
+        logln("\n\n Locale: %s_%s_%s@%s", testLocale[localeIndex][0], testLocale[localeIndex][1], testLocale[localeIndex][2], testLocale[localeIndex][3]);
+        DateTimePatternGenerator *patGen=DateTimePatternGenerator::createInstance(loc, status);
+        if(U_FAILURE(status)) {
+            dataerrln("ERROR: Could not create DateTimePatternGenerator with locale index:%d . - exitting\n", localeIndex);
+            return;
+        }
+        while (patternData[dataIndex].length() > 0) {
+            log(patternData[dataIndex]);
+            bestPattern = patGen->getBestPattern(patternData[dataIndex++], status);
+            logln(UnicodeString(" -> ") + bestPattern);
+            
+            SimpleDateFormat sdf(bestPattern, loc, status);
+            resultDate.remove();
+            resultDate = sdf.format(testDate, resultDate);
+            if ( resultDate != patternResults[resultIndex] ) {
+                errln(UnicodeString("\nERROR: Test various skeletons[") + (dataIndex-1) + UnicodeString("], localeIndex ") + localeIndex +
+                      UnicodeString(". Got: ") + resultDate + UnicodeString(" Expected: ") + patternResults[resultIndex] );
+            }
+            
+            resultIndex++;
+        }
+        delete patGen;
+        localeIndex++;
+    }
+    
+    // ======= More tests ticket#6110
+    logln("Testing DateTimePatternGenerator with various skeleton");
+   
+    status = U_ZERO_ERROR;
+    localeIndex=0;
+    resultIndex=0;
+    testDate= LocaleTest::date(99, 9, 13, 23, 58, 59);
+    {       
+        int32_t dataIndex=0;
+        UnicodeString bestPattern;
+        logln("\n\n Test various skeletons for English locale...");
+        DateTimePatternGenerator *patGen=DateTimePatternGenerator::createInstance(Locale::getEnglish(), status);
+        if(U_FAILURE(status)) {
+            dataerrln("ERROR: Could not create DateTimePatternGenerator with locale English . - exitting\n");
+            return;
+        }
+        TimeZone *enZone = TimeZone::createTimeZone(UnicodeString("ECT/GMT"));
+        if (enZone==NULL) {
+            dataerrln("ERROR: Could not create TimeZone ECT");
+            delete patGen;
+            return;
+        }
+        SimpleDateFormat *enFormat = (SimpleDateFormat *)DateFormat::createDateTimeInstance(DateFormat::kFull, 
+                         DateFormat::kFull, Locale::getEnglish());
+        enFormat->setTimeZone(*enZone);
+        while (patternTests2[dataIndex].length() > 0) {
+            logln(patternTests2[dataIndex]);
+            bestPattern = patGen->getBestPattern(patternTests2[dataIndex], status);
+            logln(UnicodeString(" -> ") + bestPattern);
+            enFormat->applyPattern(bestPattern);
+            resultDate.remove();
+            resultDate = enFormat->format(testDate, resultDate);
+            if ( resultDate != patternResults2[resultIndex] ) {
+                errln(UnicodeString("\nERROR: Test various skeletons[") + dataIndex
+                    + UnicodeString("]. Got: ") + resultDate + UnicodeString(" Expected: ") + 
+                    patternResults2[resultIndex] );
+            }
+            dataIndex++;
+            resultIndex++;
+        }
+        delete patGen;
+        delete enZone;
+        delete enFormat;
+    }
+
+
+
+    // ======= Test random skeleton 
+    DateTimePatternGenerator *randDTGen= DateTimePatternGenerator::createInstance(status);
+    if (U_FAILURE(status)) {
+        dataerrln("ERROR: Could not create DateTimePatternGenerator (Locale::getFrench()) - exitting");
+        return;
+    }
+    UChar newChar;
+    int32_t i;
+    for (i=0; i<10; ++i) {
+        UnicodeString randomSkeleton;
+        int32_t len = rand() % 20;
+        for (int32_t j=0; j<len; ++j ) {
+            while ((newChar = (UChar)(rand()%0x7f))>=(UChar)0x20) {
+                randomSkeleton += newChar;
+            }
+        }
+        UnicodeString bestPattern = randDTGen->getBestPattern(randomSkeleton, status);
+    }
+    delete randDTGen;
+    
+    // UnicodeString randomString=Unicode
+    // ======= Test getStaticClassID()
+
+    logln("Testing getStaticClassID()");
+    status = U_ZERO_ERROR;
+    DateTimePatternGenerator *test= DateTimePatternGenerator::createInstance(status);
+    
+    if(test->getDynamicClassID() != DateTimePatternGenerator::getStaticClassID()) {
+        errln("ERROR: getDynamicClassID() didn't return the expected value");
+    }
+    delete test;
+    
+    // ====== Test createEmptyInstance()
+    
+    logln("Testing createEmptyInstance()");
+    status = U_ZERO_ERROR;
+    
+    test = DateTimePatternGenerator::createEmptyInstance(status);
+    if(U_FAILURE(status)) {
+         errln("ERROR: Fail to create an empty instance ! - exitting.\n");
+         delete test;
+         return;
+    }
+    
+    conflictingStatus = test->addPattern(UnicodeString("MMMMd"), true, conflictingPattern, status); 
+    status = U_ZERO_ERROR;
+    testPattern=test->getBestPattern(UnicodeString("MMMMdd"), status);
+    conflictingStatus = test->addPattern(UnicodeString("HH:mm"), true, conflictingPattern, status); 
+    conflictingStatus = test->addPattern(UnicodeString("MMMMMd"), true, conflictingPattern, status); //duplicate pattern
+    StringEnumeration *output=NULL;
+    output = test->getRedundants(status);
+    expectedResult=UnicodeString("MMMMd");
+    if (output != NULL) {
+        output->reset(status);
+        const UnicodeString *dupPattern=output->snext(status);
+        if ( (dupPattern==NULL) || (*dupPattern != expectedResult) ) {
+            errln("ERROR: Fail in getRedundants !\n");
+        }
+    }
+    
+    // ======== Test getSkeletons and getBaseSkeletons
+    StringEnumeration* ptrSkeletonEnum = test->getSkeletons(status);
+    if(U_FAILURE(status)) {
+        errln("ERROR: Fail to get skeletons !\n");
+    }
+    UnicodeString returnPattern, *ptrSkeleton;
+    ptrSkeletonEnum->reset(status);
+    int32_t count=ptrSkeletonEnum->count(status);
+    for (i=0; i<count; ++i) {
+        ptrSkeleton = (UnicodeString *)ptrSkeletonEnum->snext(status);
+        returnPattern = test->getPatternForSkeleton(*ptrSkeleton);
+        if ( returnPattern != testSkeletonsResults[i] ) {
+            errln(UnicodeString("ERROR: Unexpected result from getSkeletons and getPatternForSkeleton\nGot: ") + returnPattern
+               + UnicodeString("\nExpected: ") + testSkeletonsResults[i]
+               + UnicodeString("\n"));
+        }
+    }
+    StringEnumeration* ptrBaseSkeletonEnum = test->getBaseSkeletons(status);
+    if(U_FAILURE(status)) {
+        errln("ERROR: Fail to get base skeletons !\n");
+    }   
+    count=ptrBaseSkeletonEnum->count(status);
+    for (i=0; i<count; ++i) {
+        ptrSkeleton = (UnicodeString *)ptrBaseSkeletonEnum->snext(status);
+        if ( *ptrSkeleton != testBaseSkeletonsResults[i] ) {
+            errln("ERROR: Unexpected result from getBaseSkeletons() !\n");
+        }
+    }
+
+    // ========= DateTimePatternGenerator sample code in Userguide
+    // set up the generator
+    Locale locale = Locale::getFrench();
+    status = U_ZERO_ERROR;
+    DateTimePatternGenerator *generator = DateTimePatternGenerator::createInstance( locale, status);
+        
+    // get a pattern for an abbreviated month and day
+    pattern = generator->getBestPattern(UnicodeString("MMMd"), status); 
+    SimpleDateFormat formatter(pattern, locale, status); 
+
+    zone = TimeZone::createTimeZone(UnicodeString("GMT"));
+    formatter.setTimeZone(*zone);
+    // use it to format (or parse)
+    UnicodeString formatted;
+    formatted = formatter.format(Calendar::getNow(), formatted, status); 
+    // for French, the result is "13 sept."
+    formatted.remove();
+    // cannot use the result from getNow() because the value change evreyday.
+    testDate= LocaleTest::date(99, 0, 13, 23, 58, 59);
+    formatted = formatter.format(testDate, formatted, status);
+    expectedResult=UnicodeString("14 janv.");
+    if ( formatted != expectedResult ) {
+        errln("ERROR: Userguide sample code result!");
+        errln(UnicodeString(" Got: ")+ formatted + UnicodeString(" Expected: ") + expectedResult);
+    }
+
+    delete zone;
+    delete output;
+    delete ptrSkeletonEnum;
+    delete ptrBaseSkeletonEnum;
+    delete test;
+    delete generator;
+}
+
+#endif /* #if !UCONFIG_NO_FORMATTING */