OLD | NEW |
| (Empty) |
1 /******************************************************************** | |
2 * COPYRIGHT: | |
3 * Copyright (c) 1997-2009, International Business Machines Corporation and | |
4 * others. All Rights Reserved. | |
5 ********************************************************************/ | |
6 | |
7 #include "unicode/utypes.h" | |
8 | |
9 #if !UCONFIG_NO_COLLATION | |
10 | |
11 #include "unicode/coll.h" | |
12 #include "unicode/tblcoll.h" | |
13 #include "unicode/unistr.h" | |
14 #include "unicode/sortkey.h" | |
15 #include "allcoll.h" | |
16 #include "sfwdchit.h" | |
17 #include "../cintltst/calldata.h" | |
18 | |
19 | |
20 CollationDummyTest::CollationDummyTest() | |
21 : myCollation(0) | |
22 { | |
23 /*UErrorCode status = U_ZERO_ERROR; | |
24 UnicodeString rules(TRUE, DEFAULTRULEARRAY, sizeof(DEFAULTRULEARRAY)/sizeof(
DEFAULTRULEARRAY[0])); | |
25 UnicodeString newRules("& C < ch, cH, Ch, CH & Five, 5 & Four, 4 & one, 1 &
Ampersand; '&' & Two, 2 "); | |
26 rules += newRules; | |
27 myCollation = new RuleBasedCollator(rules, status); | |
28 */ | |
29 | |
30 UErrorCode status = U_ZERO_ERROR; | |
31 UnicodeString ruleset("& C < ch, cH, Ch, CH & Five, 5 & Four, 4 & one, 1 & A
mpersand; '&' & Two, 2 "); | |
32 if (myCollation != NULL) | |
33 { | |
34 delete myCollation; | |
35 } | |
36 myCollation = new RuleBasedCollator(ruleset, status); | |
37 if(U_FAILURE(status)){ | |
38 errcheckln(status, "ERROR: in creation of rule based collator from rules
et - %s", u_errorName(status)); | |
39 delete myCollation; | |
40 myCollation = 0; | |
41 } | |
42 } | |
43 | |
44 CollationDummyTest::~CollationDummyTest() | |
45 { | |
46 delete myCollation; | |
47 } | |
48 | |
49 const Collator::EComparisonResult CollationDummyTest::results[] = { | |
50 Collator::LESS, | |
51 Collator::LESS, /*Collator::GREATER,*/ | |
52 Collator::LESS, | |
53 Collator::LESS, | |
54 Collator::LESS, | |
55 Collator::LESS, | |
56 Collator::LESS, | |
57 Collator::GREATER, | |
58 Collator::GREATER, | |
59 Collator::LESS, /* 10 */ | |
60 Collator::GREATER, | |
61 Collator::LESS, | |
62 Collator::GREATER, | |
63 Collator::GREATER, | |
64 Collator::LESS, | |
65 Collator::LESS, | |
66 Collator::LESS, | |
67 /* test primary > 17 */ | |
68 Collator::EQUAL, | |
69 Collator::EQUAL, | |
70 Collator::EQUAL, /* 20 */ | |
71 Collator::LESS, | |
72 Collator::LESS, | |
73 Collator::EQUAL, | |
74 Collator::EQUAL, | |
75 Collator::EQUAL, | |
76 Collator::LESS, | |
77 /* test secondary > 26 */ | |
78 Collator::EQUAL, | |
79 Collator::EQUAL, | |
80 Collator::EQUAL, | |
81 Collator::EQUAL, | |
82 Collator::EQUAL, /* 30 */ | |
83 Collator::EQUAL, | |
84 Collator::LESS, | |
85 Collator::EQUAL, /* 34 */ | |
86 Collator::EQUAL, | |
87 Collator::EQUAL, | |
88 Collator::LESS | |
89 }; | |
90 | |
91 | |
92 void CollationDummyTest::TestTertiary(/* char* par */) | |
93 { | |
94 int32_t i = 0; | |
95 myCollation->setStrength(Collator::TERTIARY); | |
96 for (i = 0; i < 17 ; i++) | |
97 { | |
98 doTest(myCollation, testSourceCases[i], testTargetCases[i], results[i]); | |
99 } | |
100 } | |
101 void CollationDummyTest::TestPrimary(/* char* par */) | |
102 { | |
103 /* problem in strcollinc for unfinshed contractions */ | |
104 UErrorCode status = U_ZERO_ERROR; | |
105 | |
106 myCollation->setAttribute(UCOL_NORMALIZATION_MODE, UCOL_ON, status); | |
107 myCollation->setStrength(Collator::PRIMARY); | |
108 | |
109 if (U_FAILURE(status)) | |
110 { | |
111 errln("Failure in setting attribute for normalization mode\n"); | |
112 } | |
113 | |
114 for (int i = 17; i < 26 ; i++) | |
115 { | |
116 doTest(myCollation, testSourceCases[i], testTargetCases[i], results[i]); | |
117 } | |
118 } | |
119 | |
120 void CollationDummyTest::TestSecondary(/* char* par */) | |
121 { | |
122 int32_t i; | |
123 myCollation->setStrength(Collator::SECONDARY); | |
124 for (i = 26; i < 34; i++) | |
125 { | |
126 doTest(myCollation, testSourceCases[i], testTargetCases[i], results[i]); | |
127 } | |
128 } | |
129 | |
130 void CollationDummyTest::TestExtra(/* char* par */) | |
131 { | |
132 int32_t i, j; | |
133 myCollation->setStrength(Collator::TERTIARY); | |
134 for (i = 0; i < COUNT_TEST_CASES-1; i++) | |
135 { | |
136 for (j = i + 1; j < COUNT_TEST_CASES; j += 1) | |
137 { | |
138 doTest(myCollation, testCases[i], testCases[j], Collator::LESS); | |
139 } | |
140 } | |
141 } | |
142 | |
143 void CollationDummyTest::TestIdentical() | |
144 { | |
145 int32_t i; | |
146 myCollation->setStrength(Collator::IDENTICAL); | |
147 for (i= 34; i<37; i++) | |
148 { | |
149 doTest(myCollation, testSourceCases[i], testTargetCases[i], results[i]); | |
150 } | |
151 } | |
152 | |
153 void CollationDummyTest::TestJB581(void) | |
154 { | |
155 UErrorCode status = U_ZERO_ERROR; | |
156 | |
157 UnicodeString source("THISISATEST."); | |
158 UnicodeString target("Thisisatest."); | |
159 | |
160 Collator *coll = Collator::createInstance("en_US", status); | |
161 if (U_FAILURE(status)){ | |
162 errln("ERROR: Failed to create the collator for : en_US\n"); | |
163 return; | |
164 } | |
165 | |
166 Collator::EComparisonResult result = coll->compare(source, target); | |
167 /* result is 1, secondary differences only for ignorable space characters*/ | |
168 if (result != 1) | |
169 { | |
170 errln("Comparing two strings with only secondary differences in C failed
.\n"); | |
171 } | |
172 /* To compare them with just primary differences */ | |
173 coll->setStrength(Collator::PRIMARY); | |
174 result = coll->compare(source, target); | |
175 /* result is 0 */ | |
176 if (result != 0) | |
177 { | |
178 errln("Comparing two strings with no differences in C failed.\n"); | |
179 } | |
180 /* Now, do the same comparison with keys */ | |
181 CollationKey sourceKeyOut, | |
182 targetKeyOut; | |
183 coll->getCollationKey(source, sourceKeyOut, status); | |
184 coll->getCollationKey(target, targetKeyOut, status); | |
185 result = sourceKeyOut.compareTo(targetKeyOut); | |
186 if (result != 0) | |
187 { | |
188 errln("Comparing two strings with sort keys in C failed.\n"); | |
189 } | |
190 delete coll; | |
191 } | |
192 | |
193 void CollationDummyTest::runIndexedTest( int32_t index, UBool exec, const char*
&name, char* /*par*/ ) | |
194 { | |
195 if (exec) logln("TestSuite CollationDummyTest: "); | |
196 if(myCollation) { | |
197 switch (index) { | |
198 case 0: name = "TestPrimary"; if (exec) TestPrimary(/* par */); br
eak; | |
199 case 1: name = "TestSecondary"; if (exec) TestSecondary(/* par */);
break; | |
200 case 2: name = "TestTertiary"; if (exec) TestTertiary(/* par */); b
reak; | |
201 case 3: name = "TestExtra"; if (exec) TestExtra(/* par */); brea
k; | |
202 case 4: name = "TestIdentical"; if (exec) TestIdentical(/* par */);
break; | |
203 case 5: name = "TestJB581"; if (exec) TestJB581(/* par */); brea
k; | |
204 default: name = ""; break; | |
205 } | |
206 } else { | |
207 dataerrln("Collator couldn't be instantiated!"); | |
208 name = ""; | |
209 } | |
210 } | |
211 | |
212 #endif /* #if !UCONFIG_NO_COLLATION */ | |
OLD | NEW |