malloc/Makefile: Split and sort tests
[glibc.git] / localedata / tests-mbwc / dat_strcoll.c
blobb729ae9e894a3757c3c1e571c6304756fa70517c
1 /*
2 * TEST SUITE FOR MB/WC FUNCTIONS IN C LIBRARY
4 * FILE: dat_strcoll.c
6 * STRCOLL: int strcoll (const char *s1, const char *s2);
7 */
9 /*
10 NOTE:
12 If a return value is expected to be 0, set ret_flg=1 and the
13 expected value = 0. If a return value is expected to be a
14 positive/negative value, set ret_flg=0, and set the expected value
15 = +1/-1.
16 There is inconsistensy between tst_strcoll() and tst_wcscoll()(it
17 has cmp_flg) for input data. I'll fix it.
19 Assuming en_US to be en_US.ascii. (maybe, should be iso8859-1).
23 ASCII CODE : A,B,C, ... , a, b, c, ... B,a:-1 a,B:+1
24 DICTIONARY : A,a,B,b,C,c,.... a,B:-1 B,a:+1 */
26 TST_STRCOLL tst_strcoll_loc [] = {
28 { Tstrcoll, TST_LOC_de },
30 { /*input.*/ { "ÄBCDEFG", "ÄBCDEFG" }, /* #1 */
31 /*expect*/ { 0,1,0, },
33 { /*input.*/ { "XX Ä XX", "XX B XX" }, /* #2 */
34 /*expect*/ { 0,0,-1, },
36 { /*input.*/ { "XX B XX", "XX Ä XX" }, /* #3 */
37 /*expect*/ { 0,0,+1, },
39 { /*input.*/ { "B", "a" }, /* #4 */
40 /*expect*/ { 0,0,+1, },
42 { /*input.*/ { "a", "B" }, /* #5 */
43 /*expect*/ { 0,0,-1, },
45 { /*input.*/ { "b", "A" }, /* #6 */
46 /*expect*/ { 0,0,+1, },
48 { /*input.*/ { "A", "b" }, /* #7 */
49 /*expect*/ { 0,0,-1, },
51 { /*input.*/ { "ä", "B" }, /* #8 */
52 /*expect*/ { 0,0,-1, },
54 { /*input.*/ { "B", "ä" }, /* #9 */
55 /*expect*/ { 0,0,+1, },
57 { .is_last = 1 } /* Last element. */
61 { Tstrcoll, TST_LOC_enUS },
63 { /*input.*/ { "ABCDEFG", "ABCDEFG" }, /* #1 */
64 /*expect*/ { 0,1,0, },
66 { /*input.*/ { "XX a XX", "XX B XX" }, /* #2 */
67 /*expect*/ { 0,0,-1, },
69 { /*input.*/ { "XX B XX", "XX a XX" }, /* #3 */
70 /*expect*/ { 0,0,+1, },
73 /* <WAIVER> */
74 /*input.*/ { "B", "a" }, /* #4 */
75 /* XXX We are not testing the C locale. */
76 /*expect*/ { 0,0,+1, },
79 /* <WAIVER> */
80 /*input.*/ { "a", "B" }, /* #5 */
81 /* XXX We are not testing the C locale. */
82 /*expect*/ { 0,0,-1, },
84 { /*input.*/ { "b", "A" }, /* #6 */
85 /*expect*/ { 0,0,+1, },
87 { /*input.*/ { "A", "b" }, /* #7 */
88 /*expect*/ { 0,0,-1, },
90 #ifdef NO_WAIVER
91 /* XXX I do not yet know whether strcoll really should reject
92 characters outside the multibyte character range. */
94 /* #8 */ /* <WAIVER> */
95 /*input.*/ { "\244\242\244\244\244\246\244\250\244\252", "ABCDEFG" },
96 /*expect*/ { EINVAL,0,0, },
99 /* #9 */ /* <WAIVER> */
100 /*input.*/ { "ABCZEFG", "\244\242\244\244\244\246\244\250\244\252" },
101 /*expect*/ { EINVAL,0,0, },
103 #endif
104 { .is_last = 1 } /* Last element. */
108 { Tstrcoll, TST_LOC_eucJP },
110 { /*input.*/ { "\244\242\244\244\244\246\244\250\244\252",
111 "\244\242\244\244\244\246\244\250\244\252" }, /* #1 */
112 /*expect*/ { 0,1,0, },
114 { /*input.*/ { "\244\242\244\244\244\246\244\250\244\252",
115 "\244\242\244\244\244\363\244\250\244\252" }, /* #2 */
116 /*expect*/ { 0,0,-1, },
118 { /*input.*/ { "\244\242\244\244\244\363\244\250\244\252",
119 "\244\242\244\244\244\246\244\250\244\252" }, /* #3 */
120 /*expect*/ { 0,0,+1, },
122 { /*input.*/ { "B", "a" }, /* #4 */
123 /*expect*/ { 0,0,-1, },
125 { /*input.*/ { "a", "B" }, /* #5 */
126 /*expect*/ { 0,0,+1, },
128 { /*input.*/ { "b", "A" }, /* #6 */
129 /*expect*/ { 0,0,+1, },
131 { /*input.*/ { "A", "b" }, /* #7 */
132 /*expect*/ { 0,0,-1, },
134 #ifdef NO_WAIVER
135 /* XXX I do not yet know whether strcoll really should reject
136 characters outside the multibyte character range. */
138 /* <WAIVER> */
139 /*input.*/ { "\200\216\217", "ABCDEFG" }, /* #8 */
140 /*expect*/ { EINVAL,0,0, },
143 /* <WAIVER> */
144 /*input.*/ { "ABCZEFG", "\200\216\217" }, /* #9 */
145 /*expect*/ { EINVAL,0,0, },
147 #endif
148 { .is_last = 1 } /* Last element. */
152 { Tstrcoll, TST_LOC_end }