1
/********************************************************************
3
* Copyright (c) 1997-2001, International Business Machines Corporation and
4
* others. All Rights Reserved.
5
********************************************************************/
7
#include "unicode/coll.h"
8
#include "unicode/tblcoll.h"
9
#include "unicode/unistr.h"
10
#include "unicode/sortkey.h"
15
* Include callcoll.c to get the test data.
16
* This helps maintain a single copy of the data.
18
#define INCLUDE_CALLCOLL_C
19
#include "../cintltst/callcoll.c"
21
CollationDummyTest::CollationDummyTest()
24
/*UErrorCode status = U_ZERO_ERROR;
25
UnicodeString rules(TRUE, DEFAULTRULEARRAY, sizeof(DEFAULTRULEARRAY)/sizeof(DEFAULTRULEARRAY[0]));
26
UnicodeString newRules("& C < ch, cH, Ch, CH & Five, 5 & Four, 4 & one, 1 & Ampersand; '&' & Two, 2 ");
28
myCollation = new RuleBasedCollator(rules, status);
31
UErrorCode status = U_ZERO_ERROR;
32
UnicodeString ruleset("& C < ch, cH, Ch, CH & Five, 5 & Four, 4 & one, 1 & Ampersand; '&' & Two, 2 ");
33
if (myCollation != NULL)
37
myCollation = new RuleBasedCollator(ruleset, status);
38
if(U_FAILURE(status)){
39
errln("ERROR: in creation of rule based collator from ruleset");
43
CollationDummyTest::~CollationDummyTest()
48
const Collator::EComparisonResult CollationDummyTest::results[] = {
50
Collator::LESS, /*Collator::GREATER,*/
58
Collator::LESS, /* 10 */
66
/* test primary > 17 */
69
Collator::EQUAL, /* 20 */
76
/* test secondary > 26 */
81
Collator::EQUAL, /* 30 */
84
Collator::EQUAL, /* 34 */
91
CollationDummyTest::doTestVariant(const UnicodeString source, const UnicodeString target, Collator::EComparisonResult result)
93
UErrorCode status = U_ZERO_ERROR;
95
Collator::EComparisonResult compareResult = myCollation->compare(source, target);
97
CollationKey srckey, tgtkey;
98
myCollation->getCollationKey(source, srckey, status);
99
myCollation->getCollationKey(target, tgtkey, status);
100
if (U_FAILURE(status)){
101
errln("Creation of collation keys failed\n");
103
Collator::EComparisonResult keyResult = srckey.compareTo(tgtkey);
105
if (compareResult != result) {
106
errln("String comparison failed in variant test\n");
108
if (keyResult != result) {
109
errln("Collation key comparison failed in variant test\n");
113
void CollationDummyTest::doTest( UnicodeString source, UnicodeString target, Collator::EComparisonResult result)
116
Collator::EComparisonResult compareResult = myCollation->compare(source, target);
117
SimpleFwdCharIterator src(source);
118
SimpleFwdCharIterator trg(target);
119
Collator::EComparisonResult incResult = myCollation->compare(src, trg);
120
CollationKey sortKey1, sortKey2;
121
UErrorCode key1status = U_ZERO_ERROR, key2status = U_ZERO_ERROR; //nos
122
myCollation->getCollationKey(source, sortKey1, key1status );
123
myCollation->getCollationKey(target, sortKey2, key2status );
124
if (U_FAILURE(key1status) || U_FAILURE(key2status))
126
errln("SortKey generation Failed.\n");
130
Collator::EComparisonResult keyResult = sortKey1.compareTo(sortKey2);
131
reportCResult( source, target, sortKey1, sortKey2, compareResult, keyResult, incResult, result );
133
doTestVariant(source, target, result);
134
if(result == Collator::LESS) {
135
doTestVariant(target, source, Collator::GREATER);
136
} else if (result == Collator::GREATER) {
137
doTestVariant(target, source, Collator::LESS);
139
doTestVariant(target, source, Collator::EQUAL);
143
void CollationDummyTest::TestTertiary(/* char* par */)
146
myCollation->setStrength(Collator::TERTIARY);
147
for (i = 0; i < 17 ; i++)
149
doTest(testSourceCases[i], testTargetCases[i], results[i]);
152
void CollationDummyTest::TestPrimary(/* char* par */)
154
/* problem in strcollinc for unfinshed contractions */
155
UErrorCode status = U_ZERO_ERROR;
157
myCollation->setAttribute(UCOL_NORMALIZATION_MODE, UCOL_ON, status);
158
myCollation->setStrength(Collator::PRIMARY);
160
if (U_FAILURE(status))
162
errln("Failure in setting attribute for normalization mode\n");
165
for (int i = 17; i < 26 ; i++)
167
doTest(testSourceCases[i], testTargetCases[i], results[i]);
171
void CollationDummyTest::TestSecondary(/* char* par */)
174
myCollation->setStrength(Collator::SECONDARY);
175
for (i = 26; i < 34; i++)
177
doTest(testSourceCases[i], testTargetCases[i], results[i]);
181
void CollationDummyTest::TestExtra(/* char* par */)
184
myCollation->setStrength(Collator::TERTIARY);
185
for (i = 0; i < COUNT_TEST_CASES-1; i++)
187
for (j = i + 1; j < COUNT_TEST_CASES; j += 1)
189
doTest(testCases[i], testCases[j], Collator::LESS);
194
void CollationDummyTest::TestIdentical()
197
myCollation->setStrength(Collator::IDENTICAL);
198
for (i= 34; i<37; i++)
200
doTest(testSourceCases[i], testTargetCases[i], results[i]);
204
void CollationDummyTest::TestJB581(void)
206
UErrorCode status = U_ZERO_ERROR;
208
UnicodeString source("THISISATEST.");
209
UnicodeString target("Thisisatest.");
211
Collator *coll = Collator::createInstance("en_US", status);
212
if (U_FAILURE(status)){
213
errln("ERROR: Failed to create the collator for : en_US\n");
217
Collator::EComparisonResult result = coll->compare(source, target);
218
/* result is 1, secondary differences only for ignorable space characters*/
221
errln("Comparing two strings with only secondary differences in C failed.\n");
223
/* To compare them with just primary differences */
224
coll->setStrength(Collator::PRIMARY);
225
result = coll->compare(source, target);
229
errln("Comparing two strings with no differences in C failed.\n");
231
/* Now, do the same comparison with keys */
232
CollationKey sourceKeyOut,
234
coll->getCollationKey(source, sourceKeyOut, status);
235
coll->getCollationKey(target, targetKeyOut, status);
236
result = sourceKeyOut.compareTo(targetKeyOut);
239
errln("Comparing two strings with sort keys in C failed.\n");
244
void CollationDummyTest::runIndexedTest( int32_t index, UBool exec, const char* &name, char* /*par*/ )
246
if (exec) logln("TestSuite CollationDummyTest: ");
248
case 0: name = "TestPrimary"; if (exec) TestPrimary(/* par */); break;
249
case 1: name = "TestSecondary"; if (exec) TestSecondary(/* par */); break;
250
case 2: name = "TestTertiary"; if (exec) TestTertiary(/* par */); break;
251
case 3: name = "TestExtra"; if (exec) TestExtra(/* par */); break;
252
case 4: name = "TestIdentical"; if (exec) TestIdentical(/* par */); break;
253
case 5: name = "TestJB581"; if (exec) TestJB581(/* par */); break;
254
default: name = ""; break;