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