/******************************************************************** * COPYRIGHT: * Copyright (c) 1997-2001, International Business Machines Corporation and * others. All Rights Reserved. ********************************************************************/ /** * CollationMonkeyTest is a third level test class. This tests the random * substrings of the default test strings to verify if the compare and * sort key algorithm works correctly. For example, any string is always * less than the string itself appended with any character. */ #ifndef _MNKYTST #define _MNKYTST #include "unicode/utypes.h" #if !UCONFIG_NO_COLLATION #include "tscoll.h" class CollationMonkeyTest: public IntlTestCollator { public: // If this is too small for the test data, just increase it. // Just don't make it too large, otherwise the executable will get too big enum EToken_Len { MAX_TOKEN_LEN = 16 }; CollationMonkeyTest(); virtual ~CollationMonkeyTest(); void runIndexedTest( int32_t index, UBool exec, const char* &name, char* par = NULL ); // utility function used in tests, returns absolute value int32_t checkValue(int32_t value); // perform monkey tests using Collator::compare void TestCompare(/* char* par */); // perform monkey tests using CollationKey::compareTo void TestCollationKey(/* char* par */); void TestRules(/* char* par */); private: void report(UnicodeString& s, UnicodeString& t, int32_t result, int32_t revResult); const UnicodeString source; Collator *myCollator; }; #endif /* #if !UCONFIG_NO_COLLATION */ #endif