scuffed-code/icu4c/source/test/intltest/mnkytst.h

62 lines
2.1 KiB
C++

/*
*****************************************************************************************
* *
* COPYRIGHT: *
* (C) Copyright Taligent, Inc., 1997 *
* (C) Copyright International Business Machines Corporation, 1997-1998 *
* Licensed Material - Program-Property of IBM - All Rights Reserved. *
* US Government Users Restricted Rights - Use, duplication, or disclosure *
* restricted by GSA ADP Schedule Contract with IBM Corp. *
* *
*****************************************************************************************
*/
/**
* 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
#ifndef _UTYPES
#include "unicode/utypes.h"
#endif
#ifndef _COLL
#include "unicode/coll.h"
#endif
#ifndef _INTLTEST
#include "intltest.h"
#endif
class CollationMonkeyTest: public IntlTest {
public:
// static constants
enum EToken_Len { MAX_TOKEN_LEN = 128 };
CollationMonkeyTest();
~CollationMonkeyTest();
void runIndexedTest( int32_t index, bool_t exec, 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 );
private:
void report(UnicodeString& s, UnicodeString& t, int32_t result, int32_t revResult);
static const UnicodeString source;
Collator *myCollator;
};
#endif