| /******************************************************************** |
| * COPYRIGHT: |
| * Copyright (c) 1997-1999, International Business Machines Corporation and |
| * others. All Rights Reserved. |
| ********************************************************************/ |
| |
| #ifndef _COLL |
| #include "unicode/coll.h" |
| #endif |
| |
| #ifndef _TBLCOLL |
| #include "unicode/tblcoll.h" |
| #endif |
| |
| #ifndef _UNISTR |
| #include "unicode/unistr.h" |
| #endif |
| |
| #ifndef _SORTKEY |
| #include "unicode/sortkey.h" |
| #endif |
| |
| #ifndef _DACOLL |
| #include "dacoll.h" |
| #endif |
| |
| CollationDanishTest::CollationDanishTest() |
| : myCollation(0) |
| { |
| UErrorCode status = U_ZERO_ERROR; |
| myCollation = Collator::createInstance(Locale("da", "DK", ""),status); |
| } |
| |
| 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} |
| }; |
| |
| 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} |
| }; |
| |
| 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}, |
| {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 |
| }; |
| |
| 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 */ |
| }; |
| void CollationDanishTest::doTest( UnicodeString source, UnicodeString target, Collator::EComparisonResult result) |
| { |
| Collator::EComparisonResult compareResult = myCollation->compare(source, target); |
| CollationKey sortKey1, sortKey2; |
| UErrorCode key1status = U_ZERO_ERROR, key2status = U_ZERO_ERROR; //nos |
| myCollation->getCollationKey(source, /*nos*/ sortKey1, key1status ); |
| myCollation->getCollationKey(target, /*nos*/ sortKey2, key2status ); |
| if (U_FAILURE(key1status) || U_FAILURE(key2status)) { |
| errln("SortKey generation Failed.\n"); |
| return; |
| } |
| Collator::EComparisonResult keyResult = sortKey1.compareTo(sortKey2); |
| reportCResult( source, target, sortKey1, sortKey2, compareResult, keyResult, result ); |
| } |
| |
| void CollationDanishTest::TestTertiary( char* par ) |
| { |
| 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 ) |
| { |
| 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, bool_t exec, char* &name, char* par ) |
| { |
| if (exec) logln("TestSuite CollationDanishTest: "); |
| switch (index) { |
| case 0: name = "TestPrimary"; if (exec) TestPrimary( par ); break; |
| case 1: name = "TestTertiary"; if (exec) TestTertiary( par ); break; |
| default: name = ""; break; |
| } |
| } |
| |
| |