]> git.saurik.com Git - apple/icu.git/blob - icuSources/test/cintltst/utexttst.c
ICU-511.25.tar.gz
[apple/icu.git] / icuSources / test / cintltst / utexttst.c
1 /********************************************************************
2 * COPYRIGHT:
3 * Copyright (c) 2005-2011, International Business Machines Corporation and
4 * others. All Rights Reserved.
5 ********************************************************************/
6 /*
7 * File utexttst.c
8 *
9 * Modification History:
10 *
11 * Date Name Description
12 * 06/13/2005 Andy Heninger Creation
13 *******************************************************************************
14 */
15
16 #include "unicode/utypes.h"
17 #include "unicode/utext.h"
18 #include "unicode/ustring.h"
19 #include "cintltst.h"
20 #include "memory.h"
21 #include "string.h"
22
23
24 static void TestAPI(void);
25 void addUTextTest(TestNode** root);
26
27
28 void
29 addUTextTest(TestNode** root)
30 {
31 addTest(root, &TestAPI , "tsutil/UTextTest/TestAPI");
32 }
33
34
35 #define TEST_ASSERT(x) \
36 {if ((x)==FALSE) {log_err("Test failure in file %s at line %d\n", __FILE__, __LINE__);\
37 gFailed = TRUE;\
38 }}
39
40
41 #define TEST_SUCCESS(status) \
42 {if (U_FAILURE(status)) {log_err("Test failure in file %s at line %d. Error = \"%s\"\n", \
43 __FILE__, __LINE__, u_errorName(status)); \
44 gFailed = TRUE;\
45 }}
46
47
48
49 /*
50 * TestAPI verify that the UText API is accessible from C programs.
51 * This is not intended to be a complete test of the API functionality. That is
52 * in the C++ intltest program.
53 * This test is intended to check that everything can be accessed and built in
54 * a pure C enviornment.
55 */
56
57
58 static void TestAPI(void) {
59 UErrorCode status = U_ZERO_ERROR;
60 UBool gFailed = FALSE;
61
62 /* Open */
63 {
64 UText utLoc = UTEXT_INITIALIZER;
65 const char * cString = "\x61\x62\x63\x64";
66 UChar uString[] = {0x41, 0x42, 0x43, 0};
67 UText *uta;
68 UText *utb;
69 UChar c;
70
71 uta = utext_openUChars(NULL, uString, -1, &status);
72 TEST_SUCCESS(status);
73 c = utext_next32(uta);
74 TEST_ASSERT(c == 0x41);
75 utb = utext_close(uta);
76 TEST_ASSERT(utb == NULL);
77
78 uta = utext_openUTF8(&utLoc, cString, -1, &status);
79 TEST_SUCCESS(status);
80 TEST_ASSERT(uta == &utLoc);
81
82 uta = utext_close(&utLoc);
83 TEST_ASSERT(uta == &utLoc);
84 }
85
86 /* utext_clone() */
87 {
88 UChar uString[] = {0x41, 0x42, 0x43, 0};
89 int64_t len;
90 UText *uta;
91 UText *utb;
92
93 status = U_ZERO_ERROR;
94 uta = utext_openUChars(NULL, uString, -1, &status);
95 TEST_SUCCESS(status);
96 utb = utext_clone(NULL, uta, FALSE, FALSE, &status);
97 TEST_SUCCESS(status);
98 TEST_ASSERT(utb != NULL);
99 TEST_ASSERT(utb != uta);
100 len = utext_nativeLength(uta);
101 TEST_ASSERT(len == u_strlen(uString));
102 utext_close(uta);
103 utext_close(utb);
104 }
105
106 /* basic access functions */
107 {
108 UChar uString[] = {0x41, 0x42, 0x43, 0};
109 UText *uta;
110 UChar32 c;
111 int64_t len;
112 UBool b;
113 int64_t i;
114
115 status = U_ZERO_ERROR;
116 uta = utext_openUChars(NULL, uString, -1, &status);
117 TEST_ASSERT(uta!=NULL);
118 TEST_SUCCESS(status);
119 b = utext_isLengthExpensive(uta);
120 TEST_ASSERT(b==TRUE);
121 len = utext_nativeLength(uta);
122 TEST_ASSERT(len == u_strlen(uString));
123 b = utext_isLengthExpensive(uta);
124 TEST_ASSERT(b==FALSE);
125
126 c = utext_char32At(uta, 0);
127 TEST_ASSERT(c==uString[0]);
128
129 c = utext_current32(uta);
130 TEST_ASSERT(c==uString[0]);
131
132 c = utext_next32(uta);
133 TEST_ASSERT(c==uString[0]);
134 c = utext_current32(uta);
135 TEST_ASSERT(c==uString[1]);
136
137 c = utext_previous32(uta);
138 TEST_ASSERT(c==uString[0]);
139 c = utext_current32(uta);
140 TEST_ASSERT(c==uString[0]);
141
142 c = utext_next32From(uta, 1);
143 TEST_ASSERT(c==uString[1]);
144 c = utext_next32From(uta, u_strlen(uString));
145 TEST_ASSERT(c==U_SENTINEL);
146
147 c = utext_previous32From(uta, 2);
148 TEST_ASSERT(c==uString[1]);
149 i = utext_getNativeIndex(uta);
150 TEST_ASSERT(i == 1);
151
152 utext_setNativeIndex(uta, 0);
153 b = utext_moveIndex32(uta, 1);
154 TEST_ASSERT(b==TRUE);
155 i = utext_getNativeIndex(uta);
156 TEST_ASSERT(i==1);
157
158 b = utext_moveIndex32(uta, u_strlen(uString)-1);
159 TEST_ASSERT(b==TRUE);
160 i = utext_getNativeIndex(uta);
161 TEST_ASSERT(i==u_strlen(uString));
162
163 b = utext_moveIndex32(uta, 1);
164 TEST_ASSERT(b==FALSE);
165 i = utext_getNativeIndex(uta);
166 TEST_ASSERT(i==u_strlen(uString));
167
168 utext_setNativeIndex(uta, 0);
169 c = UTEXT_NEXT32(uta);
170 TEST_ASSERT(c==uString[0]);
171 c = utext_current32(uta);
172 TEST_ASSERT(c==uString[1]);
173
174 c = UTEXT_PREVIOUS32(uta);
175 TEST_ASSERT(c==uString[0]);
176 c = UTEXT_PREVIOUS32(uta);
177 TEST_ASSERT(c==U_SENTINEL);
178
179
180 utext_close(uta);
181 }
182
183 {
184 /*
185 * UText opened on a NULL string with zero length
186 */
187 UText *uta;
188 UChar32 c;
189
190 status = U_ZERO_ERROR;
191 uta = utext_openUChars(NULL, NULL, 0, &status);
192 TEST_SUCCESS(status);
193 c = UTEXT_NEXT32(uta);
194 TEST_ASSERT(c == U_SENTINEL);
195 utext_close(uta);
196
197 uta = utext_openUTF8(NULL, NULL, 0, &status);
198 TEST_SUCCESS(status);
199 c = UTEXT_NEXT32(uta);
200 TEST_ASSERT(c == U_SENTINEL);
201 utext_close(uta);
202 }
203
204
205 {
206 /*
207 * extract
208 */
209 UText *uta;
210 UChar uString[] = {0x41, 0x42, 0x43, 0};
211 UChar buf[100];
212 int32_t i;
213 /* Test pinning of input bounds */
214 UChar uString2[] = {0x41, 0x42, 0x43, 0x44, 0x45,
215 0x46, 0x47, 0x48, 0x49, 0x4A, 0};
216 UChar * uString2Ptr = uString2 + 5;
217
218 status = U_ZERO_ERROR;
219 uta = utext_openUChars(NULL, uString, -1, &status);
220 TEST_SUCCESS(status);
221
222 status = U_ZERO_ERROR;
223 i = utext_extract(uta, 0, 100, NULL, 0, &status);
224 TEST_ASSERT(status==U_BUFFER_OVERFLOW_ERROR);
225 TEST_ASSERT(i == u_strlen(uString));
226
227 status = U_ZERO_ERROR;
228 memset(buf, 0, sizeof(buf));
229 i = utext_extract(uta, 0, 100, buf, 100, &status);
230 TEST_SUCCESS(status);
231 TEST_ASSERT(i == u_strlen(uString));
232 i = u_strcmp(uString, buf);
233 TEST_ASSERT(i == 0);
234 utext_close(uta);
235
236 /* Test pinning of input bounds */
237 status = U_ZERO_ERROR;
238 uta = utext_openUChars(NULL, uString2Ptr, -1, &status);
239 TEST_SUCCESS(status);
240
241 status = U_ZERO_ERROR;
242 memset(buf, 0, sizeof(buf));
243 i = utext_extract(uta, -3, 20, buf, 100, &status);
244 TEST_SUCCESS(status);
245 TEST_ASSERT(i == u_strlen(uString2Ptr));
246 i = u_strcmp(uString2Ptr, buf);
247 TEST_ASSERT(i == 0);
248 utext_close(uta);
249 }
250
251 {
252 /*
253 * Copy, Replace, isWritable
254 * Can't create an editable UText from plain C, so all we
255 * can easily do is check that errors returned.
256 */
257 UText *uta;
258 UChar uString[] = {0x41, 0x42, 0x43, 0};
259 UBool b;
260
261 status = U_ZERO_ERROR;
262 uta = utext_openUChars(NULL, uString, -1, &status);
263 TEST_SUCCESS(status);
264
265 b = utext_isWritable(uta);
266 TEST_ASSERT(b == FALSE);
267
268 b = utext_hasMetaData(uta);
269 TEST_ASSERT(b == FALSE);
270
271 utext_replace(uta,
272 0, 1, /* start, limit */
273 uString, -1, /* replacement, replacement length */
274 &status);
275 TEST_ASSERT(status == U_NO_WRITE_PERMISSION);
276
277
278 utext_copy(uta,
279 0, 1, /* start, limit */
280 2, /* destination index */
281 FALSE, /* move flag */
282 &status);
283 TEST_ASSERT(status == U_NO_WRITE_PERMISSION);
284
285 utext_close(uta);
286 }
287
288
289 }
290