2000-01-15 02:00:06 +00:00
|
|
|
/********************************************************************
|
|
|
|
* COPYRIGHT:
|
|
|
|
* Copyright (c) 1997-1999, International Business Machines Corporation and
|
|
|
|
* others. All Rights Reserved.
|
|
|
|
********************************************************************/
|
1999-08-16 21:50:52 +00:00
|
|
|
|
|
|
|
#ifndef _COLL
|
1999-12-28 23:57:50 +00:00
|
|
|
#include "unicode/coll.h"
|
1999-08-16 21:50:52 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef _TBLCOLL
|
1999-12-28 23:57:50 +00:00
|
|
|
#include "unicode/tblcoll.h"
|
1999-08-16 21:50:52 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef _UNISTR
|
1999-12-28 23:57:50 +00:00
|
|
|
#include "unicode/unistr.h"
|
1999-08-16 21:50:52 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef _SORTKEY
|
1999-12-28 23:57:50 +00:00
|
|
|
#include "unicode/sortkey.h"
|
1999-08-16 21:50:52 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef _ALLCOLL
|
|
|
|
#include "allcoll.h"
|
|
|
|
#endif
|
|
|
|
|
2000-03-22 23:17:42 +00:00
|
|
|
/*
|
|
|
|
* Include callcoll.c to get the test data.
|
|
|
|
* This helps maintain a single copy of the data.
|
|
|
|
*/
|
|
|
|
#define INCLUDE_CALLCOLL_C
|
2000-08-14 23:35:57 +00:00
|
|
|
#ifndef __OS400__
|
2000-03-22 23:17:42 +00:00
|
|
|
#include "../cintltst/callcoll.c"
|
2000-08-14 23:35:57 +00:00
|
|
|
#else
|
|
|
|
#include "cintltst/callcoll.c"
|
|
|
|
#endif
|
1999-08-16 21:50:52 +00:00
|
|
|
|
|
|
|
CollationDummyTest::CollationDummyTest()
|
|
|
|
: myCollation(0)
|
|
|
|
{
|
1999-10-07 00:07:53 +00:00
|
|
|
UErrorCode status = U_ZERO_ERROR;
|
2000-06-29 19:42:17 +00:00
|
|
|
UnicodeString rules(TRUE, DEFAULTRULEARRAY, sizeof(DEFAULTRULEARRAY)/sizeof(DEFAULTRULEARRAY[0]));
|
1999-08-16 21:50:52 +00:00
|
|
|
UnicodeString newRules("& C < ch, cH, Ch, CH & Five, 5 & Four, 4 & one, 1 & Ampersand; '&' & Two, 2 ");
|
|
|
|
rules += newRules;
|
|
|
|
myCollation = new RuleBasedCollator(rules, status);
|
|
|
|
}
|
|
|
|
|
|
|
|
CollationDummyTest::~CollationDummyTest()
|
|
|
|
{
|
|
|
|
delete myCollation;
|
|
|
|
}
|
|
|
|
|
|
|
|
const Collator::EComparisonResult CollationDummyTest::results[] = {
|
|
|
|
Collator::LESS,
|
|
|
|
Collator::GREATER,
|
|
|
|
Collator::LESS,
|
|
|
|
Collator::LESS,
|
|
|
|
Collator::LESS,
|
|
|
|
Collator::LESS,
|
|
|
|
Collator::LESS,
|
|
|
|
Collator::GREATER,
|
|
|
|
Collator::GREATER,
|
|
|
|
Collator::LESS, // 10
|
|
|
|
Collator::GREATER,
|
|
|
|
Collator::LESS,
|
|
|
|
Collator::GREATER,
|
|
|
|
Collator::GREATER,
|
|
|
|
Collator::LESS,
|
|
|
|
Collator::LESS,
|
|
|
|
Collator::LESS,
|
|
|
|
// test primary > 17
|
|
|
|
Collator::EQUAL,
|
|
|
|
Collator::EQUAL,
|
|
|
|
Collator::EQUAL, // 20
|
|
|
|
Collator::LESS,
|
|
|
|
Collator::LESS,
|
|
|
|
Collator::EQUAL,
|
|
|
|
Collator::EQUAL,
|
|
|
|
Collator::EQUAL,
|
|
|
|
Collator::LESS,
|
|
|
|
// test secondary > 26
|
|
|
|
Collator::EQUAL,
|
|
|
|
Collator::EQUAL,
|
|
|
|
Collator::EQUAL,
|
|
|
|
Collator::EQUAL,
|
|
|
|
Collator::EQUAL, // 30
|
|
|
|
Collator::EQUAL,
|
|
|
|
Collator::LESS,
|
2000-03-22 23:17:42 +00:00
|
|
|
Collator::EQUAL, // 34
|
|
|
|
Collator::EQUAL,
|
|
|
|
Collator::EQUAL,
|
|
|
|
Collator::LESS /* 37 */
|
1999-08-16 21:50:52 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
void CollationDummyTest::doTest( UnicodeString source, UnicodeString target, Collator::EComparisonResult result)
|
|
|
|
{
|
|
|
|
Collator::EComparisonResult compareResult = myCollation->compare(source, target);
|
|
|
|
CollationKey sortKey1, sortKey2;
|
1999-10-07 00:07:53 +00:00
|
|
|
UErrorCode key1status = U_ZERO_ERROR, key2status = U_ZERO_ERROR; //nos
|
1999-08-16 21:50:52 +00:00
|
|
|
myCollation->getCollationKey(source, /*nos*/ sortKey1, key1status );
|
|
|
|
myCollation->getCollationKey(target, /*nos*/ sortKey2, key2status );
|
1999-10-18 22:48:32 +00:00
|
|
|
if (U_FAILURE(key1status) || U_FAILURE(key2status))
|
1999-08-16 21:50:52 +00:00
|
|
|
{
|
|
|
|
errln("SortKey generation Failed.\n");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
Collator::EComparisonResult keyResult = sortKey1.compareTo(sortKey2);
|
|
|
|
reportCResult( source, target, sortKey1, sortKey2, compareResult, keyResult, result );
|
|
|
|
}
|
|
|
|
|
2000-08-23 19:11:16 +00:00
|
|
|
void CollationDummyTest::TestTertiary(/* char* par */)
|
1999-08-16 21:50:52 +00:00
|
|
|
{
|
|
|
|
int32_t i = 0;
|
|
|
|
myCollation->setStrength(Collator::TERTIARY);
|
|
|
|
for (i = 0; i < 17 ; i++)
|
|
|
|
{
|
|
|
|
doTest(testSourceCases[i], testTargetCases[i], results[i]);
|
|
|
|
}
|
|
|
|
}
|
2000-08-23 19:11:16 +00:00
|
|
|
void CollationDummyTest::TestPrimary(/* char* par */)
|
1999-08-16 21:50:52 +00:00
|
|
|
{
|
|
|
|
int32_t i;
|
|
|
|
myCollation->setStrength(Collator::PRIMARY);
|
|
|
|
for (i = 17; i < 26; i++)
|
|
|
|
{
|
|
|
|
doTest(testSourceCases[i], testTargetCases[i], results[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2000-08-23 19:11:16 +00:00
|
|
|
void CollationDummyTest::TestSecondary(/* char* par */)
|
1999-08-16 21:50:52 +00:00
|
|
|
{
|
|
|
|
int32_t i;
|
|
|
|
myCollation->setStrength(Collator::SECONDARY);
|
|
|
|
for (i = 26; i < 34; i++)
|
|
|
|
{
|
|
|
|
doTest(testSourceCases[i], testTargetCases[i], results[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2000-08-23 19:11:16 +00:00
|
|
|
void CollationDummyTest::TestExtra(/* char* par */)
|
1999-08-16 21:50:52 +00:00
|
|
|
{
|
|
|
|
int32_t i, j;
|
|
|
|
myCollation->setStrength(Collator::TERTIARY);
|
2000-03-22 23:17:42 +00:00
|
|
|
for (i = 0; i < COUNT_TEST_CASES-1; i++)
|
1999-08-16 21:50:52 +00:00
|
|
|
{
|
2000-03-22 23:17:42 +00:00
|
|
|
for (j = i + 1; j < COUNT_TEST_CASES; j += 1)
|
1999-08-16 21:50:52 +00:00
|
|
|
{
|
|
|
|
doTest(testCases[i], testCases[j], Collator::LESS);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2000-08-23 19:11:16 +00:00
|
|
|
void CollationDummyTest::runIndexedTest( int32_t index, UBool exec, const char* &name, char* /*par*/ )
|
1999-08-16 21:50:52 +00:00
|
|
|
{
|
|
|
|
if (exec) logln("TestSuite CollationDummyTest: ");
|
|
|
|
switch (index) {
|
2000-08-23 19:11:16 +00:00
|
|
|
case 0: name = "TestPrimary"; if (exec) TestPrimary(/* par */); break;
|
|
|
|
case 1: name = "TestSecondary"; if (exec) TestSecondary(/* par */); break;
|
|
|
|
case 2: name = "TestTertiary"; if (exec) TestTertiary(/* par */); break;
|
|
|
|
case 3: name = "TestExtra"; if (exec) TestExtra(/* par */); break;
|
1999-08-16 21:50:52 +00:00
|
|
|
default: name = ""; break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|