X-Git-Url: https://git.saurik.com/apple/icu.git/blobdiff_plain/729e4ab9bc6618bc3d8a898e575df7f4019e29ca..a0b4f637ba1a6c3c5651b61a69303b029bacf7d3:/icuSources/test/intltest/locnmtst.cpp diff --git a/icuSources/test/intltest/locnmtst.cpp b/icuSources/test/intltest/locnmtst.cpp index c2798c20..86025504 100644 --- a/icuSources/test/intltest/locnmtst.cpp +++ b/icuSources/test/intltest/locnmtst.cpp @@ -1,6 +1,6 @@ /********************************************************************* * COPYRIGHT: - * Copyright (c) 2010, International Business Machines Corporation and + * Copyright (c) 2010-2014, International Business Machines Corporation and * others. All Rights Reserved. *********************************************************************/ @@ -49,7 +49,7 @@ logln("unexpected value '" + (value) + "'"); \ dataerrln("FAIL: " #target " == " #value " was not true. In " __FILE__ " on line %d", __LINE__); \ } else { \ - logln("PASS: asserted " #target " == " #value); \ + logln("PASS: asserted " #target " == " #value); \ } \ } @@ -62,21 +62,26 @@ LocaleDisplayNamesTest::~LocaleDisplayNamesTest() { } void LocaleDisplayNamesTest::runIndexedTest(int32_t index, UBool exec, const char* &name, - char* /*par*/) { + char* /*par*/) { switch (index) { #if !UCONFIG_NO_FORMATTING TESTCASE(0, TestCreate); TESTCASE(1, TestCreateDialect); - TESTCASE(2, TestWithKeywordsAndEverything); - TESTCASE(3, TestUldnOpen); - TESTCASE(4, TestUldnOpenDialect); - TESTCASE(5, TestUldnWithKeywordsAndEverything); - TESTCASE(6, TestUldnComponents); - TESTCASE(7, TestRootEtc); + TESTCASE(2, TestWithKeywordsAndEverything); + TESTCASE(3, TestUldnOpen); + TESTCASE(4, TestUldnOpenDialect); + TESTCASE(5, TestUldnWithKeywordsAndEverything); + TESTCASE(6, TestUldnComponents); + TESTCASE(7, TestRootEtc); + TESTCASE(8, TestCurrencyKeyword); + TESTCASE(9, TestUnknownCurrencyKeyword); + TESTCASE(10, TestUntranslatedKeywords); + TESTCASE(11, TestPrivateUse); + TESTCASE(12, TestUldnDisplayContext); #endif default: - name = ""; - break; + name = ""; + break; } } @@ -101,8 +106,48 @@ void LocaleDisplayNamesTest::TestWithKeywordsAndEverything() { UnicodeString temp; LocaleDisplayNames *ldn = LocaleDisplayNames::createInstance(Locale::getUS()); const char *locname = "en_Hant_US_VALLEY@calendar=gregorian;collation=phonebook"; - const char *target = "English (Traditional Han, United States, VALLEY, " - "Calendar=Gregorian Calendar, Collation=Phonebook Sort Order)"; + const char *target = "English (Traditional, US, VALLEY, " + "Gregorian Calendar, Phonebook Sort Order)"; + ldn->localeDisplayName(locname, temp); + delete ldn; + test_assert_equal(target, temp); +} + +void LocaleDisplayNamesTest::TestCurrencyKeyword() { + UnicodeString temp; + LocaleDisplayNames *ldn = LocaleDisplayNames::createInstance(Locale::getUS()); + const char *locname = "ja@currency=JPY"; + const char *target = "Japanese (Japanese Yen)"; + ldn->localeDisplayName(locname, temp); + delete ldn; + test_assert_equal(target, temp); +} + +void LocaleDisplayNamesTest::TestUnknownCurrencyKeyword() { + UnicodeString temp; + LocaleDisplayNames *ldn = LocaleDisplayNames::createInstance(Locale::getUS()); + const char *locname = "de@currency=XYZ"; + const char *target = "German (Currency: XYZ)"; + ldn->localeDisplayName(locname, temp); + delete ldn; + test_assert_equal(target, temp); +} + +void LocaleDisplayNamesTest::TestUntranslatedKeywords() { + UnicodeString temp; + LocaleDisplayNames *ldn = LocaleDisplayNames::createInstance(Locale::getUS()); + const char *locname = "de@foo=bar"; + const char *target = "German (foo=bar)"; + ldn->localeDisplayName(locname, temp); + delete ldn; + test_assert_equal(target, temp); +} + +void LocaleDisplayNamesTest::TestPrivateUse() { + UnicodeString temp; + LocaleDisplayNames *ldn = LocaleDisplayNames::createInstance(Locale::getUS()); + const char *locname = "de@x=foobar"; + const char *target = "German (Private-Use: foobar)"; ldn->localeDisplayName(locname, temp); delete ldn; test_assert_equal(target, temp); @@ -148,8 +193,8 @@ void LocaleDisplayNamesTest::TestUldnWithKeywordsAndEverything() { const int32_t kMaxResultSize = 150; // long enough UChar result[150]; const char *locname = "en_Hant_US_VALLEY@calendar=gregorian;collation=phonebook"; - const char *target = "English (Traditional Han, United States, VALLEY, " - "Calendar=Gregorian Calendar, Collation=Phonebook Sort Order)"; + const char *target = "English (Traditional, US, VALLEY, " + "Gregorian Calendar, Phonebook Sort Order)"; ULocaleDisplayNames *ldn = uldn_open(Locale::getUS().getName(), ULDN_STANDARD_NAMES, &status); int32_t len = uldn_localeDisplayName(ldn, locname, result, kMaxResultSize, &status); uldn_close(ldn); @@ -182,14 +227,14 @@ void LocaleDisplayNamesTest::TestUldnComponents() { { int32_t len = uldn_scriptDisplayName(ldn, "Hant", result, kMaxResultSize, &status); UnicodeString str(result, len, kMaxResultSize); - test_assert_equal("Traditionelle Chinesische Schrift", str); + test_assert_equal("Traditionell", str); } { int32_t len = uldn_scriptCodeDisplayName(ldn, USCRIPT_TRADITIONAL_HAN, result, kMaxResultSize, - &status); + &status); UnicodeString str(result, len, kMaxResultSize); - test_assert_equal("Traditionelle Chinesische Schrift", str); + test_assert_equal("Traditionell", str); } { @@ -212,7 +257,7 @@ void LocaleDisplayNamesTest::TestUldnComponents() { { int32_t len = uldn_keyValueDisplayName(ldn, "calendar", "gregorian", result, - kMaxResultSize, &status); + kMaxResultSize, &status); UnicodeString str(result, len, kMaxResultSize); test_assert_equal("Gregorianischer Kalender", str); } @@ -220,11 +265,121 @@ void LocaleDisplayNamesTest::TestUldnComponents() { uldn_close(ldn); } + +typedef struct { + const char * displayLocale; + UDisplayContext dialectHandling; + UDisplayContext capitalization; + UDisplayContext displayLength; + const char * localeToBeNamed; + const UChar * result; +} LocNameDispContextItem; + +static char en[] = "en"; +static char en_GB[] = "en_GB"; + +static UChar daFor_en[] = {0x65,0x6E,0x67,0x65,0x6C,0x73,0x6B,0}; //"engelsk" +static UChar daFor_en_GB[] = {0x65,0x6E,0x67,0x65,0x6C,0x73,0x6B,0x20,0x28,0x55,0x4B,0x29,0}; //"engelsk (UK)" // Apple change +static UChar daFor_en_GB_S[] = {0x65,0x6E,0x67,0x65,0x6C,0x73,0x6B,0x20,0x28,0x55,0x4B,0x29,0}; //"engelsk (UK)" +static UChar daFor_en_GB_D[] = {0x62,0x72,0x69,0x74,0x69,0x73,0x6B,0x20,0x65,0x6E,0x67,0x65,0x6C,0x73,0x6B,0}; //"britisk engelsk" +static UChar esFor_en[] = {0x69,0x6E,0x67,0x6C,0xE9,0x73,0}; //"ingles" with acute on the e +static UChar esFor_en_GB[] = {0x69,0x6E,0x67,0x6C,0xE9,0x73,0x20,0x28,0x52,0x55,0x29,0}; //"ingles (RU)" ... // Apple change +static UChar esFor_en_GB_S[] = {0x69,0x6E,0x67,0x6C,0xE9,0x73,0x20,0x28,0x52,0x55,0x29,0}; //"ingles (RU)" ... +static UChar esFor_en_GB_D[] = {0x69,0x6E,0x67,0x6C,0xE9,0x73,0x20,0x62,0x72,0x69,0x74,0xE1,0x6E,0x69,0x63,0x6F,0}; //"ingles britanico" with acute on the e, a +#if !UCONFIG_NO_BREAK_ITERATION +static UChar daFor_en_T[] = {0x45,0x6E,0x67,0x65,0x6C,0x73,0x6B,0}; //"Engelsk" +static UChar daFor_en_GB_T[] = {0x45,0x6E,0x67,0x65,0x6C,0x73,0x6B,0x20,0x28,0x55,0x4B,0x29,0}; //"Engelsk (UK)" // Apple change +static UChar daFor_en_GB_ST[] = {0x45,0x6E,0x67,0x65,0x6C,0x73,0x6B,0x20,0x28,0x55,0x4B,0x29,0}; //"Engelsk (UK)" +static UChar daFor_en_GB_DT[] = {0x42,0x72,0x69,0x74,0x69,0x73,0x6B,0x20,0x65,0x6E,0x67,0x65,0x6C,0x73,0x6B,0}; //"Britisk engelsk" +static UChar esFor_en_T[] = {0x49,0x6E,0x67,0x6C,0xE9,0x73,0}; //"Ingles" with acute on the e +static UChar esFor_en_GB_T[] = {0x49,0x6E,0x67,0x6C,0xE9,0x73,0x20,0x28,0x52,0x55,0x29,0}; //"Ingles (RU)" ... // Apple change +static UChar esFor_en_GB_ST[] = {0x49,0x6E,0x67,0x6C,0xE9,0x73,0x20,0x28,0x52,0x55,0x29,0}; //"Ingles (RU)" ... +static UChar esFor_en_GB_DT[] = {0x49,0x6E,0x67,0x6C,0xE9,0x73,0x20,0x62,0x72,0x69,0x74,0xE1,0x6E,0x69,0x63,0x6F,0}; //"Ingles britanico" with acute on the e, a +#endif /* #if !UCONFIG_NO_BREAK_ITERATION */ + +static const LocNameDispContextItem ctxtItems[] = { + { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_MIDDLE_OF_SENTENCE, UDISPCTX_LENGTH_FULL, en, daFor_en }, + { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_MIDDLE_OF_SENTENCE, UDISPCTX_LENGTH_FULL, en_GB, daFor_en_GB }, + { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_MIDDLE_OF_SENTENCE, UDISPCTX_LENGTH_SHORT, en_GB, daFor_en_GB_S }, + { "da", UDISPCTX_DIALECT_NAMES, UDISPCTX_CAPITALIZATION_FOR_MIDDLE_OF_SENTENCE, UDISPCTX_LENGTH_FULL, en_GB, daFor_en_GB_D }, + { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_MIDDLE_OF_SENTENCE, UDISPCTX_LENGTH_FULL, en, esFor_en }, + { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_MIDDLE_OF_SENTENCE, UDISPCTX_LENGTH_FULL, en_GB, esFor_en_GB }, + { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_MIDDLE_OF_SENTENCE, UDISPCTX_LENGTH_SHORT, en_GB, esFor_en_GB_S }, + { "es", UDISPCTX_DIALECT_NAMES, UDISPCTX_CAPITALIZATION_FOR_MIDDLE_OF_SENTENCE, UDISPCTX_LENGTH_FULL, en_GB, esFor_en_GB_D }, +#if !UCONFIG_NO_BREAK_ITERATION + { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE, UDISPCTX_LENGTH_FULL, en, daFor_en_T }, + { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE, UDISPCTX_LENGTH_FULL, en_GB, daFor_en_GB_T }, + { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE, UDISPCTX_LENGTH_SHORT, en_GB, daFor_en_GB_ST }, + { "da", UDISPCTX_DIALECT_NAMES, UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE, UDISPCTX_LENGTH_FULL, en_GB, daFor_en_GB_DT }, + { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE, UDISPCTX_LENGTH_FULL, en, esFor_en_T }, + { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE, UDISPCTX_LENGTH_FULL, en_GB, esFor_en_GB_T }, + { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE, UDISPCTX_LENGTH_SHORT, en_GB, esFor_en_GB_ST }, + { "es", UDISPCTX_DIALECT_NAMES, UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE, UDISPCTX_LENGTH_FULL, en_GB, esFor_en_GB_DT }, + + { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU, UDISPCTX_LENGTH_FULL, en, daFor_en_T }, + { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU, UDISPCTX_LENGTH_FULL, en_GB, daFor_en_GB_T }, + { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU, UDISPCTX_LENGTH_SHORT, en_GB, daFor_en_GB_ST }, + { "da", UDISPCTX_DIALECT_NAMES, UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU, UDISPCTX_LENGTH_FULL, en_GB, daFor_en_GB_DT }, + { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU, UDISPCTX_LENGTH_FULL, en, esFor_en_T }, + { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU, UDISPCTX_LENGTH_FULL, en_GB, esFor_en_GB_T }, + { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU, UDISPCTX_LENGTH_SHORT, en_GB, esFor_en_GB_ST }, + { "es", UDISPCTX_DIALECT_NAMES, UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU, UDISPCTX_LENGTH_FULL, en_GB, esFor_en_GB_DT }, + + { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_STANDALONE, UDISPCTX_LENGTH_FULL, en, daFor_en }, + { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_STANDALONE, UDISPCTX_LENGTH_FULL, en_GB, daFor_en_GB }, + { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_STANDALONE, UDISPCTX_LENGTH_SHORT, en_GB, daFor_en_GB_S }, + { "da", UDISPCTX_DIALECT_NAMES, UDISPCTX_CAPITALIZATION_FOR_STANDALONE, UDISPCTX_LENGTH_FULL, en_GB, daFor_en_GB_D }, + { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_STANDALONE, UDISPCTX_LENGTH_FULL, en, esFor_en_T }, + { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_STANDALONE, UDISPCTX_LENGTH_FULL, en_GB, esFor_en_GB_T }, + { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_STANDALONE, UDISPCTX_LENGTH_SHORT, en_GB, esFor_en_GB_ST }, + { "es", UDISPCTX_DIALECT_NAMES, UDISPCTX_CAPITALIZATION_FOR_STANDALONE, UDISPCTX_LENGTH_FULL, en_GB, esFor_en_GB_DT }, + #endif /* #if !UCONFIG_NO_BREAK_ITERATION */ + { NULL, (UDisplayContext)0, (UDisplayContext)0, (UDisplayContext)0, NULL, NULL } +}; + +void LocaleDisplayNamesTest::TestUldnDisplayContext() { + const LocNameDispContextItem * ctxtItemPtr; + for (ctxtItemPtr = ctxtItems; ctxtItemPtr->displayLocale != NULL; ctxtItemPtr++) { + UDisplayContext contexts[3] = {ctxtItemPtr->dialectHandling, ctxtItemPtr->capitalization, ctxtItemPtr->displayLength}; + UErrorCode status = U_ZERO_ERROR; + ULocaleDisplayNames * uldn = uldn_openForContext(ctxtItemPtr->displayLocale, contexts, 3, &status); + if (U_FAILURE(status)) { + errln(UnicodeString("FAIL: uldn_openForContext failed for locale ") + ctxtItemPtr->displayLocale + + ", dialectHandling " + ctxtItemPtr->dialectHandling + + ", capitalization " + ctxtItemPtr->capitalization + + ", displayLength " + ctxtItemPtr->displayLength); + } else { + UDisplayContext dialectHandling = uldn_getContext(uldn, UDISPCTX_TYPE_DIALECT_HANDLING, &status); + UDisplayContext capitalization = uldn_getContext(uldn, UDISPCTX_TYPE_CAPITALIZATION, &status); + UDisplayContext displayLength = uldn_getContext(uldn, UDISPCTX_TYPE_DISPLAY_LENGTH, &status); + if (U_FAILURE(status)) { + errln(UnicodeString("FAIL: uldn_getContext status ") + (int)status); + } else if (dialectHandling != ctxtItemPtr->dialectHandling || + capitalization != ctxtItemPtr->capitalization || + displayLength != ctxtItemPtr->displayLength) { + errln("FAIL: uldn_getContext retrieved incorrect dialectHandling, capitalization, or displayLength"); + } else { + UChar nameBuf[ULOC_FULLNAME_CAPACITY]; + int32_t len = uldn_localeDisplayName(uldn, ctxtItemPtr->localeToBeNamed, nameBuf, ULOC_FULLNAME_CAPACITY, &status); + if (U_FAILURE(status)) { + dataerrln(UnicodeString("FAIL: uldn_localeDisplayName status: ") + u_errorName(status)); + } else if (u_strcmp(ctxtItemPtr->result, nameBuf) != 0) { + UnicodeString exp(ctxtItemPtr->result, u_strlen(ctxtItemPtr->result)); + UnicodeString got(nameBuf, len); + dataerrln(UnicodeString("FAIL: uldn_localeDisplayName, capitalization ") + ctxtItemPtr->capitalization + + ", expected " + exp + ", got " + got ); + } + } + uldn_close(uldn); + } + } +} + void LocaleDisplayNamesTest::TestRootEtc() { UnicodeString temp; LocaleDisplayNames *ldn = LocaleDisplayNames::createInstance(Locale::getUS()); const char *locname = "@collation=phonebook"; - const char *target = "Root (Collation=Phonebook Sort Order)"; + const char *target = "Root (Phonebook Sort Order)"; ldn->localeDisplayName(locname, temp); test_assert_equal(target, temp); @@ -238,4 +393,3 @@ void LocaleDisplayNamesTest::TestRootEtc() { } #endif /* UCONFIG_NO_FORMATTING */ -