/********************************************************************
* COPYRIGHT:
* Copyright (c) 1997-2003, 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