scuffed-code/icu4c/source/test/intltest/dacoll.cpp

260 lines
9.6 KiB
C++
Raw Normal View History

/********************************************************************
* COPYRIGHT:
* Copyright (c) 1997-1999, International Business Machines Corporation and
* others. All Rights Reserved.
********************************************************************/
1999-08-16 21:50:52 +00:00
#ifndef _COLL
#include "unicode/coll.h"
1999-08-16 21:50:52 +00:00
#endif
#ifndef _TBLCOLL
#include "unicode/tblcoll.h"
1999-08-16 21:50:52 +00:00
#endif
#ifndef _UNISTR
#include "unicode/unistr.h"
1999-08-16 21:50:52 +00:00
#endif
#ifndef _SORTKEY
#include "unicode/sortkey.h"
1999-08-16 21:50:52 +00:00
#endif
#ifndef _DACOLL
#include "dacoll.h"
#endif
#include "sfwdchit.h"
1999-08-16 21:50:52 +00:00
CollationDanishTest::CollationDanishTest()
: myCollation(0)
{
UErrorCode status = U_ZERO_ERROR;
1999-08-16 21:50:52 +00:00
myCollation = Collator::createInstance(Locale("da", "DK", ""),status);
if(!myCollation || U_FAILURE(status)) {
errln(__FILE__ "failed to create! err " + UnicodeString(u_errorName(status)));
/* if it wasn't already: */
delete myCollation;
myCollation = NULL;
}
1999-08-16 21:50:52 +00:00
}
CollationDanishTest::~CollationDanishTest()
{
delete myCollation;
}
const UChar CollationDanishTest::testSourceCases[][CollationDanishTest::MAX_TOKEN_LEN] = {
{0x4c, 0x75, 0x63, 0},
{0x6c, 0x75, 0x63, 0x6b, 0},
{0x4c, 0x00FC, 0x62, 0x65, 0x63, 0x6b, 0},
{0x4c, 0x00E4, 0x76, 0x69, 0},
{0x4c, 0x00F6, 0x77, 0x77, 0},
{0x4c, 0x76, 0x69, 0},
{0x4c, 0x00E4, 0x76, 0x69, 0},
{0x4c, 0x00FC, 0x62, 0x65, 0x63, 0x6b, 0}
1999-08-16 21:50:52 +00:00
};
const UChar CollationDanishTest::testTargetCases[][CollationDanishTest::MAX_TOKEN_LEN] = {
{0x6c, 0x75, 0x63, 0x6b, 0},
{0x4c, 0x00FC, 0x62, 0x65, 0x63, 0x6b, 0},
{0x6c, 0x79, 0x62, 0x65, 0x63, 0x6b, 0},
{0x4c, 0x00F6, 0x77, 0x65, 0},
{0x6d, 0x61, 0x73, 0x74, 0},
{0x4c, 0x77, 0x69, 0},
{0x4c, 0x00F6, 0x77, 0x69, 0},
{0x4c, 0x79, 0x62, 0x65, 0x63, 0x6b, 0}
1999-08-16 21:50:52 +00:00
};
const Collator::EComparisonResult CollationDanishTest::results[] = {
Collator::LESS,
Collator::LESS,
Collator::GREATER,
Collator::LESS,
Collator::LESS,
// test primary > 5
Collator::EQUAL,
Collator::LESS,
Collator::EQUAL
};
const UChar CollationDanishTest::testBugs[][CollationDanishTest::MAX_TOKEN_LEN] = {
{0x41, 0x2f, 0x53, 0},
{0x41, 0x4e, 0x44, 0x52, 0x45, 0},
{0x41, 0x4e, 0x44, 0x52, 0x00C9, 0},
{0x41, 0x4e, 0x44, 0x52, 0x45, 0x41, 0x53, 0},
{0x41, 0x53, 0},
{0x43, 0x41, 0},
{0x00C7, 0x41, 0},
{0x43, 0x42, 0},
{0x00C7, 0x43, 0},
{0x44, 0x2e, 0x53, 0x2e, 0x42, 0x2e, 0},
{0x44, 0x41, 0}, // 10
{0x44, 0x42, 0},
{0x44, 0x53, 0x42, 0},
{0x44, 0x53, 0x43, 0},
{0x45, 0x4b, 0x53, 0x54, 0x52, 0x41, 0x5f, 0x41, 0x52, 0x42, 0x45, 0x4a, 0x44, 0x45, 0},
{0x45, 0x4b, 0x53, 0x54, 0x52, 0x41, 0x42, 0x55, 0x44, 0},
{0x48, 0x00D8, 0x53, 0x54, 0}, // could the 0x00D8 be 0x2205?
{0x48, 0x41, 0x41, 0x47, 0}, // 20
{0x48, 0x00C5, 0x4e, 0x44, 0x42, 0x4f, 0x47, 0},
{0x48, 0x41, 0x41, 0x4e, 0x44, 0x56, 0x00C6, 0x52, 0x4b, 0x53, 0x42, 0x41, 0x4e, 0x4b, 0x45, 0x4e, 0},
{0x6b, 0x61, 0x72, 0x6c, 0},
{0x4b, 0x61, 0x72, 0x6c, 0},
{0x4e, 0x49, 0x45, 0x4c, 0x53, 0x45, 0x4e, 0},
{0x4e, 0x49, 0x45, 0x4c, 0x53, 0x20, 0x4a, 0x00D8, 0x52, 0x47, 0x45, 0x4e, 0},
{0x4e, 0x49, 0x45, 0x4c, 0x53, 0x2d, 0x4a, 0x00D8, 0x52, 0x47, 0x45, 0x4e, 0},
{0x52, 0x00C9, 0x45, 0x2c, 0x20, 0x41, 0},
{0x52, 0x45, 0x45, 0x2c, 0x20, 0x42, 0},
{0x52, 0x00C9, 0x45, 0x2c, 0x20, 0x4c, 0}, // 30
{0x52, 0x45, 0x45, 0x2c, 0x20, 0x56, 0},
{0x53, 0x43, 0x48, 0x59, 0x54, 0x54, 0x2c, 0x20, 0x42, 0},
{0x53, 0x43, 0x48, 0x59, 0x54, 0x54, 0x2c, 0x20, 0x48, 0},
{0x53, 0x43, 0x48, 0x00DC, 0x54, 0x54, 0x2c, 0x20, 0x48, 0},
{0x53, 0x43, 0x48, 0x59, 0x54, 0x54, 0x2c, 0x20, 0x4c, 0},
{0x53, 0x43, 0x48, 0x00DC, 0x54, 0x54, 0x2c, 0x20, 0x4d, 0},
{0x53, 0x53, 0},
1999-08-16 21:50:52 +00:00
{0x00DF, 0},
{0x53, 0x53, 0x41, 0},
{0x53, 0x54, 0x4f, 0x52, 0x45, 0x4b, 0x00C6, 0x52, 0},
{0x53, 0x54, 0x4f, 0x52, 0x45, 0x20, 0x56, 0x49, 0x4c, 0x44, 0x4d, 0x4f, 0x53, 0x45, 0}, // 40
{0x53, 0x54, 0x4f, 0x52, 0x4d, 0x4c, 0x59, 0},
{0x53, 0x54, 0x4f, 0x52, 0x4d, 0x20, 0x50, 0x45, 0x54, 0x45, 0x52, 0x53, 0x45, 0x4e, 0},
{0x54, 0x48, 0x4f, 0x52, 0x56, 0x41, 0x4c, 0x44, 0},
{0x54, 0x48, 0x4f, 0x52, 0x56, 0x41, 0x52, 0x44, 0x55, 0x52, 0},
{0x00FE, 0x4f, 0x52, 0x56, 0x41, 0x52, 0x0110, 0x55, 0x52, 0},
{0x54, 0x48, 0x59, 0x47, 0x45, 0x53, 0x45, 0x4e, 0},
{0x56, 0x45, 0x53, 0x54, 0x45, 0x52, 0x47, 0x00C5, 0x52, 0x44, 0x2c, 0x20, 0x41, 0},
{0x56, 0x45, 0x53, 0x54, 0x45, 0x52, 0x47, 0x41, 0x41, 0x52, 0x44, 0x2c, 0x20, 0x41, 0},
{0x56, 0x45, 0x53, 0x54, 0x45, 0x52, 0x47, 0x00C5, 0x52, 0x44, 0x2c, 0x20, 0x42, 0}, // 50
{0x00C6, 0x42, 0x4c, 0x45, 0},
{0x00C4, 0x42, 0x4c, 0x45, 0},
{0x00D8, 0x42, 0x45, 0x52, 0x47, 0},
{0x00D6, 0x42, 0x45, 0x52, 0x47, 0},
{0x0110, 0x41, 0},
{0x0110, 0x43, 0} // 54
1999-08-16 21:50:52 +00:00
};
const UChar CollationDanishTest::testNTList[][CollationDanishTest::MAX_TOKEN_LEN] = {
{0x61, 0x6e, 0x64, 0x65, 0x72, 0x65, 0},
{0x63, 0x68, 0x61, 0x71, 0x75, 0x65, 0},
{0x63, 0x68, 0x65, 0x6d, 0x69, 0x6e, 0},
{0x63, 0x6f, 0x74, 0x65, 0},
{0x63, 0x6f, 0x74, 0x00e9, 0},
{0x63, 0x00f4, 0x74, 0x65, 0},
{0x63, 0x00f4, 0x74, 0x00e9, 0},
{0x010d, 0x75, 0x010d, 0x0113, 0x74, 0},
{0x43, 0x7a, 0x65, 0x63, 0x68, 0},
{0x68, 0x69, 0x0161, 0x61, 0},
{0x69, 0x72, 0x64, 0x69, 0x73, 0x63, 0x68, 0},
{0x6c, 0x69, 0x65, 0},
{0x6c, 0x69, 0x72, 0x65, 0},
{0x6c, 0x6c, 0x61, 0x6d, 0x61, 0},
{0x6c, 0x00f5, 0x75, 0x67, 0},
{0x6c, 0x00f2, 0x7a, 0x61, 0},
{0x6c, 0x75, 0x010d, 0},
{0x6c, 0x75, 0x63, 0x6b, 0},
{0x4c, 0x00fc, 0x62, 0x65, 0x63, 0x6b, 0},
{0x6c, 0x79, 0x65, 0}, /* 20 */
{0x6c, 0x00e4, 0x76, 0x69, 0},
{0x4c, 0x00f6, 0x77, 0x65, 0x6e, 0},
{0x6d, 0x00e0, 0x0161, 0x74, 0x61, 0},
{0x6d, 0x00ee, 0x72, 0},
{0x6d, 0x79, 0x6e, 0x64, 0x69, 0x67, 0},
{0x4d, 0x00e4, 0x6e, 0x6e, 0x65, 0x72, 0},
{0x6d, 0x00f6, 0x63, 0x68, 0x74, 0x65, 0x6e, 0},
{0x70, 0x69, 0x00f1, 0x61, 0},
{0x70, 0x69, 0x6e, 0x74, 0},
{0x70, 0x79, 0x6c, 0x6f, 0x6e, 0},
{0x0161, 0x00e0, 0x72, 0x61, 0x6e, 0},
{0x73, 0x61, 0x76, 0x6f, 0x69, 0x72, 0},
{0x0160, 0x65, 0x72, 0x62, 0x016b, 0x72, 0x61, 0},
{0x53, 0x69, 0x65, 0x74, 0x6c, 0x61, 0},
{0x015b, 0x6c, 0x75, 0x62, 0},
{0x73, 0x75, 0x62, 0x74, 0x6c, 0x65, 0},
{0x73, 0x79, 0x6d, 0x62, 0x6f, 0x6c, 0},
{0x73, 0x00e4, 0x6d, 0x74, 0x6c, 0x69, 0x63, 0x68, 0},
{0x77, 0x61, 0x66, 0x66, 0x6c, 0x65, 0},
{0x76, 0x65, 0x72, 0x6b, 0x65, 0x68, 0x72, 0x74, 0},
{0x77, 0x6f, 0x6f, 0x64, 0},
{0x76, 0x6f, 0x78, 0}, /* 40 */
{0x76, 0x00e4, 0x67, 0x61, 0},
{0x79, 0x65, 0x6e, 0},
{0x79, 0x75, 0x61, 0x6e, 0},
{0x79, 0x75, 0x63, 0x63, 0x61, 0},
{0x017e, 0x61, 0x6c, 0},
{0x017e, 0x65, 0x6e, 0x61, 0},
{0x017d, 0x65, 0x6e, 0x0113, 0x76, 0x61, 0},
{0x7a, 0x6f, 0x6f, 0},
{0x5a, 0x76, 0x69, 0x65, 0x64, 0x72, 0x69, 0x6a, 0x61, 0},
{0x5a, 0x00fc, 0x72, 0x69, 0x63, 0x68, 0},
{0x7a, 0x79, 0x73, 0x6b, 0},
{0x00e4, 0x6e, 0x64, 0x65, 0x72, 0x65, 0} /* 53 */
1999-08-16 21:50:52 +00:00
};
void CollationDanishTest::doTest( UnicodeString source, UnicodeString target, Collator::EComparisonResult result)
{
Collator::EComparisonResult compareResult = myCollation->compare(source, target);
SimpleFwdCharIterator src(source);
SimpleFwdCharIterator trg(target);
Collator::EComparisonResult incResult = myCollation->compare(src, trg);
1999-08-16 21:50:52 +00:00
CollationKey sortKey1, sortKey2;
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 );
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, incResult, result );
1999-08-16 21:50:52 +00:00
}
void CollationDanishTest::TestTertiary(/* char* par */)
1999-08-16 21:50:52 +00:00
{
int32_t i = 0;
myCollation->setStrength(Collator::TERTIARY);
for (i = 0; i < 5 ; i++) {
doTest(testSourceCases[i], testTargetCases[i], results[i]);
}
int32_t j = 0;
logln("Test internet data list : ");
for (i = 0; i < 53; i++) {
for (j = i+1; j < 54; j++) {
doTest(testBugs[i], testBugs[j], Collator::LESS);
}
}
logln("Test NT data list : ");
for (i = 0; i < 52; i++) {
for (j = i+1; j < 53; j++) {
doTest(testNTList[i], testNTList[j], Collator::LESS);
}
}
}
void CollationDanishTest::TestPrimary(/* char* par */)
1999-08-16 21:50:52 +00:00
{
int32_t i;
myCollation->setStrength(Collator::PRIMARY);
for (i = 5; i < 8; i++) {
doTest(testSourceCases[i], testTargetCases[i], results[i]);
}
}
void CollationDanishTest::runIndexedTest( int32_t index, UBool exec, const char* &name, char* /*par*/ )
1999-08-16 21:50:52 +00:00
{
if (exec) logln("TestSuite CollationDanishTest: ");
if((!myCollation) && exec) {
errln(__FILE__ " cannot test - failed to create collator.");
name = "";
return;
}
1999-08-16 21:50:52 +00:00
switch (index) {
case 0: name = "TestPrimary"; if (exec) TestPrimary(/* par */); break;
case 1: name = "TestTertiary"; if (exec) TestTertiary(/* par */); break;
1999-08-16 21:50:52 +00:00
default: name = ""; break;
}
}