1 // © 2016 and later: Unicode, Inc. and others.
2 // License & terms of use: http://www.unicode.org/copyright.html
3 /*********************************************************************
4  * COPYRIGHT:
5  * Copyright (c) 2010-2016, International Business Machines Corporation and
6  * others. All Rights Reserved.
7  *********************************************************************/
8 
9 #include "locnmtst.h"
10 #include "unicode/ustring.h"
11 #include "cstring.h"
12 
13 /*
14  Usage:
15     test_assert(    Test (should be TRUE)  )
16 
17    Example:
18        test_assert(i==3);
19 
20    the macro is ugly but makes the tests pretty.
21 */
22 
23 #define test_assert(test) \
24     { \
25         if(!(test)) \
26             errln("FAIL: " #test " was not true. In " __FILE__ " on line %d", __LINE__ ); \
27         else \
28             logln("PASS: asserted " #test); \
29     }
30 
31 /*
32  Usage:
33     test_assert_print(    Test (should be TRUE),  printable  )
34 
35    Example:
36        test_assert(i==3, toString(i));
37 
38    the macro is ugly but makes the tests pretty.
39 */
40 
41 #define test_assert_print(test,print) \
42     { \
43         if(!(test)) \
44             errln("FAIL: " #test " was not true. " + UnicodeString(print) ); \
45         else \
46             logln("PASS: asserted " #test "-> " + UnicodeString(print)); \
47     }
48 
49 #define test_assert_equal(target,value) \
50   { \
51     if (UnicodeString(target)!=(value)) { \
52       logln("unexpected value '" + (value) + "'"); \
53       dataerrln("FAIL: " #target " == " #value " was not true. In " __FILE__ " on line %d", __LINE__); \
54     } else { \
55       logln("PASS: asserted " #target " == " #value); \
56     } \
57   }
58 
59 #define test_dumpLocale(l) { logln(#l " = " + UnicodeString(l.getName(), "")); }
60 
LocaleDisplayNamesTest()61 LocaleDisplayNamesTest::LocaleDisplayNamesTest() {
62 }
63 
~LocaleDisplayNamesTest()64 LocaleDisplayNamesTest::~LocaleDisplayNamesTest() {
65 }
66 
runIndexedTest(int32_t index,UBool exec,const char * & name,char *)67 void LocaleDisplayNamesTest::runIndexedTest(int32_t index, UBool exec, const char* &name,
68                         char* /*par*/) {
69     switch (index) {
70 #if !UCONFIG_NO_FORMATTING
71         TESTCASE(0, TestCreate);
72         TESTCASE(1, TestCreateDialect);
73         TESTCASE(2, TestWithKeywordsAndEverything);
74         TESTCASE(3, TestUldnOpen);
75         TESTCASE(4, TestUldnOpenDialect);
76         TESTCASE(5, TestUldnWithKeywordsAndEverything);
77         TESTCASE(6, TestUldnComponents);
78         TESTCASE(7, TestRootEtc);
79         TESTCASE(8, TestCurrencyKeyword);
80         TESTCASE(9, TestUnknownCurrencyKeyword);
81         TESTCASE(10, TestUntranslatedKeywords);
82         TESTCASE(11, TestPrivateUse);
83         TESTCASE(12, TestUldnDisplayContext);
84         TESTCASE(13, TestUldnWithGarbage);
85 #endif
86         default:
87             name = "";
88             break;
89     }
90 }
91 
92 #if !UCONFIG_NO_FORMATTING
TestCreate()93 void LocaleDisplayNamesTest::TestCreate() {
94   UnicodeString temp;
95   LocaleDisplayNames *ldn = LocaleDisplayNames::createInstance(Locale::getGermany());
96   ldn->localeDisplayName("de_DE", temp);
97   delete ldn;
98   test_assert_equal("Deutsch (Deutschland)", temp);
99 }
100 
TestCreateDialect()101 void LocaleDisplayNamesTest::TestCreateDialect() {
102   UnicodeString temp;
103   LocaleDisplayNames *ldn = LocaleDisplayNames::createInstance(Locale::getUS(), ULDN_DIALECT_NAMES);
104   ldn->localeDisplayName("en_GB", temp);
105   delete ldn;
106   test_assert_equal("British English", temp);
107 }
108 
TestWithKeywordsAndEverything()109 void LocaleDisplayNamesTest::TestWithKeywordsAndEverything() {
110   UnicodeString temp;
111   LocaleDisplayNames *ldn = LocaleDisplayNames::createInstance(Locale::getUS());
112   const char *locname = "en_Hant_US_VALLEY@calendar=gregorian;collation=phonebook";
113   const char *target = "English (Traditional, United States, VALLEY, "
114     "Gregorian Calendar, Phonebook Sort Order)";
115   ldn->localeDisplayName(locname, temp);
116   delete ldn;
117   test_assert_equal(target, temp);
118 }
119 
TestCurrencyKeyword()120 void LocaleDisplayNamesTest::TestCurrencyKeyword() {
121   UnicodeString temp;
122   LocaleDisplayNames *ldn = LocaleDisplayNames::createInstance(Locale::getUS());
123   const char *locname = "ja@currency=JPY";
124   const char *target = "Japanese (Japanese Yen)";
125   ldn->localeDisplayName(locname, temp);
126   delete ldn;
127   test_assert_equal(target, temp);
128 }
129 
TestUnknownCurrencyKeyword()130 void LocaleDisplayNamesTest::TestUnknownCurrencyKeyword() {
131   UnicodeString temp;
132   LocaleDisplayNames *ldn = LocaleDisplayNames::createInstance(Locale::getUS());
133   const char *locname = "de@currency=XYZ";
134   const char *target = "German (Currency: XYZ)";
135   ldn->localeDisplayName(locname, temp);
136   delete ldn;
137   test_assert_equal(target, temp);
138 }
139 
TestUntranslatedKeywords()140 void LocaleDisplayNamesTest::TestUntranslatedKeywords() {
141   UnicodeString temp;
142   LocaleDisplayNames *ldn = LocaleDisplayNames::createInstance(Locale::getUS());
143   const char *locname = "de@foo=bar";
144   const char *target = "German (foo=bar)";
145   ldn->localeDisplayName(locname, temp);
146   delete ldn;
147   test_assert_equal(target, temp);
148 }
149 
TestPrivateUse()150 void LocaleDisplayNamesTest::TestPrivateUse() {
151   UnicodeString temp;
152   LocaleDisplayNames *ldn = LocaleDisplayNames::createInstance(Locale::getUS());
153   const char *locname = "de@x=foobar";
154   const char *target = "German (Private-Use: foobar)";
155   ldn->localeDisplayName(locname, temp);
156   delete ldn;
157   test_assert_equal(target, temp);
158 }
159 
TestUldnOpen()160 void LocaleDisplayNamesTest::TestUldnOpen() {
161   UErrorCode status = U_ZERO_ERROR;
162   const int32_t kMaxResultSize = 150;  // long enough
163   UChar result[150];
164   ULocaleDisplayNames *ldn = uldn_open(Locale::getGermany().getName(), ULDN_STANDARD_NAMES, &status);
165   int32_t len = uldn_localeDisplayName(ldn, "de_DE", result, kMaxResultSize, &status);
166   uldn_close(ldn);
167   test_assert(U_SUCCESS(status));
168 
169   UnicodeString str(result, len, kMaxResultSize);
170   test_assert_equal("Deutsch (Deutschland)", str);
171 
172   // make sure that NULL gives us the default locale as usual
173   ldn = uldn_open(NULL, ULDN_STANDARD_NAMES, &status);
174   const char *locale = uldn_getLocale(ldn);
175   if(0 != uprv_strcmp(uloc_getDefault(), locale)) {
176     errln("uldn_getLocale(uldn_open(NULL))=%s != default locale %s\n", locale, uloc_getDefault());
177   }
178   uldn_close(ldn);
179   test_assert(U_SUCCESS(status));
180 }
181 
TestUldnOpenDialect()182 void LocaleDisplayNamesTest::TestUldnOpenDialect() {
183   UErrorCode status = U_ZERO_ERROR;
184   const int32_t kMaxResultSize = 150;  // long enough
185   UChar result[150];
186   ULocaleDisplayNames *ldn = uldn_open(Locale::getUS().getName(), ULDN_DIALECT_NAMES, &status);
187   int32_t len = uldn_localeDisplayName(ldn, "en_GB", result, kMaxResultSize, &status);
188   uldn_close(ldn);
189   test_assert(U_SUCCESS(status));
190 
191   UnicodeString str(result, len, kMaxResultSize);
192   test_assert_equal("British English", str);
193 }
194 
TestUldnWithGarbage()195 void LocaleDisplayNamesTest::TestUldnWithGarbage() {
196   UErrorCode status = U_ZERO_ERROR;
197   const int32_t kMaxResultSize = 150;  // long enough
198   UChar result[150];
199   ULocaleDisplayNames *ldn = uldn_open(Locale::getUS().getName(), ULDN_DIALECT_NAMES, &status);
200   int32_t len = uldn_localeDisplayName(ldn, "english (United States) [w", result, kMaxResultSize, &status);
201   uldn_close(ldn);
202   test_assert(U_FAILURE(status) && len == 0);
203 }
204 
TestUldnWithKeywordsAndEverything()205 void LocaleDisplayNamesTest::TestUldnWithKeywordsAndEverything() {
206   UErrorCode status = U_ZERO_ERROR;
207   const int32_t kMaxResultSize = 150;  // long enough
208   UChar result[150];
209   const char *locname = "en_Hant_US_VALLEY@calendar=gregorian;collation=phonebook";
210   const char *target = "English (Traditional, United States, VALLEY, "
211     "Gregorian Calendar, Phonebook Sort Order)";
212   ULocaleDisplayNames *ldn = uldn_open(Locale::getUS().getName(), ULDN_STANDARD_NAMES, &status);
213   int32_t len = uldn_localeDisplayName(ldn, locname, result, kMaxResultSize, &status);
214   uldn_close(ldn);
215   test_assert(U_SUCCESS(status));
216 
217   UnicodeString str(result, len, kMaxResultSize);
218   test_assert_equal(target, str);
219 }
220 
TestUldnComponents()221 void LocaleDisplayNamesTest::TestUldnComponents() {
222   UErrorCode status = U_ZERO_ERROR;
223   const int32_t kMaxResultSize = 150;  // long enough
224   UChar result[150];
225 
226   ULocaleDisplayNames *ldn = uldn_open(Locale::getGermany().getName(), ULDN_STANDARD_NAMES, &status);
227   test_assert(U_SUCCESS(status));
228   if (U_FAILURE(status)) {
229     return;
230   }
231 
232   // "en_Hant_US_PRE_EURO@calendar=gregorian";
233 
234   {
235     int32_t len = uldn_languageDisplayName(ldn, "en", result, kMaxResultSize, &status);
236     UnicodeString str(result, len, kMaxResultSize);
237     test_assert_equal("Englisch", str);
238   }
239 
240 
241   {
242     int32_t len = uldn_scriptDisplayName(ldn, "Hant", result, kMaxResultSize, &status);
243     UnicodeString str(result, len, kMaxResultSize);
244     test_assert_equal("Traditionell", str);
245   }
246 
247   {
248     int32_t len = uldn_scriptCodeDisplayName(ldn, USCRIPT_TRADITIONAL_HAN, result, kMaxResultSize,
249                          &status);
250     UnicodeString str(result, len, kMaxResultSize);
251     test_assert_equal("Traditionell", str);
252   }
253 
254   {
255     int32_t len = uldn_regionDisplayName(ldn, "US", result, kMaxResultSize, &status);
256     UnicodeString str(result, len, kMaxResultSize);
257     test_assert_equal("Vereinigte Staaten", str);
258   }
259 
260   {
261     int32_t len = uldn_variantDisplayName(ldn, "PRE_EURO", result, kMaxResultSize, &status);
262     UnicodeString str(result, len, kMaxResultSize);
263     test_assert_equal("PRE_EURO", str);
264   }
265 
266   {
267     int32_t len = uldn_keyDisplayName(ldn, "calendar", result, kMaxResultSize, &status);
268     UnicodeString str(result, len, kMaxResultSize);
269     test_assert_equal("Kalender", str);
270   }
271 
272   {
273     int32_t len = uldn_keyValueDisplayName(ldn, "calendar", "gregorian", result,
274                        kMaxResultSize, &status);
275     UnicodeString str(result, len, kMaxResultSize);
276     test_assert_equal("Gregorianischer Kalender", str);
277   }
278 
279   uldn_close(ldn);
280 }
281 
282 
283 typedef struct {
284     const char * displayLocale;
285     UDisplayContext dialectHandling;
286     UDisplayContext capitalization;
287     UDisplayContext displayLength;
288     const char * localeToBeNamed;
289     const UChar * result;
290 } LocNameDispContextItem;
291 
292 static char en[] = "en";
293 static char en_cabud[] = "en@calendar=buddhist";
294 static char en_GB[] = "en_GB";
295 static char uz_Latn[] = "uz_Latn";
296 
297 static UChar daFor_en[]       = {0x65,0x6E,0x67,0x65,0x6C,0x73,0x6B,0}; //"engelsk"
298 static UChar daFor_en_cabud[] = {0x65,0x6E,0x67,0x65,0x6C,0x73,0x6B,0x20,0x28,0x62,0x75,0x64,0x64,0x68,0x69,0x73,0x74,0x69,0x73,0x6B,0x20,
299                                  0x6B,0x61,0x6C,0x65,0x6E,0x64,0x65,0x72,0x29,0}; //"engelsk (buddhistisk kalender)"
300 static UChar daFor_en_GB[]    = {0x65,0x6E,0x67,0x65,0x6C,0x73,0x6B,0x20,0x28,0x53,0x74,0x6F,0x72,0x62,0x72,0x69,0x74,0x61,0x6E,0x6E,0x69,0x65,0x6E,0x29,0}; //"engelsk (Storbritannien)"
301 static UChar daFor_en_GB_S[]  = {0x65,0x6E,0x67,0x65,0x6C,0x73,0x6B,0x20,0x28,0x55,0x4B,0x29,0}; //"engelsk (UK)"
302 static UChar daFor_en_GB_D[]  = {0x62,0x72,0x69,0x74,0x69,0x73,0x6B,0x20,0x65,0x6E,0x67,0x65,0x6C,0x73,0x6B,0}; //"britisk engelsk"
303 static UChar esFor_en[]       = {0x69,0x6E,0x67,0x6C,0xE9,0x73,0}; //"ingles" with acute on the e
304 static UChar esFor_en_GB[]    = {0x69,0x6E,0x67,0x6C,0xE9,0x73,0x20,0x28,0x52,0x65,0x69,0x6E,0x6F,0x20,0x55,0x6E,0x69,0x64,0x6F,0x29,0}; //"ingles (Reino Unido)" ...
305 static UChar esFor_en_GB_S[]  = {0x69,0x6E,0x67,0x6C,0xE9,0x73,0x20,0x28,0x52,0x55,0x29,0}; //"ingles (RU)" ...
306 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
307 static UChar ruFor_uz_Latn[]  = {0x0443,0x0437,0x0431,0x0435,0x043A,0x0441,0x043A,0x0438,0x0439,0x20,0x28,0x043B,0x0430,0x0442,0x0438,0x043D,0x0438,0x0446,0x0430,0x29,0}; // all lowercase
308 #if !UCONFIG_NO_BREAK_ITERATION
309 static UChar daFor_en_T[]     = {0x45,0x6E,0x67,0x65,0x6C,0x73,0x6B,0}; //"Engelsk"
310 static UChar daFor_en_cabudT[]= {0x45,0x6E,0x67,0x65,0x6C,0x73,0x6B,0x20,0x28,0x62,0x75,0x64,0x64,0x68,0x69,0x73,0x74,0x69,0x73,0x6B,0x20,
311                                  0x6B,0x61,0x6C,0x65,0x6E,0x64,0x65,0x72,0x29,0}; //"Engelsk (buddhistisk kalender)"
312 static UChar daFor_en_GB_T[]  = {0x45,0x6E,0x67,0x65,0x6C,0x73,0x6B,0x20,0x28,0x53,0x74,0x6F,0x72,0x62,0x72,0x69,0x74,0x61,0x6E,0x6E,0x69,0x65,0x6E,0x29,0}; //"Engelsk (Storbritannien)"
313 static UChar daFor_en_GB_ST[] = {0x45,0x6E,0x67,0x65,0x6C,0x73,0x6B,0x20,0x28,0x55,0x4B,0x29,0}; //"Engelsk (UK)"
314 static UChar daFor_en_GB_DT[] = {0x42,0x72,0x69,0x74,0x69,0x73,0x6B,0x20,0x65,0x6E,0x67,0x65,0x6C,0x73,0x6B,0}; //"Britisk engelsk"
315 static UChar esFor_en_T[]     = {0x49,0x6E,0x67,0x6C,0xE9,0x73,0}; //"Ingles" with acute on the e
316 static UChar esFor_en_GB_T[]  = {0x49,0x6E,0x67,0x6C,0xE9,0x73,0x20,0x28,0x52,0x65,0x69,0x6E,0x6F,0x20,0x55,0x6E,0x69,0x64,0x6F,0x29,0}; //"Ingles (Reino Unido)" ...
317 static UChar esFor_en_GB_ST[] = {0x49,0x6E,0x67,0x6C,0xE9,0x73,0x20,0x28,0x52,0x55,0x29,0}; //"Ingles (RU)" ...
318 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
319 static UChar ruFor_uz_Latn_T[]= {0x0423,0x0437,0x0431,0x0435,0x043A,0x0441,0x043A,0x0438,0x0439,0x20,0x28,0x043B,0x0430,0x0442,0x0438,0x043D,0x0438,0x0446,0x0430,0x29,0}; // first char upper
320 #endif /* #if !UCONFIG_NO_BREAK_ITERATION */
321 
322 static const LocNameDispContextItem ctxtItems[] = {
323     { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_MIDDLE_OF_SENTENCE,    UDISPCTX_LENGTH_FULL,   en,    daFor_en },
324     { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_MIDDLE_OF_SENTENCE,    UDISPCTX_LENGTH_FULL,   en_cabud, daFor_en_cabud },
325     { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_MIDDLE_OF_SENTENCE,    UDISPCTX_LENGTH_FULL,   en_GB, daFor_en_GB },
326     { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_MIDDLE_OF_SENTENCE,    UDISPCTX_LENGTH_SHORT,  en_GB, daFor_en_GB_S },
327     { "da", UDISPCTX_DIALECT_NAMES,  UDISPCTX_CAPITALIZATION_FOR_MIDDLE_OF_SENTENCE,    UDISPCTX_LENGTH_FULL,   en_GB, daFor_en_GB_D },
328     { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_MIDDLE_OF_SENTENCE,    UDISPCTX_LENGTH_FULL,   en,    esFor_en },
329     { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_MIDDLE_OF_SENTENCE,    UDISPCTX_LENGTH_FULL,   en_GB, esFor_en_GB },
330     { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_MIDDLE_OF_SENTENCE,    UDISPCTX_LENGTH_SHORT,  en_GB, esFor_en_GB_S },
331     { "es", UDISPCTX_DIALECT_NAMES,  UDISPCTX_CAPITALIZATION_FOR_MIDDLE_OF_SENTENCE,    UDISPCTX_LENGTH_FULL,   en_GB, esFor_en_GB_D },
332     { "ru", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_MIDDLE_OF_SENTENCE,    UDISPCTX_LENGTH_FULL,   uz_Latn, ruFor_uz_Latn },
333 #if !UCONFIG_NO_BREAK_ITERATION
334     { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE, UDISPCTX_LENGTH_FULL,   en,    daFor_en_T },
335     { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE, UDISPCTX_LENGTH_FULL,   en_cabud, daFor_en_cabudT },
336     { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE, UDISPCTX_LENGTH_FULL,   en_GB, daFor_en_GB_T },
337     { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE, UDISPCTX_LENGTH_SHORT,  en_GB, daFor_en_GB_ST },
338     { "da", UDISPCTX_DIALECT_NAMES,  UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE, UDISPCTX_LENGTH_FULL,   en_GB, daFor_en_GB_DT },
339     { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE, UDISPCTX_LENGTH_FULL,   en,    esFor_en_T },
340     { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE, UDISPCTX_LENGTH_FULL,   en_GB, esFor_en_GB_T },
341     { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE, UDISPCTX_LENGTH_SHORT,  en_GB, esFor_en_GB_ST },
342     { "es", UDISPCTX_DIALECT_NAMES,  UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE, UDISPCTX_LENGTH_FULL,   en_GB, esFor_en_GB_DT },
343     { "ru", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE, UDISPCTX_LENGTH_FULL,   uz_Latn, ruFor_uz_Latn_T },
344 
345     { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU,       UDISPCTX_LENGTH_FULL,   en,    daFor_en_T },
346     { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU,       UDISPCTX_LENGTH_FULL,   en_cabud, daFor_en_cabudT },
347     { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU,       UDISPCTX_LENGTH_FULL,   en_GB, daFor_en_GB_T },
348     { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU,       UDISPCTX_LENGTH_SHORT,  en_GB, daFor_en_GB_ST },
349     { "da", UDISPCTX_DIALECT_NAMES,  UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU,       UDISPCTX_LENGTH_FULL,   en_GB, daFor_en_GB_DT },
350     { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU,       UDISPCTX_LENGTH_FULL,   en,    esFor_en_T },
351     { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU,       UDISPCTX_LENGTH_FULL,   en_GB, esFor_en_GB_T },
352     { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU,       UDISPCTX_LENGTH_SHORT,  en_GB, esFor_en_GB_ST },
353     { "es", UDISPCTX_DIALECT_NAMES,  UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU,       UDISPCTX_LENGTH_FULL,   en_GB, esFor_en_GB_DT },
354     { "ru", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU,       UDISPCTX_LENGTH_FULL,   uz_Latn, ruFor_uz_Latn_T },
355 
356     { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_STANDALONE,            UDISPCTX_LENGTH_FULL,   en,    daFor_en },
357     { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_STANDALONE,            UDISPCTX_LENGTH_FULL,   en_cabud, daFor_en_cabud },
358     { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_STANDALONE,            UDISPCTX_LENGTH_FULL,   en_GB, daFor_en_GB },
359     { "da", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_STANDALONE,            UDISPCTX_LENGTH_SHORT,  en_GB, daFor_en_GB_S },
360     { "da", UDISPCTX_DIALECT_NAMES,  UDISPCTX_CAPITALIZATION_FOR_STANDALONE,            UDISPCTX_LENGTH_FULL,   en_GB, daFor_en_GB_D },
361     { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_STANDALONE,            UDISPCTX_LENGTH_FULL,   en,    esFor_en_T },
362     { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_STANDALONE,            UDISPCTX_LENGTH_FULL,   en_GB, esFor_en_GB_T },
363     { "es", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_STANDALONE,            UDISPCTX_LENGTH_SHORT,  en_GB, esFor_en_GB_ST },
364     { "es", UDISPCTX_DIALECT_NAMES,  UDISPCTX_CAPITALIZATION_FOR_STANDALONE,            UDISPCTX_LENGTH_FULL,   en_GB, esFor_en_GB_DT },
365     { "ru", UDISPCTX_STANDARD_NAMES, UDISPCTX_CAPITALIZATION_FOR_STANDALONE,            UDISPCTX_LENGTH_FULL,   uz_Latn, ruFor_uz_Latn_T },
366  #endif /* #if !UCONFIG_NO_BREAK_ITERATION */
367     { NULL, (UDisplayContext)0,      (UDisplayContext)0,                                (UDisplayContext)0,     NULL,  NULL }
368 };
369 
TestUldnDisplayContext()370 void LocaleDisplayNamesTest::TestUldnDisplayContext() {
371     const LocNameDispContextItem * ctxtItemPtr;
372     for (ctxtItemPtr = ctxtItems; ctxtItemPtr->displayLocale != NULL; ctxtItemPtr++) {
373         UDisplayContext contexts[3] = {ctxtItemPtr->dialectHandling, ctxtItemPtr->capitalization, ctxtItemPtr->displayLength};
374         UErrorCode status = U_ZERO_ERROR;
375         ULocaleDisplayNames * uldn = uldn_openForContext(ctxtItemPtr->displayLocale, contexts, 3, &status);
376         if (U_FAILURE(status)) {
377             errln(UnicodeString("FAIL: uldn_openForContext failed for locale ") + ctxtItemPtr->displayLocale +
378                   ", dialectHandling " + ctxtItemPtr->dialectHandling +
379                   ", capitalization " +  ctxtItemPtr->capitalization +
380                   ", displayLength " +  ctxtItemPtr->displayLength);
381         } else {
382             UDisplayContext dialectHandling = uldn_getContext(uldn, UDISPCTX_TYPE_DIALECT_HANDLING, &status);
383             UDisplayContext capitalization = uldn_getContext(uldn, UDISPCTX_TYPE_CAPITALIZATION, &status);
384             UDisplayContext displayLength = uldn_getContext(uldn, UDISPCTX_TYPE_DISPLAY_LENGTH, &status);
385             if (U_FAILURE(status)) {
386                 errln(UnicodeString("FAIL: uldn_getContext status ") + (int)status);
387             } else if (dialectHandling != ctxtItemPtr->dialectHandling ||
388                        capitalization != ctxtItemPtr->capitalization ||
389                        displayLength != ctxtItemPtr->displayLength) {
390                 errln("FAIL: uldn_getContext retrieved incorrect dialectHandling, capitalization, or displayLength");
391             } else {
392                 UChar nameBuf[ULOC_FULLNAME_CAPACITY];
393                 int32_t len = uldn_localeDisplayName(uldn, ctxtItemPtr->localeToBeNamed, nameBuf, ULOC_FULLNAME_CAPACITY, &status);
394                 if (U_FAILURE(status)) {
395                     dataerrln(UnicodeString("FAIL: uldn_localeDisplayName status: ") + u_errorName(status));
396                 } else if (u_strcmp(ctxtItemPtr->result, nameBuf) != 0) {
397                     UnicodeString exp(ctxtItemPtr->result, u_strlen(ctxtItemPtr->result));
398                     UnicodeString got(nameBuf, len);
399                     dataerrln(UnicodeString("FAIL: uldn_localeDisplayName, capitalization ") + ctxtItemPtr->capitalization +
400                           ", expected " + exp + ", got " + got );
401                 }
402             }
403             uldn_close(uldn);
404         }
405     }
406 }
407 
TestRootEtc()408 void LocaleDisplayNamesTest::TestRootEtc() {
409   UnicodeString temp;
410   LocaleDisplayNames *ldn = LocaleDisplayNames::createInstance(Locale::getUS());
411   const char *locname = "@collation=phonebook";
412   const char *target = "Root (Phonebook Sort Order)";
413   ldn->localeDisplayName(locname, temp);
414   test_assert_equal(target, temp);
415 
416   ldn->languageDisplayName("root", temp);
417   test_assert_equal("root", temp);
418 
419   ldn->languageDisplayName("en_GB", temp);
420   test_assert_equal("en_GB", temp);
421 
422   delete ldn;
423 }
424 
425 #endif   /*  UCONFIG_NO_FORMATTING */
426