1 // © 2016 and later: Unicode, Inc. and others.
2 // License & terms of use: http://www.unicode.org/copyright.html
3 /*
4 *******************************************************************************
5 *
6 * Copyright (C) 2003-2016, International Business Machines
7 * Corporation and others. All Rights Reserved.
8 *
9 *******************************************************************************
10 * file name: idnatest.c
11 * encoding: UTF-8
12 * tab size: 8 (not used)
13 * indentation:4
14 *
15 * created on: 2003jul11
16 * created by: Ram Viswanadha
17 */
18 #include <stdlib.h>
19 #include <string.h>
20 #include "unicode/utypes.h"
21
22 #if !UCONFIG_NO_IDNA
23
24 #include "unicode/ustring.h"
25 #include "unicode/uidna.h"
26 #include "cintltst.h"
27 #include "cmemory.h"
28
29 #define MAX_DEST_SIZE 1000
30
31 static void TestToUnicode(void);
32 static void TestToASCII(void);
33 static void TestIDNToUnicode(void);
34 static void TestIDNToASCII(void);
35 static void TestCompare(void);
36 static void TestJB4490(void);
37 static void TestJB4475(void);
38 static void TestLength(void);
39 static void TestJB5273(void);
40 static void TestUTS46(void);
41
42 void addIDNATest(TestNode** root);
43
44
45 typedef int32_t
46 (U_EXPORT2 *TestFunc) ( const UChar *src, int32_t srcLength,
47 UChar *dest, int32_t destCapacity,
48 int32_t options, UParseError *parseError,
49 UErrorCode *status);
50 typedef int32_t
51 (U_EXPORT2 *CompareFunc) (const UChar *s1, int32_t s1Len,
52 const UChar *s2, int32_t s2Len,
53 int32_t options,
54 UErrorCode *status);
55
56
57 void
addIDNATest(TestNode ** root)58 addIDNATest(TestNode** root)
59 {
60 addTest(root, &TestToUnicode, "idna/TestToUnicode");
61 addTest(root, &TestToASCII, "idna/TestToASCII");
62 addTest(root, &TestIDNToUnicode, "idna/TestIDNToUnicode");
63 addTest(root, &TestIDNToASCII, "idna/TestIDNToASCII");
64 addTest(root, &TestCompare, "idna/TestCompare");
65 addTest(root, &TestJB4490, "idna/TestJB4490");
66 addTest(root, &TestJB4475, "idna/TestJB4475");
67 addTest(root, &TestLength, "idna/TestLength");
68 addTest(root, &TestJB5273, "idna/TestJB5273");
69 addTest(root, &TestUTS46, "idna/TestUTS46");
70 }
71
72 static void
testAPI(const UChar * src,const UChar * expected,const char * testName,UBool useSTD3ASCIIRules,UErrorCode expectedStatus,UBool doCompare,UBool testUnassigned,TestFunc func)73 testAPI(const UChar* src, const UChar* expected, const char* testName,
74 UBool useSTD3ASCIIRules,UErrorCode expectedStatus,
75 UBool doCompare, UBool testUnassigned, TestFunc func){
76
77 UErrorCode status = U_ZERO_ERROR;
78 UChar destStack[MAX_DEST_SIZE];
79 int32_t destLen = 0;
80 UChar* dest = NULL;
81 int32_t expectedLen = (expected != NULL) ? u_strlen(expected) : 0;
82 int32_t options = (useSTD3ASCIIRules == TRUE) ? UIDNA_USE_STD3_RULES : UIDNA_DEFAULT;
83 UParseError parseError;
84 int32_t tSrcLen = 0;
85 UChar* tSrc = NULL;
86
87 if(src != NULL){
88 tSrcLen = u_strlen(src);
89 tSrc =(UChar*) malloc( U_SIZEOF_UCHAR * tSrcLen );
90 memcpy(tSrc,src,tSrcLen * U_SIZEOF_UCHAR);
91 }
92
93 /* test null-terminated source and return value of number of UChars required */
94
95 destLen = func(src,-1,NULL,0,options, &parseError , &status);
96 if(status == U_BUFFER_OVERFLOW_ERROR){
97 status = U_ZERO_ERROR; /* reset error code */
98 if(destLen+1 < MAX_DEST_SIZE){
99 dest = destStack;
100 destLen = func(src,-1,dest,destLen+1,options, &parseError, &status);
101 /* TODO : compare output with expected */
102 if(U_SUCCESS(status) && expectedStatus != U_IDNA_STD3_ASCII_RULES_ERROR&& (doCompare==TRUE) && u_strCaseCompare(dest,destLen, expected,expectedLen,0,&status)!=0){
103 log_err("Did not get the expected result for null terminated source.\n" );
104 }
105 }else{
106 log_err( "%s null terminated source failed. Requires destCapacity > 300\n",testName);
107 }
108 }
109
110 if(status != expectedStatus){
111 log_err_status(status, "Did not get the expected error for %s null terminated source failed. Expected: %s Got: %s\n",testName, u_errorName(expectedStatus), u_errorName(status));
112 free(tSrc);
113 return;
114 }
115 if(testUnassigned ){
116 status = U_ZERO_ERROR;
117 destLen = func(src,-1,NULL,0,options | UIDNA_ALLOW_UNASSIGNED, &parseError, &status);
118 if(status == U_BUFFER_OVERFLOW_ERROR){
119 status = U_ZERO_ERROR; /* reset error code */
120 if(destLen+1 < MAX_DEST_SIZE){
121 dest = destStack;
122 destLen = func(src,-1,dest,destLen+1,options | UIDNA_ALLOW_UNASSIGNED, &parseError, &status);
123 /* TODO : compare output with expected */
124 if(U_SUCCESS(status) && (doCompare==TRUE) && u_strCaseCompare(dest,destLen, expected,expectedLen,0,&status)!=0){
125 log_err("Did not get the expected result for %s null terminated source with both options set.\n",testName);
126
127 }
128 }else{
129 log_err( "%s null terminated source failed. Requires destCapacity > 300\n",testName);
130 }
131 }
132 /*testing query string*/
133 if(status != expectedStatus && expectedStatus != U_IDNA_UNASSIGNED_ERROR){
134 log_err( "Did not get the expected error for %s null terminated source with options set. Expected: %s Got: %s\n",testName, u_errorName(expectedStatus), u_errorName(status));
135 }
136 }
137
138 status = U_ZERO_ERROR;
139
140 /* test source with lengthand return value of number of UChars required*/
141 destLen = func(tSrc, tSrcLen, NULL,0,options, &parseError, &status);
142 if(status == U_BUFFER_OVERFLOW_ERROR){
143 status = U_ZERO_ERROR; /* reset error code */
144 if(destLen+1 < MAX_DEST_SIZE){
145 dest = destStack;
146 destLen = func(src,u_strlen(src),dest,destLen+1,options, &parseError, &status);
147 /* TODO : compare output with expected */
148 if(U_SUCCESS(status) && (doCompare==TRUE) && u_strCaseCompare(dest,destLen, expected,expectedLen,0,&status)!=0){
149 log_err("Did not get the expected result for %s with source length.\n",testName);
150 }
151 }else{
152 log_err( "%s with source length failed. Requires destCapacity > 300\n",testName);
153 }
154 }
155
156 if(status != expectedStatus){
157 log_err( "Did not get the expected error for %s with source length. Expected: %s Got: %s\n",testName, u_errorName(expectedStatus), u_errorName(status));
158 }
159 if(testUnassigned){
160 status = U_ZERO_ERROR;
161
162 destLen = func(tSrc,tSrcLen,NULL,0,options | UIDNA_ALLOW_UNASSIGNED, &parseError, &status);
163
164 if(status == U_BUFFER_OVERFLOW_ERROR){
165 status = U_ZERO_ERROR; /* reset error code */
166 if(destLen+1 < MAX_DEST_SIZE){
167 dest = destStack;
168 destLen = func(src,u_strlen(src),dest,destLen+1,options | UIDNA_ALLOW_UNASSIGNED, &parseError, &status);
169 /* TODO : compare output with expected */
170 if(U_SUCCESS(status) && (doCompare==TRUE) && u_strCaseCompare(dest,destLen, expected,expectedLen,0,&status)!=0){
171 log_err("Did not get the expected result for %s with source length and both options set.\n",testName);
172 }
173 }else{
174 log_err( "%s with source length failed. Requires destCapacity > 300\n",testName);
175 }
176 }
177 /*testing query string*/
178 if(status != expectedStatus && expectedStatus != U_IDNA_UNASSIGNED_ERROR){
179 log_err( "Did not get the expected error for %s with source length and options set. Expected: %s Got: %s\n",testName, u_errorName(expectedStatus), u_errorName(status));
180 }
181 }
182
183 status = U_ZERO_ERROR;
184 destLen = func(src,-1,NULL,0,options | UIDNA_USE_STD3_RULES, &parseError, &status);
185 if(status == U_BUFFER_OVERFLOW_ERROR){
186 status = U_ZERO_ERROR; /* reset error code*/
187 if(destLen+1 < MAX_DEST_SIZE){
188 dest = destStack;
189 destLen = func(src,-1,dest,destLen+1,options | UIDNA_USE_STD3_RULES, &parseError, &status);
190 /* TODO : compare output with expected*/
191 if(U_SUCCESS(status) && (doCompare==TRUE) && u_strCaseCompare(dest,destLen, expected,expectedLen,0,&status)!=0){
192 log_err("Did not get the expected result for %s null terminated source with both options set.\n",testName);
193
194 }
195 }else{
196 log_err( "%s null terminated source failed. Requires destCapacity > 300\n",testName);
197 }
198 }
199 /*testing query string*/
200 if(status != expectedStatus){
201 log_err( "Did not get the expected error for %s null terminated source with options set. Expected: %s Got: %s\n",testName, u_errorName(expectedStatus), u_errorName(status));
202 }
203
204 status = U_ZERO_ERROR;
205
206 destLen = func(tSrc,tSrcLen,NULL,0,options | UIDNA_USE_STD3_RULES, &parseError, &status);
207
208 if(status == U_BUFFER_OVERFLOW_ERROR){
209 status = U_ZERO_ERROR; /* reset error code*/
210 if(destLen+1 < MAX_DEST_SIZE){
211 dest = destStack;
212 destLen = func(src,u_strlen(src),dest,destLen+1,options | UIDNA_USE_STD3_RULES, &parseError, &status);
213 /* TODO : compare output with expected*/
214 if(U_SUCCESS(status) && (doCompare==TRUE) && u_strCaseCompare(dest,destLen, expected,expectedLen,0,&status)!=0){
215 log_err("Did not get the expected result for %s with source length and both options set.\n",testName);
216 }
217 }else{
218 log_err( "%s with source length failed. Requires destCapacity > 300\n",testName);
219 }
220 }
221 /*testing query string*/
222 if(status != expectedStatus && expectedStatus != U_IDNA_UNASSIGNED_ERROR){
223 log_err( "Did not get the expected error for %s with source length and options set. Expected: %s Got: %s\n",testName, u_errorName(expectedStatus), u_errorName(status));
224 }
225 free(tSrc);
226 }
227
228 static const UChar unicodeIn[][41] ={
229 {
230 0x0644, 0x064A, 0x0647, 0x0645, 0x0627, 0x0628, 0x062A, 0x0643, 0x0644,
231 0x0645, 0x0648, 0x0634, 0x0639, 0x0631, 0x0628, 0x064A, 0x061F, 0x0000
232 },
233 {
234 0x4ED6, 0x4EEC, 0x4E3A, 0x4EC0, 0x4E48, 0x4E0D, 0x8BF4, 0x4E2D, 0x6587,
235 0x0000
236 },
237 {
238 0x0050, 0x0072, 0x006F, 0x010D, 0x0070, 0x0072, 0x006F, 0x0073, 0x0074,
239 0x011B, 0x006E, 0x0065, 0x006D, 0x006C, 0x0075, 0x0076, 0x00ED, 0x010D,
240 0x0065, 0x0073, 0x006B, 0x0079, 0x0000
241 },
242 {
243 0x05DC, 0x05DE, 0x05D4, 0x05D4, 0x05DD, 0x05E4, 0x05E9, 0x05D5, 0x05D8,
244 0x05DC, 0x05D0, 0x05DE, 0x05D3, 0x05D1, 0x05E8, 0x05D9, 0x05DD, 0x05E2,
245 0x05D1, 0x05E8, 0x05D9, 0x05EA, 0x0000
246 },
247 {
248 0x092F, 0x0939, 0x0932, 0x094B, 0x0917, 0x0939, 0x093F, 0x0928, 0x094D,
249 0x0926, 0x0940, 0x0915, 0x094D, 0x092F, 0x094B, 0x0902, 0x0928, 0x0939,
250 0x0940, 0x0902, 0x092C, 0x094B, 0x0932, 0x0938, 0x0915, 0x0924, 0x0947,
251 0x0939, 0x0948, 0x0902, 0x0000
252 },
253 {
254 0x306A, 0x305C, 0x307F, 0x3093, 0x306A, 0x65E5, 0x672C, 0x8A9E, 0x3092,
255 0x8A71, 0x3057, 0x3066, 0x304F, 0x308C, 0x306A, 0x3044, 0x306E, 0x304B,
256 0x0000
257 },
258 /*
259 {
260 0xC138, 0xACC4, 0xC758, 0xBAA8, 0xB4E0, 0xC0AC, 0xB78C, 0xB4E4, 0xC774,
261 0xD55C, 0xAD6D, 0xC5B4, 0xB97C, 0xC774, 0xD574, 0xD55C, 0xB2E4, 0xBA74,
262 0xC5BC, 0xB9C8, 0xB098, 0xC88B, 0xC744, 0xAE4C, 0x0000
263 },
264 */
265 {
266 0x043F, 0x043E, 0x0447, 0x0435, 0x043C, 0x0443, 0x0436, 0x0435, 0x043E,
267 0x043D, 0x0438, 0x043D, 0x0435, 0x0433, 0x043E, 0x0432, 0x043E, 0x0440,
268 0x044F, 0x0442, 0x043F, 0x043E, 0x0440, 0x0443, 0x0441, 0x0441, 0x043A,
269 0x0438, 0x0000
270 },
271 {
272 0x0050, 0x006F, 0x0072, 0x0071, 0x0075, 0x00E9, 0x006E, 0x006F, 0x0070,
273 0x0075, 0x0065, 0x0064, 0x0065, 0x006E, 0x0073, 0x0069, 0x006D, 0x0070,
274 0x006C, 0x0065, 0x006D, 0x0065, 0x006E, 0x0074, 0x0065, 0x0068, 0x0061,
275 0x0062, 0x006C, 0x0061, 0x0072, 0x0065, 0x006E, 0x0045, 0x0073, 0x0070,
276 0x0061, 0x00F1, 0x006F, 0x006C, 0x0000
277 },
278 {
279 0x4ED6, 0x5011, 0x7232, 0x4EC0, 0x9EBD, 0x4E0D, 0x8AAA, 0x4E2D, 0x6587,
280 0x0000
281 },
282 {
283 0x0054, 0x1EA1, 0x0069, 0x0073, 0x0061, 0x006F, 0x0068, 0x1ECD, 0x006B,
284 0x0068, 0x00F4, 0x006E, 0x0067, 0x0074, 0x0068, 0x1EC3, 0x0063, 0x0068,
285 0x1EC9, 0x006E, 0x00F3, 0x0069, 0x0074, 0x0069, 0x1EBF, 0x006E, 0x0067,
286 0x0056, 0x0069, 0x1EC7, 0x0074, 0x0000
287 },
288 {
289 0x0033, 0x5E74, 0x0042, 0x7D44, 0x91D1, 0x516B, 0x5148, 0x751F, 0x0000
290 },
291 {
292 0x5B89, 0x5BA4, 0x5948, 0x7F8E, 0x6075, 0x002D, 0x0077, 0x0069, 0x0074,
293 0x0068, 0x002D, 0x0053, 0x0055, 0x0050, 0x0045, 0x0052, 0x002D, 0x004D,
294 0x004F, 0x004E, 0x004B, 0x0045, 0x0059, 0x0053, 0x0000
295 },
296 {
297 0x0048, 0x0065, 0x006C, 0x006C, 0x006F, 0x002D, 0x0041, 0x006E, 0x006F,
298 0x0074, 0x0068, 0x0065, 0x0072, 0x002D, 0x0057, 0x0061, 0x0079, 0x002D,
299 0x305D, 0x308C, 0x305E, 0x308C, 0x306E, 0x5834, 0x6240, 0x0000
300 },
301 {
302 0x3072, 0x3068, 0x3064, 0x5C4B, 0x6839, 0x306E, 0x4E0B, 0x0032, 0x0000
303 },
304 {
305 0x004D, 0x0061, 0x006A, 0x0069, 0x3067, 0x004B, 0x006F, 0x0069, 0x3059,
306 0x308B, 0x0035, 0x79D2, 0x524D, 0x0000
307 },
308 {
309 0x30D1, 0x30D5, 0x30A3, 0x30FC, 0x0064, 0x0065, 0x30EB, 0x30F3, 0x30D0,
310 0x0000
311 },
312 {
313 0x305D, 0x306E, 0x30B9, 0x30D4, 0x30FC, 0x30C9, 0x3067, 0x0000
314 },
315 /* test non-BMP code points */
316 {
317 0xD800, 0xDF00, 0xD800, 0xDF01, 0xD800, 0xDF02, 0xD800, 0xDF03, 0xD800, 0xDF05,
318 0xD800, 0xDF06, 0xD800, 0xDF07, 0xD800, 0xDF09, 0xD800, 0xDF0A, 0xD800, 0xDF0B,
319 0x0000
320 },
321 {
322 0xD800, 0xDF0D, 0xD800, 0xDF0C, 0xD800, 0xDF1E, 0xD800, 0xDF0F, 0xD800, 0xDF16,
323 0xD800, 0xDF15, 0xD800, 0xDF14, 0xD800, 0xDF12, 0xD800, 0xDF10, 0xD800, 0xDF20,
324 0xD800, 0xDF21,
325 0x0000
326 },
327 /* Greek */
328 {
329 0x03b5, 0x03bb, 0x03bb, 0x03b7, 0x03bd, 0x03b9, 0x03ba, 0x03ac
330 },
331 /* Maltese */
332 {
333 0x0062, 0x006f, 0x006e, 0x0121, 0x0075, 0x0073, 0x0061, 0x0127,
334 0x0127, 0x0061
335 },
336 /* Russian */
337 {
338 0x043f, 0x043e, 0x0447, 0x0435, 0x043c, 0x0443, 0x0436, 0x0435,
339 0x043e, 0x043d, 0x0438, 0x043d, 0x0435, 0x0433, 0x043e, 0x0432,
340 0x043e, 0x0440, 0x044f, 0x0442, 0x043f, 0x043e, 0x0440, 0x0443,
341 0x0441, 0x0441, 0x043a, 0x0438
342 },
343 {
344 0x0054,0x0045,0x0053,0x0054
345 }
346 };
347
348 static const char * const asciiIn[] = {
349 "xn--egbpdaj6bu4bxfgehfvwxn",
350 "xn--ihqwcrb4cv8a8dqg056pqjye",
351 "xn--Proprostnemluvesky-uyb24dma41a",
352 "xn--4dbcagdahymbxekheh6e0a7fei0b",
353 "xn--i1baa7eci9glrd9b2ae1bj0hfcgg6iyaf8o0a1dig0cd",
354 "xn--n8jok5ay5dzabd5bym9f0cm5685rrjetr6pdxa",
355 /* "xn--989aomsvi5e83db1d2a355cv1e0vak1dwrv93d5xbh15a0dt30a5jpsd879ccm6fea98c",*/
356 "xn--b1abfaaepdrnnbgefbaDotcwatmq2g4l",
357 "xn--PorqunopuedensimplementehablarenEspaol-fmd56a",
358 "xn--ihqwctvzc91f659drss3x8bo0yb",
359 "xn--TisaohkhngthchnitingVit-kjcr8268qyxafd2f1b9g",
360 "xn--3B-ww4c5e180e575a65lsy2b",
361 "xn---with-SUPER-MONKEYS-pc58ag80a8qai00g7n9n",
362 "xn--Hello-Another-Way--fc4qua05auwb3674vfr0b",
363 "xn--2-u9tlzr9756bt3uc0v",
364 "xn--MajiKoi5-783gue6qz075azm5e",
365 "xn--de-jg4avhby1noc0d",
366 "xn--d9juau41awczczp",
367 "XN--097CCDEKGHQJK",
368 "XN--db8CBHEJLGH4E0AL",
369 "xn--hxargifdar", /* Greek */
370 "xn--bonusaa-5bb1da", /* Maltese */
371 "xn--b1abfaaepdrnnbgefbadotcwatmq2g4l", /* Russian (Cyrillic)*/
372 "TEST"
373
374 };
375
376 static const char * const domainNames[] = {
377 "slip129-37-118-146.nc.us.ibm.net",
378 "saratoga.pe.utexas.edu",
379 "dial-120-45.ots.utexas.edu",
380 "woo-085.dorms.waller.net",
381 "hd30-049.hil.compuserve.com",
382 "pem203-31.pe.ttu.edu",
383 "56K-227.MaxTNT3.pdq.net",
384 "dial-36-2.ots.utexas.edu",
385 "slip129-37-23-152.ga.us.ibm.net",
386 "ts45ip119.cadvision.com",
387 "sdn-ts-004txaustP05.dialsprint.net",
388 "bar-tnt1s66.erols.com",
389 "101.st-louis-15.mo.dial-access.att.net",
390 "h92-245.Arco.COM",
391 "dial-13-2.ots.utexas.edu",
392 "net-redynet29.datamarkets.com.ar",
393 "ccs-shiva28.reacciun.net.ve",
394 "7.houston-11.tx.dial-access.att.net",
395 "ingw129-37-120-26.mo.us.ibm.net",
396 "dialup6.austintx.com",
397 "dns2.tpao.gov.tr",
398 "slip129-37-119-194.nc.us.ibm.net",
399 "cs7.dillons.co.uk.203.119.193.in-addr.arpa",
400 "swprd1.innovplace.saskatoon.sk.ca",
401 "bikini.bologna.maraut.it",
402 "node91.subnet159-198-79.baxter.com",
403 "cust19.max5.new-york.ny.ms.uu.net",
404 "balexander.slip.andrew.cmu.edu",
405 "pool029.max2.denver.co.dynip.alter.net",
406 "cust49.max9.new-york.ny.ms.uu.net",
407 "s61.abq-dialin2.hollyberry.com",
408 "\\u0917\\u0928\\u0947\\u0936.sanjose.ibm.com", /*':'(0x003a) produces U_IDNA_STD3_ASCII_RULES_ERROR*/
409 "www.xn--vea.com",
410 /* "www.\\u00E0\\u00B3\\u00AF.com",//' ' (0x0020) produces U_IDNA_STD3_ASCII_RULES_ERROR*/
411 "www.\\u00C2\\u00A4.com",
412 "www.\\u00C2\\u00A3.com",
413 /* "\\u0025", //'%' (0x0025) produces U_IDNA_STD3_ASCII_RULES_ERROR*/
414 /* "\\u005C\\u005C", //'\' (0x005C) produces U_IDNA_STD3_ASCII_RULES_ERROR*/
415 /*"@",*/
416 /*"\\u002F",*/
417 /*"www.\\u0021.com",*/
418 /*"www.\\u0024.com",*/
419 /*"\\u003f",*/
420 /* These yeild U_IDNA_PROHIBITED_ERROR*/
421 /*"\\u00CF\\u0082.com",*/
422 /*"\\u00CE\\u00B2\\u00C3\\u009Fss.com",*/
423 /*"\\u00E2\\u0098\\u00BA.com",*/
424 "\\u00C3\\u00BC.com"
425
426 };
427
428 static void
TestToASCII()429 TestToASCII(){
430
431 int32_t i;
432 UChar buf[MAX_DEST_SIZE];
433 const char* testName = "uidna_toASCII";
434 TestFunc func = uidna_toASCII;
435 for(i=0;i< UPRV_LENGTHOF(unicodeIn); i++){
436 u_charsToUChars(asciiIn[i],buf, (int32_t)strlen(asciiIn[i])+1);
437 testAPI(unicodeIn[i], buf,testName, FALSE,U_ZERO_ERROR, TRUE, TRUE, func);
438
439 }
440 }
441
442 static void
TestToUnicode()443 TestToUnicode(){
444
445 int32_t i;
446 UChar buf[MAX_DEST_SIZE];
447 const char* testName = "uidna_toUnicode";
448 TestFunc func = uidna_toUnicode;
449 for(i=0;i< UPRV_LENGTHOF(asciiIn); i++){
450 u_charsToUChars(asciiIn[i],buf, (int32_t)strlen(asciiIn[i])+1);
451 testAPI(buf,unicodeIn[i],testName,FALSE,U_ZERO_ERROR, TRUE, TRUE, func);
452 }
453 }
454
455
456 static void
TestIDNToUnicode()457 TestIDNToUnicode(){
458 int32_t i;
459 UChar buf[MAX_DEST_SIZE];
460 UChar expected[MAX_DEST_SIZE];
461 UErrorCode status = U_ZERO_ERROR;
462 int32_t bufLen = 0;
463 UParseError parseError;
464 const char* testName="uidna_IDNToUnicode";
465 TestFunc func = uidna_IDNToUnicode;
466 for(i=0;i< UPRV_LENGTHOF(domainNames); i++){
467 bufLen = (int32_t)strlen(domainNames[i]);
468 bufLen = u_unescape(domainNames[i],buf, bufLen+1);
469 func(buf,bufLen,expected,MAX_DEST_SIZE, UIDNA_ALLOW_UNASSIGNED, &parseError,&status);
470 if(U_FAILURE(status)){
471 log_err_status(status, "%s failed to convert domainNames[%i].Error: %s \n",testName, i, u_errorName(status));
472 break;
473 }
474 testAPI(buf,expected,testName,FALSE,U_ZERO_ERROR, TRUE, TRUE, func);
475 /*test toUnicode with all labels in the string*/
476 testAPI(buf,expected,testName, FALSE,U_ZERO_ERROR, TRUE, TRUE, func);
477 if(U_FAILURE(status)){
478 log_err( "%s failed to convert domainNames[%i].Error: %s \n",testName,i, u_errorName(status));
479 break;
480 }
481 }
482
483 }
484
485 static void
TestIDNToASCII()486 TestIDNToASCII(){
487 int32_t i;
488 UChar buf[MAX_DEST_SIZE];
489 UChar expected[MAX_DEST_SIZE];
490 UErrorCode status = U_ZERO_ERROR;
491 int32_t bufLen = 0;
492 UParseError parseError;
493 const char* testName="udina_IDNToASCII";
494 TestFunc func=uidna_IDNToASCII;
495
496 for(i=0;i< UPRV_LENGTHOF(domainNames); i++){
497 bufLen = (int32_t)strlen(domainNames[i]);
498 bufLen = u_unescape(domainNames[i],buf, bufLen+1);
499 func(buf,bufLen,expected,MAX_DEST_SIZE, UIDNA_ALLOW_UNASSIGNED, &parseError,&status);
500 if(U_FAILURE(status)){
501 log_err_status(status, "%s failed to convert domainNames[%i].Error: %s \n",testName,i, u_errorName(status));
502 break;
503 }
504 testAPI(buf,expected,testName, FALSE,U_ZERO_ERROR, TRUE, TRUE, func);
505 /*test toASCII with all labels in the string*/
506 testAPI(buf,expected,testName, FALSE,U_ZERO_ERROR, FALSE, TRUE, func);
507 if(U_FAILURE(status)){
508 log_err( "%s failed to convert domainNames[%i].Error: %s \n",testName,i, u_errorName(status));
509 break;
510 }
511 }
512
513
514 }
515
516
517 static void
testCompareWithSrc(const UChar * s1,int32_t s1Len,const UChar * s2,int32_t s2Len,const char * testName,CompareFunc func,UBool isEqual)518 testCompareWithSrc(const UChar* s1, int32_t s1Len,
519 const UChar* s2, int32_t s2Len,
520 const char* testName, CompareFunc func,
521 UBool isEqual){
522
523 UErrorCode status = U_ZERO_ERROR;
524 int32_t retVal = func(s1,-1,s2,-1,UIDNA_DEFAULT,&status);
525
526 if(isEqual==TRUE && retVal !=0){
527 log_err("Did not get the expected result for %s with null termniated strings.\n",testName);
528 }
529 if(U_FAILURE(status)){
530 log_err_status(status, "%s null terminated source failed. Error: %s\n", testName,u_errorName(status));
531 }
532
533 status = U_ZERO_ERROR;
534 retVal = func(s1,-1,s2,-1,UIDNA_ALLOW_UNASSIGNED,&status);
535
536 if(isEqual==TRUE && retVal !=0){
537 log_err("Did not get the expected result for %s with null termniated strings with options set.\n", testName);
538 }
539 if(U_FAILURE(status)){
540 log_err_status(status, "%s null terminated source and options set failed. Error: %s\n",testName, u_errorName(status));
541 }
542
543 status = U_ZERO_ERROR;
544 retVal = func(s1,s1Len,s2,s2Len,UIDNA_DEFAULT,&status);
545
546 if(isEqual==TRUE && retVal !=0){
547 log_err("Did not get the expected result for %s with string length.\n",testName);
548 }
549 if(U_FAILURE(status)){
550 log_err_status(status, "%s with string length. Error: %s\n",testName, u_errorName(status));
551 }
552
553 status = U_ZERO_ERROR;
554 retVal = func(s1,s1Len,s2,s2Len,UIDNA_ALLOW_UNASSIGNED,&status);
555
556 if(isEqual==TRUE && retVal !=0){
557 log_err("Did not get the expected result for %s with string length and options set.\n",testName);
558 }
559 if(U_FAILURE(status)){
560 log_err_status(status, "%s with string length and options set. Error: %s\n", u_errorName(status), testName);
561 }
562 }
563
564
565 static void
TestCompare()566 TestCompare(){
567 int32_t i;
568
569 const char* testName ="uidna_compare";
570 CompareFunc func = uidna_compare;
571
572 UChar www[] = {0x0057, 0x0057, 0x0057, 0x002E, 0x0000};
573 UChar com[] = {0x002E, 0x0043, 0x004F, 0x004D, 0x0000};
574 UChar buf[MAX_DEST_SIZE]={0x0057, 0x0057, 0x0057, 0x002E, 0x0000};
575 UChar source[MAX_DEST_SIZE]={0},
576 uni0[MAX_DEST_SIZE]={0},
577 uni1[MAX_DEST_SIZE]={0},
578 ascii0[MAX_DEST_SIZE]={0},
579 ascii1[MAX_DEST_SIZE]={0},
580 temp[MAX_DEST_SIZE] ={0};
581
582
583 u_strcat(uni0,unicodeIn[0]);
584 u_strcat(uni0,com);
585
586 u_strcat(uni1,unicodeIn[1]);
587 u_strcat(uni1,com);
588
589 u_charsToUChars(asciiIn[0], temp, (int32_t)strlen(asciiIn[0]));
590 u_strcat(ascii0,temp);
591 u_strcat(ascii0,com);
592
593 memset(temp, 0, U_SIZEOF_UCHAR * MAX_DEST_SIZE);
594
595 u_charsToUChars(asciiIn[1], temp, (int32_t)strlen(asciiIn[1]));
596 u_strcat(ascii1,temp);
597 u_strcat(ascii1,com);
598
599 /* prepend www. */
600 u_strcat(source, www);
601
602 for(i=0;i< UPRV_LENGTHOF(unicodeIn); i++){
603 UChar* src;
604 int32_t srcLen;
605
606 memset(buf+4, 0, (MAX_DEST_SIZE-4) * U_SIZEOF_UCHAR);
607
608 u_charsToUChars(asciiIn[i],buf+4, (int32_t)strlen(asciiIn[i]));
609 u_strcat(buf,com);
610
611
612 /* for every entry in unicodeIn array
613 prepend www. and append .com*/
614 source[4]=0;
615 u_strncat(source,unicodeIn[i], u_strlen(unicodeIn[i]));
616 u_strcat(source,com);
617
618 /* a) compare it with itself*/
619 src = source;
620 srcLen = u_strlen(src);
621
622 testCompareWithSrc(src,srcLen,src,srcLen,testName, func, TRUE);
623
624 /* b) compare it with asciiIn equivalent */
625 testCompareWithSrc(src,srcLen,buf,u_strlen(buf),testName, func,TRUE);
626
627 /* c) compare it with unicodeIn not equivalent*/
628 if(i==0){
629 testCompareWithSrc(src,srcLen,uni1,u_strlen(uni1),testName, func,FALSE);
630 }else{
631 testCompareWithSrc(src,srcLen,uni0,u_strlen(uni0),testName, func,FALSE);
632 }
633 /* d) compare it with asciiIn not equivalent */
634 if(i==0){
635 testCompareWithSrc(src,srcLen,ascii1,u_strlen(ascii1),testName, func,FALSE);
636 }else{
637 testCompareWithSrc(src,srcLen,ascii0,u_strlen(ascii0),testName, func,FALSE);
638 }
639
640 }
641 }
642
TestJB4490()643 static void TestJB4490(){
644 static const UChar data[][50]= {
645 {0x00F5,0x00dE,0x00dF,0x00dD, 0x0000},
646 {0xFB00,0xFB01}
647 };
648 UChar output1[40] = {0};
649 UChar output2[40] = {0};
650 int32_t i;
651 for(i=0; i< UPRV_LENGTHOF(data); i++){
652 const UChar* src1 = data[i];
653 int32_t src1Len = u_strlen(src1);
654 UChar* dest1 = output1;
655 int32_t dest1Len = 40;
656 UErrorCode status = U_ZERO_ERROR;
657 UParseError ps;
658 UChar* src2 = NULL;
659 int32_t src2Len = 0;
660 UChar* dest2 = output2;
661 int32_t dest2Len = 40;
662 dest1Len = uidna_toASCII(src1, src1Len, dest1, dest1Len,UIDNA_DEFAULT, &ps, &status);
663 if(U_FAILURE(status)){
664 log_err_status(status, "uidna_toUnicode failed with error %s.\n", u_errorName(status));
665 }
666 src2 = dest1;
667 src2Len = dest1Len;
668 dest2Len = uidna_toUnicode(src2, src2Len, dest2, dest2Len, UIDNA_DEFAULT, &ps, &status);
669 if(U_FAILURE(status)){
670 log_err_status(status, "uidna_toUnicode failed with error %s.\n", u_errorName(status));
671 }
672 }
673 }
674
TestJB4475()675 static void TestJB4475(){
676
677 static const UChar input[][10] = {
678 {0x0054,0x0045,0x0053,0x0054,0x0000},/* TEST */
679 {0x0074,0x0065,0x0073,0x0074,0x0000} /* test */
680 };
681 int i;
682 UChar output[40] = {0};
683 for(i=0; i< UPRV_LENGTHOF(input); i++){
684 const UChar* src = input[i];
685 int32_t srcLen = u_strlen(src);
686 UChar* dest = output;
687 int32_t destLen = 40;
688 UErrorCode status = U_ZERO_ERROR;
689 UParseError ps;
690
691 destLen = uidna_toASCII(src, srcLen, dest, destLen,UIDNA_DEFAULT, &ps, &status);
692 if(U_FAILURE(status)){
693 log_err_status(status, "uidna_toASCII failed with error %s.\n", u_errorName(status));
694 continue;
695 }
696 if(u_strncmp(input[i], dest, srcLen)!=0){
697 log_err("uidna_toASCII did not return the expected output.\n");
698 }
699 }
700 }
701
TestLength()702 static void TestLength(){
703 {
704 static const char* cl = "my_very_very_very_very_very_very_very_very_very_very_very_very_very_long_and_incredibly_uncreative_domain_label";
705 UChar ul[128] = {'\0'};
706 UChar dest[256] = {'\0'};
707 /* this unicode string is longer than MAX_LABEL_BUFFER_SIZE and produces an
708 IDNA prepared string (including xn--)that is exactly 63 bytes long */
709 UChar ul1[] = { 0xC138, 0xACC4, 0xC758, 0xBAA8, 0xB4E0, 0xC0AC, 0xB78C, 0xB4E4, 0xC774,
710 0xD55C, 0xAD6D, 0xC5B4, 0xB97C, 0xC774, 0x00AD, 0x034F, 0x1806, 0x180B,
711 0x180C, 0x180D, 0x200B, 0x200C, 0x200D, 0x2060, 0xFE00, 0xFE01, 0xFE02,
712 0xFE03, 0xFE04, 0xFE05, 0xFE06, 0xFE07, 0xFE08, 0xFE09, 0xFE0A, 0xFE0B,
713 0xFE0C, 0xFE0D, 0xFE0E, 0xFE0F, 0xFEFF, 0xD574, 0xD55C, 0xB2E4, 0xBA74,
714 0xC138, 0x0041, 0x00AD, 0x034F, 0x1806, 0x180B, 0x180C, 0x180D, 0x200B,
715 0x200C, 0x200D, 0x2060, 0xFE00, 0xFE01, 0xFE02, 0xFE03, 0xFE04, 0xFE05,
716 0xFE06, 0xFE07, 0xFE08, 0xFE09, 0xFE0A, 0xFE0B, 0xFE0C, 0xFE0D, 0xFE0E,
717 0xFE0F, 0xFEFF, 0x00AD, 0x034F, 0x1806, 0x180B, 0x180C, 0x180D, 0x200B,
718 0x200C, 0x200D, 0x2060, 0xFE00, 0xFE01, 0xFE02, 0xFE03, 0xFE04, 0xFE05,
719 0xFE06, 0xFE07, 0xFE08, 0xFE09, 0xFE0A, 0xFE0B, 0xFE0C, 0xFE0D, 0xFE0E,
720 0xFE0F, 0xFEFF, 0x00AD, 0x034F, 0x1806, 0x180B, 0x180C, 0x180D, 0x200B,
721 0x200C, 0x200D, 0x2060, 0xFE00, 0xFE01, 0xFE02, 0xFE03, 0xFE04, 0xFE05,
722 0xFE06, 0xFE07, 0xFE08, 0xFE09, 0xFE0A, 0xFE0B, 0xFE0C, 0xFE0D, 0xFE0E,
723 0xFE0F, 0xFEFF, 0x0000
724 };
725
726 int32_t len1 = UPRV_LENGTHOF(ul1)-1/*remove the null termination*/;
727 int32_t destLen = UPRV_LENGTHOF(dest);
728 UErrorCode status = U_ZERO_ERROR;
729 UParseError ps;
730 int32_t len = (int32_t)strlen(cl);
731 u_charsToUChars(cl, ul, len+1);
732 destLen = uidna_toUnicode(ul, len, dest, destLen, UIDNA_DEFAULT, &ps, &status);
733 if(status != U_ZERO_ERROR){
734 log_err_status(status, "uidna_toUnicode failed with error %s.\n", u_errorName(status));
735 }
736
737 status = U_ZERO_ERROR;
738 destLen = UPRV_LENGTHOF(dest);
739 len = -1;
740 destLen = uidna_toUnicode(ul, len, dest, destLen, UIDNA_DEFAULT, &ps, &status);
741 if(status != U_ZERO_ERROR){
742 log_err_status(status, "uidna_toUnicode failed with error %s.\n", u_errorName(status));
743 }
744 status = U_ZERO_ERROR;
745 destLen = UPRV_LENGTHOF(dest);
746 len = (int32_t)strlen(cl);
747 destLen = uidna_toASCII(ul, len, dest, destLen, UIDNA_DEFAULT, &ps, &status);
748 if(status != U_IDNA_LABEL_TOO_LONG_ERROR){
749 log_err_status(status, "uidna_toASCII failed with error %s.\n", u_errorName(status));
750 }
751
752 status = U_ZERO_ERROR;
753 destLen = UPRV_LENGTHOF(dest);
754 len = -1;
755 destLen = uidna_toASCII(ul, len, dest, destLen, UIDNA_DEFAULT, &ps, &status);
756 if(status != U_IDNA_LABEL_TOO_LONG_ERROR){
757 log_err_status(status, "uidna_toASCII failed with error %s.\n", u_errorName(status));
758 }
759
760 status = U_ZERO_ERROR;
761 destLen = UPRV_LENGTHOF(dest);
762 destLen = uidna_toASCII(ul1, len1, dest, destLen, UIDNA_DEFAULT, &ps, &status);
763 if(status != U_ZERO_ERROR){
764 log_err_status(status, "uidna_toASCII failed with error %s.\n", u_errorName(status));
765 }
766
767 status = U_ZERO_ERROR;
768 destLen = UPRV_LENGTHOF(dest);
769 len1 = -1;
770 destLen = uidna_toASCII(ul1, len1, dest, destLen, UIDNA_DEFAULT, &ps, &status);
771 if(status != U_ZERO_ERROR){
772 log_err_status(status, "uidna_toASCII failed with error %s.\n", u_errorName(status));
773 }
774 }
775 {
776 static const char* cl = "my_very_very_long_and_incredibly_uncreative_domain_label.my_very_very_long_and_incredibly_uncreative_domain_label.my_very_very_long_and_incredibly_uncreative_domain_label.my_very_very_long_and_incredibly_uncreative_domain_label.my_very_very_long_and_incredibly_uncreative_domain_label.my_very_very_long_and_incredibly_uncreative_domain_label.ibm.com";
777 UChar ul[400] = {'\0'};
778 UChar dest[400] = {'\0'};
779 int32_t destLen = UPRV_LENGTHOF(dest);
780 UErrorCode status = U_ZERO_ERROR;
781 UParseError ps;
782 int32_t len = (int32_t)strlen(cl);
783 u_charsToUChars(cl, ul, len+1);
784
785 destLen = uidna_IDNToUnicode(ul, len, dest, destLen, UIDNA_DEFAULT, &ps, &status);
786 if(status != U_IDNA_DOMAIN_NAME_TOO_LONG_ERROR){
787 log_err_status(status, "uidna_IDNToUnicode failed with error %s.\n", u_errorName(status));
788 }
789
790 status = U_ZERO_ERROR;
791 destLen = UPRV_LENGTHOF(dest);
792 len = -1;
793 destLen = uidna_IDNToUnicode(ul, len, dest, destLen, UIDNA_DEFAULT, &ps, &status);
794 if(status != U_IDNA_DOMAIN_NAME_TOO_LONG_ERROR){
795 log_err_status(status, "uidna_IDNToUnicode failed with error %s.\n", u_errorName(status));
796 }
797
798 status = U_ZERO_ERROR;
799 destLen = UPRV_LENGTHOF(dest);
800 len = (int32_t)strlen(cl);
801 destLen = uidna_IDNToASCII(ul, len, dest, destLen, UIDNA_DEFAULT, &ps, &status);
802 if(status != U_IDNA_DOMAIN_NAME_TOO_LONG_ERROR){
803 log_err_status(status, "uidna_IDNToASCII failed with error %s.\n", u_errorName(status));
804 }
805
806 status = U_ZERO_ERROR;
807 destLen = UPRV_LENGTHOF(dest);
808 len = -1;
809 destLen = uidna_IDNToASCII(ul, len, dest, destLen, UIDNA_DEFAULT, &ps, &status);
810 if(status != U_IDNA_DOMAIN_NAME_TOO_LONG_ERROR){
811 log_err_status(status, "uidna_IDNToASCII failed with error %s.\n", u_errorName(status));
812 }
813
814 status = U_ZERO_ERROR;
815 uidna_compare(ul, len, ul, len, UIDNA_DEFAULT, &status);
816 if(status != U_IDNA_DOMAIN_NAME_TOO_LONG_ERROR){
817 log_err_status(status, "uidna_compare failed with error %s.\n", u_errorName(status));
818 }
819 uidna_compare(ul, -1, ul, -1, UIDNA_DEFAULT, &status);
820 if(status != U_IDNA_DOMAIN_NAME_TOO_LONG_ERROR){
821 log_err_status(status, "uidna_compare failed with error %s.\n", u_errorName(status));
822 }
823 }
824 }
TestJB5273()825 static void TestJB5273(){
826 static const char INVALID_DOMAIN_NAME[] = "xn--m\\u00FCller.de";
827 UChar invalid_idn[25] = {'\0'};
828 int32_t len = u_unescape(INVALID_DOMAIN_NAME, invalid_idn, (int32_t)strlen(INVALID_DOMAIN_NAME));
829 UChar output[50] = {'\0'};
830 UErrorCode status = U_ZERO_ERROR;
831 UParseError prsError;
832 int32_t outLen = uidna_toUnicode(invalid_idn, len, output, 50, UIDNA_DEFAULT, &prsError, &status);
833 (void)outLen; /* Suppress set but not used warning. */
834 if(U_FAILURE(status)){
835 log_err_status(status, "uidna_toUnicode failed with error: %s\n", u_errorName(status));
836 }
837 status = U_ZERO_ERROR;
838 outLen = uidna_toUnicode(invalid_idn, len, output, 50, UIDNA_USE_STD3_RULES, &prsError, &status);
839 if(U_FAILURE(status)){
840 log_err_status(status, "uidna_toUnicode failed with error: %s\n", u_errorName(status));
841 }
842
843 status = U_ZERO_ERROR;
844 outLen = uidna_IDNToUnicode(invalid_idn, len, output, 50, UIDNA_DEFAULT, &prsError, &status);
845 if(U_FAILURE(status)){
846 log_err_status(status, "uidna_toUnicode failed with error: %s\n", u_errorName(status));
847 }
848 status = U_ZERO_ERROR;
849 outLen = uidna_IDNToUnicode(invalid_idn, len, output, 50, UIDNA_USE_STD3_RULES, &prsError, &status);
850 if(U_FAILURE(status)){
851 log_err_status(status, "uidna_toUnicode failed with error: %s\n", u_errorName(status));
852 }
853 }
854
855 /*
856 * Test the new (ICU 4.6/2010) C API that was added for UTS #46.
857 * Just an API test: Functionality is tested via C++ intltest.
858 */
TestUTS46()859 static void TestUTS46() {
860 static const UChar fA_sharps16[] = { 0x66, 0x41, 0xdf, 0 };
861 static const char fA_sharps8[] = { 0x66, 0x41, (char)0xc3, (char)0x9f, 0 };
862 static const UChar fa_sharps16[] = { 0x66, 0x61, 0xdf, 0 };
863 static const char fa_sharps8[] = { 0x66, 0x61, (char)0xc3, (char)0x9f, 0 };
864 static const UChar fass16[] = { 0x66, 0x61, 0x73, 0x73, 0 };
865 static const char fass8[] = { 0x66, 0x61, 0x73, 0x73, 0 };
866 static const UChar fA_BEL[] = { 0x66, 0x41, 7, 0 };
867 static const UChar fa_FFFD[] = { 0x66, 0x61, 0xfffd, 0 };
868
869 UChar dest16[10];
870 char dest8[10];
871 int32_t length;
872
873 UIDNAInfo info = UIDNA_INFO_INITIALIZER;
874 UErrorCode errorCode = U_ZERO_ERROR;
875 UIDNA *uts46 = uidna_openUTS46(UIDNA_USE_STD3_RULES|UIDNA_NONTRANSITIONAL_TO_UNICODE,
876 &errorCode);
877 if(U_FAILURE(errorCode)) {
878 log_err_status(errorCode, "uidna_openUTS46() failed: %s\n", u_errorName(errorCode));
879 return;
880 }
881
882 /* These calls should succeed. */
883 length = uidna_labelToASCII(uts46, fA_sharps16, -1,
884 dest16, UPRV_LENGTHOF(dest16), &info, &errorCode);
885 if( U_FAILURE(errorCode) || length != 4 || 0 != u_memcmp(dest16, fass16, 5) ||
886 !info.isTransitionalDifferent || info.errors != 0
887 ) {
888 log_err("uidna_labelToASCII() failed: %s\n", u_errorName(errorCode));
889 }
890 errorCode = U_ZERO_ERROR;
891 length = uidna_labelToUnicode(uts46, fA_sharps16, u_strlen(fA_sharps16),
892 dest16, UPRV_LENGTHOF(dest16), &info, &errorCode);
893 if( U_FAILURE(errorCode) || length != 3 || 0 != u_memcmp(dest16, fa_sharps16, 4) ||
894 !info.isTransitionalDifferent || info.errors != 0
895 ) {
896 log_err("uidna_labelToUnicode() failed: %s\n", u_errorName(errorCode));
897 }
898 errorCode = U_ZERO_ERROR;
899 length = uidna_nameToASCII(uts46, fA_sharps16, u_strlen(fA_sharps16),
900 dest16, 4, &info, &errorCode);
901 if( errorCode != U_STRING_NOT_TERMINATED_WARNING ||
902 length != 4 || 0 != u_memcmp(dest16, fass16, 4) ||
903 !info.isTransitionalDifferent || info.errors != 0
904 ) {
905 log_err("uidna_nameToASCII() failed: %s\n", u_errorName(errorCode));
906 }
907 errorCode = U_ZERO_ERROR;
908 length = uidna_nameToUnicode(uts46, fA_sharps16, -1,
909 dest16, 3, &info, &errorCode);
910 if( errorCode != U_STRING_NOT_TERMINATED_WARNING ||
911 length != 3 || 0 != u_memcmp(dest16, fa_sharps16, 3) ||
912 !info.isTransitionalDifferent || info.errors != 0
913 ) {
914 log_err("uidna_nameToUnicode() failed: %s\n", u_errorName(errorCode));
915 }
916
917 errorCode = U_ZERO_ERROR;
918 length = uidna_labelToASCII_UTF8(uts46, fA_sharps8, -1,
919 dest8, UPRV_LENGTHOF(dest8), &info, &errorCode);
920 if( U_FAILURE(errorCode) || length != 4 || 0 != memcmp(dest8, fass8, 5) ||
921 !info.isTransitionalDifferent || info.errors != 0
922 ) {
923 log_err("uidna_labelToASCII_UTF8() failed: %s\n", u_errorName(errorCode));
924 }
925 errorCode = U_ZERO_ERROR;
926 length = uidna_labelToUnicodeUTF8(uts46, fA_sharps8, (int32_t)strlen(fA_sharps8),
927 dest8, UPRV_LENGTHOF(dest8), &info, &errorCode);
928 if( U_FAILURE(errorCode) || length != 4 || 0 != memcmp(dest8, fa_sharps8, 5) ||
929 !info.isTransitionalDifferent || info.errors != 0
930 ) {
931 log_err("uidna_labelToUnicodeUTF8() failed: %s\n", u_errorName(errorCode));
932 }
933 errorCode = U_ZERO_ERROR;
934 length = uidna_nameToASCII_UTF8(uts46, fA_sharps8, (int32_t)strlen(fA_sharps8),
935 dest8, 4, &info, &errorCode);
936 if( errorCode != U_STRING_NOT_TERMINATED_WARNING ||
937 length != 4 || 0 != memcmp(dest8, fass8, 4) ||
938 !info.isTransitionalDifferent || info.errors != 0
939 ) {
940 log_err("uidna_nameToASCII_UTF8() failed: %s\n", u_errorName(errorCode));
941 }
942 errorCode = U_ZERO_ERROR;
943 length = uidna_nameToUnicodeUTF8(uts46, fA_sharps8, -1,
944 dest8, 4, &info, &errorCode);
945 if( errorCode != U_STRING_NOT_TERMINATED_WARNING ||
946 length != 4 || 0 != memcmp(dest8, fa_sharps8, 4) ||
947 !info.isTransitionalDifferent || info.errors != 0
948 ) {
949 log_err("uidna_nameToUnicodeUTF8() failed: %s\n", u_errorName(errorCode));
950 }
951
952 errorCode = U_ZERO_ERROR;
953 length = uidna_nameToASCII(uts46, NULL, 0,
954 dest16, 0, &info, &errorCode);
955 if( errorCode != U_STRING_NOT_TERMINATED_WARNING ||
956 length != 0 ||
957 info.isTransitionalDifferent || info.errors != UIDNA_ERROR_EMPTY_LABEL
958 ) {
959 log_err("uidna_nameToASCII(empty) failed: %s\n", u_errorName(errorCode));
960 }
961 errorCode = U_ZERO_ERROR;
962 length = uidna_nameToUnicode(uts46, fA_BEL, -1,
963 dest16, 3, &info, &errorCode);
964 if( errorCode != U_STRING_NOT_TERMINATED_WARNING ||
965 length != 3 || 0 != u_memcmp(dest16, fa_FFFD, 3) ||
966 info.isTransitionalDifferent || info.errors == 0
967 ) {
968 log_err("uidna_nameToUnicode(fa<BEL>) failed: %s\n", u_errorName(errorCode));
969 }
970
971 /* These calls should fail. */
972 errorCode = U_USELESS_COLLATOR_ERROR;
973 length = uidna_labelToASCII(uts46, fA_sharps16, -1,
974 dest16, UPRV_LENGTHOF(dest16), &info, &errorCode);
975 if(errorCode != U_USELESS_COLLATOR_ERROR) {
976 log_err("uidna_labelToASCII(failure) failed: %s\n", u_errorName(errorCode));
977 }
978 errorCode = U_ZERO_ERROR;
979 length = uidna_labelToUnicode(uts46, fA_sharps16, u_strlen(fA_sharps16),
980 dest16, UPRV_LENGTHOF(dest16), NULL, &errorCode);
981 if(errorCode != U_ILLEGAL_ARGUMENT_ERROR) {
982 log_err("uidna_labelToUnicode(UIDNAInfo=NULL) failed: %s\n", u_errorName(errorCode));
983 }
984 errorCode = U_ZERO_ERROR;
985 length = uidna_nameToASCII(uts46, NULL, u_strlen(fA_sharps16),
986 dest16, 4, &info, &errorCode);
987 if(errorCode != U_ILLEGAL_ARGUMENT_ERROR) {
988 log_err("uidna_nameToASCII(src=NULL) failed: %s\n", u_errorName(errorCode));
989 }
990 errorCode = U_ZERO_ERROR;
991 length = uidna_nameToUnicode(uts46, fA_sharps16, -2,
992 dest16, 3, &info, &errorCode);
993 if(errorCode != U_ILLEGAL_ARGUMENT_ERROR) {
994 log_err("uidna_nameToUnicode(length<-1) failed: %s\n", u_errorName(errorCode));
995 }
996
997 errorCode = U_ZERO_ERROR;
998 length = uidna_labelToASCII_UTF8(uts46, fA_sharps8, -1,
999 NULL, UPRV_LENGTHOF(dest8), &info, &errorCode);
1000 if(errorCode != U_ILLEGAL_ARGUMENT_ERROR) {
1001 log_err("uidna_labelToASCII_UTF8(dest=NULL) failed: %s\n", u_errorName(errorCode));
1002 }
1003 errorCode = U_ZERO_ERROR;
1004 length = uidna_labelToUnicodeUTF8(uts46, fA_sharps8, (int32_t)strlen(fA_sharps8),
1005 dest8, -1, &info, &errorCode);
1006 if(errorCode != U_ILLEGAL_ARGUMENT_ERROR) {
1007 log_err("uidna_labelToUnicodeUTF8(capacity<0) failed: %s\n", u_errorName(errorCode));
1008 }
1009 errorCode = U_ZERO_ERROR;
1010 length = uidna_nameToASCII_UTF8(uts46, dest8, (int32_t)strlen(fA_sharps8),
1011 dest8, 4, &info, &errorCode);
1012 if(errorCode != U_ILLEGAL_ARGUMENT_ERROR) {
1013 log_err("uidna_nameToASCII_UTF8(src==dest!=NULL) failed: %s\n", u_errorName(errorCode));
1014 }
1015 errorCode = U_ZERO_ERROR;
1016 length = uidna_nameToUnicodeUTF8(uts46, fA_sharps8, -1,
1017 dest8, 3, &info, &errorCode);
1018 if(errorCode != U_BUFFER_OVERFLOW_ERROR || length != 4) {
1019 log_err("uidna_nameToUnicodeUTF8() overflow failed: %s\n", u_errorName(errorCode));
1020 }
1021
1022 uidna_close(uts46);
1023 }
1024
1025 #endif
1026
1027 /*
1028 * Hey, Emacs, please set the following:
1029 *
1030 * Local Variables:
1031 * indent-tabs-mode: nil
1032 * End:
1033 *
1034 */
1035