8b20f17f49
X-SVN-Rev: 473
112 lines
3.2 KiB
C++
112 lines
3.2 KiB
C++
/*
|
|
**********************************************************************
|
|
* Copyright (C) 1999, International Business Machines
|
|
* Corporation and others. All Rights Reserved.
|
|
**********************************************************************
|
|
* Date Name Description
|
|
* 11/10/99 aliu Creation.
|
|
**********************************************************************
|
|
*/
|
|
#ifndef TRANSTST_H
|
|
#define TRANSTST_H
|
|
|
|
#include "unicode/utypes.h"
|
|
#include "intltest.h"
|
|
|
|
class Transliterator;
|
|
|
|
/**
|
|
* @test
|
|
* @summary General test of Transliterator
|
|
*/
|
|
class TransliteratorTest : public IntlTest {
|
|
|
|
void runIndexedTest(int32_t index, bool_t exec, char* &name,
|
|
char* par=NULL);
|
|
#if 0
|
|
void TestHashtable(void);
|
|
#endif
|
|
|
|
void TestInstantiation(void);
|
|
|
|
void TestSimpleRules(void);
|
|
|
|
/**
|
|
* Create some inverses and confirm that they work. We have to be
|
|
* careful how we do this, since the inverses will not be true
|
|
* inverses -- we can't throw any random string at the composition
|
|
* of the transliterators and expect the identity function. F x
|
|
* F' != I. However, if we are careful about the input, we will
|
|
* get the expected results.
|
|
*/
|
|
void TestRuleBasedInverse(void);
|
|
|
|
/**
|
|
* Basic test of keyboard.
|
|
*/
|
|
void TestKeyboard(void);
|
|
|
|
/**
|
|
* Basic test of keyboard with cursor.
|
|
*/
|
|
void TestKeyboard2(void);
|
|
|
|
/**
|
|
* Test keyboard transliteration with back-replacement.
|
|
*/
|
|
void TestKeyboard3(void);
|
|
|
|
void keyboardAux(const Transliterator& t,
|
|
const char* DATA[], int32_t DATA_length);
|
|
|
|
void TestArabic(void);
|
|
|
|
/**
|
|
* Compose the Kana transliterator forward and reverse and try
|
|
* some strings that should come out unchanged.
|
|
*/
|
|
void TestCompoundKana(void);
|
|
|
|
/**
|
|
* Compose the hex transliterators forward and reverse.
|
|
*/
|
|
void TestCompoundHex(void);
|
|
|
|
/**
|
|
* Do some basic tests of filtering.
|
|
*/
|
|
void TestFiltering(void);
|
|
|
|
//======================================================================
|
|
// Support methods
|
|
//======================================================================
|
|
void expect(const UnicodeString& rules,
|
|
const UnicodeString& source,
|
|
const UnicodeString& expectedResult);
|
|
|
|
void expect(const Transliterator& t,
|
|
const UnicodeString& source,
|
|
const UnicodeString& expectedResult,
|
|
const Transliterator& reverseTransliterator);
|
|
|
|
void expect(const Transliterator& t,
|
|
const UnicodeString& source,
|
|
const UnicodeString& expectedResult);
|
|
|
|
void expectAux(const UnicodeString& tag,
|
|
const UnicodeString& source,
|
|
const UnicodeString& result,
|
|
const UnicodeString& expectedResult);
|
|
|
|
void expectAux(const UnicodeString& tag,
|
|
const UnicodeString& summary, bool_t pass,
|
|
const UnicodeString& expectedResult);
|
|
|
|
/**
|
|
* Escape non-ASCII characters as Unicode.
|
|
*/
|
|
static UnicodeString escape(const UnicodeString& s);
|
|
};
|
|
|
|
#endif
|