1 // © 2016 and later: Unicode, Inc. and others.
2 // License & terms of use: http://www.unicode.org/copyright.html
3 /***********************************************************************
4  * COPYRIGHT:
5  * Copyright (c) 1997-2014, International Business Machines Corporation
6  * and others. All Rights Reserved.
7  ***********************************************************************/
8 
9 /**
10  * CollationAPITest is a third level test class. This test performs API
11  * related tests for the Collation framework.
12  */
13 
14 #ifndef _APICOLL
15 #define _APICOLL
16 
17 #include "unicode/utypes.h"
18 
19 #if !UCONFIG_NO_COLLATION
20 
21 #include "unicode/tblcoll.h"
22 #include "tscoll.h"
23 
24 class CollationAPITest: public IntlTestCollator {
25 public:
26     void runIndexedTest( int32_t index, UBool exec, const char* &name, char* /*par = NULL */);
27     void doAssert(UBool condition, const char *message);
28 
29     /**
30      * This tests the properties of a collator object.
31      * - constructor/destructor
32      * - factory method createInstance
33      * - compare and getCollationKey
34      * - get/set decomposition mode and comparison level
35      * - displayable name in the desired locale
36      */
37     void TestProperty(/* char* par */);
38     void TestKeywordValues();
39 
40     /**
41     * This tests the RuleBasedCollator
42     * - constructor/destructor
43     * - getRules
44     */
45     void TestRuleBasedColl(/* char* par */);
46 
47     /**
48     * This tests the RuleBasedCollator
49     * - getRules
50     */
51     void TestRules(/* char* par */);
52 
53     /**
54     * Tests decomposition setting
55     */
56     void TestDecomposition();
57 
58     /**
59     * SafeClone test
60     */
61     void TestSafeClone();
62 
63     /**
64      * This tests the properties of a rule based collator object.
65      * - constructor/destructor
66      * - == and != operators
67      * - clone and copy
68      * - collation rules access
69      */
70     void TestOperators(/* char* par */);
71 
72     /**
73      * This tests the duplication of a collator object.
74      */
75     void TestDuplicate(/* char* par */);
76 
77     /**
78      * This tests the comparison convenience methods of a collator object.
79      * - greater than
80      * - greater than or equal to
81      * - equal to
82      */
83     void TestCompare(/* char* par */);
84 
85     /**
86      * This tests the hashCode method of a collator object.
87      */
88     void TestHashCode(/* char* par */);
89 
90     /**
91      * This tests the collation key related APIs.
92      * - constructor/destructor
93      * - Collator::getCollationKey
94      * - == and != operators
95      * - comparison between collation keys
96      * - creating collation key with a byte array and vice versa
97      */
98     void TestCollationKey(/* char* par */);
99 
100     /**
101      * This tests the CollationElementIterator related APIs.
102      * - creation of a CollationElementIterator object
103      * - == and != operators
104      * - iterating forward
105      * - reseting the iterator index
106      * - requesting the order properties(primary, secondary or tertiary)
107      */
108     void TestElemIter(/* char* par */);
109 
110     /**
111      * This tests the list the all available locales.
112      */
113     void TestGetAll(/* char* par */);
114 
115     /**
116      * This tests the sort keys generated by collator
117      */
118     void TestSortKey();
119     void TestSortKeyOverflow();
120 
121     /**
122      * This tests getMaxExpansion
123      */
124     void TestMaxExpansion();
125 
126     /**
127     * Tests the retrieval of names given a locale
128     */
129     void TestDisplayName();
130 
131     /**
132     * Tests the collator attributes
133     */
134     void TestAttribute();
135 
136     /**
137     * Tests the setters and getters of variable top
138     */
139     void TestVariableTopSetting();
140     void TestMaxVariable();
141 
142     /**
143     * Tests GetLocale for a Collator
144     */
145     void TestGetLocale();
146 
147     /**
148     * Tests bounds API
149     */
150     void TestBounds();
151 
152     /**
153     * Tests getTailoredSet API
154     */
155     void TestGetTailoredSet();
156 
157     /**
158     * Tests the subclassability
159     */
160     void TestSubclass();
161 
162     /**
163     * Tests the dynamic and static ids of collation classes
164     */
165     void TestUClassID();
166 
167     /**
168     * Test NULL
169     */
170     void TestNULLCharTailoring();
171 
172     void TestClone();
173     void TestCloneBinary();
174     void TestIterNumeric();
175     void TestBadKeywords();
176     void TestGapTooSmall();
177 
178 private:
179     // If this is too small for the test data, just increase it.
180     // Just don't make it too large, otherwise the executable will get too big
181     enum EToken_Len { MAX_TOKEN_LEN = 16 };
182 
183     void dump(UnicodeString msg, RuleBasedCollator* c, UErrorCode& status);
184 
185 };
186 
187 #endif /* #if !UCONFIG_NO_COLLATION */
188 
189 #endif
190