numfmtst.h revision b0ac937921a2c196d8b9da665135bf6ba01a1ccf
1/********************************************************************
2 * COPYRIGHT:
3 * Copyright (c) 1997-2009, International Business Machines Corporation and
4 * others. All Rights Reserved.
5 ********************************************************************/
6
7#ifndef _NUMBERFORMATTEST_
8#define _NUMBERFORMATTEST_
9
10#include "unicode/utypes.h"
11
12#if !UCONFIG_NO_FORMATTING
13
14#include "unicode/numfmt.h"
15#include "unicode/decimfmt.h"
16#include "caltztst.h"
17
18/**
19 * Performs various in-depth test on NumberFormat
20 **/
21class NumberFormatTest: public CalendarTimeZoneTest {
22
23    // IntlTest override
24    void runIndexedTest( int32_t index, UBool exec, const char* &name, char* par );
25 public:
26
27    /**
28     * Test APIs (to increase code coverage)
29     */
30    void TestAPI(void);
31
32    void TestCoverage(void);
33
34    /**
35     * Test the handling of quotes
36     **/
37    void TestQuotes(void);
38    /**
39     * Test patterns with exponential representation
40     **/
41    void TestExponential(void);
42    /**
43     * Test handling of patterns with currency symbols
44     **/
45    void TestCurrencySign(void);
46    /**
47     * Test different format patterns
48     **/
49    void TestPatterns(void);
50    /**
51     * API coverage for DigitList
52     **/
53    //void TestDigitList(void);
54
55    /**
56     * Test localized currency patterns.
57     */
58    void TestCurrency(void);
59
60    /**
61     * Test the Currency object handling, new as of ICU 2.2.
62     */
63    void TestCurrencyObject(void);
64
65    void TestCurrencyPatterns(void);
66
67    /**
68     * Do rudimentary testing of parsing.
69     */
70    void TestParse(void);
71    /**
72     * Test proper rounding by the format method.
73     */
74    void TestRounding487(void);
75
76    // New tests for alphaWorks upgrade
77    void TestExponent(void);
78
79    void TestScientific(void);
80
81    void TestScientific2(void);
82
83    void TestScientificGrouping(void);
84
85    void TestInt64(void);
86
87    void TestSurrogateSupport(void);
88
89    /**
90     * Test the functioning of the secondary grouping value.
91     */
92    void TestSecondaryGrouping(void);
93
94    void TestWhiteSpaceParsing(void);
95
96    void TestComplexCurrency(void);
97
98    void TestPad(void);
99    void TestPatterns2(void);
100
101    /**
102     * Test currency registration.
103     */
104    void TestRegCurrency(void);
105
106    void TestCurrencyNames(void);
107
108    void TestCurrencyAmount(void);
109
110    void TestCurrencyUnit(void);
111
112    void TestSymbolsWithBadLocale(void);
113
114    void TestAdoptDecimalFormatSymbols(void);
115
116    void TestPerMill(void);
117
118    void TestIllegalPatterns(void);
119
120    void TestCases(void);
121
122    void TestJB3832(void);
123
124    void TestHost(void);
125
126    void TestHostClone(void);
127
128    void TestCurrencyFormat(void);
129
130    /* Port of ICU4J rounding test. */
131    void TestRounding(void);
132
133    void TestNonpositiveMultiplier(void);
134
135    void TestNumberingSystems();
136
137
138    void TestSpaceParsing();
139    void TestMultiCurrencySign();
140    void TestCurrencyFormatForMixParsing();
141    void TestDecimalFormatCurrencyParse();
142    void TestCurrencyIsoPluralFormat();
143    void TestCurrencyParsing();
144    void TestParseCurrencyInUCurr();
145
146 private:
147
148    static UBool equalValue(const Formattable& a, const Formattable& b);
149
150    void expect2(NumberFormat& fmt, const Formattable& n, const UnicodeString& str);
151
152    void expect3(NumberFormat& fmt, const Formattable& n, const UnicodeString& str);
153
154    void expect2(NumberFormat& fmt, const Formattable& n, const char* str) {
155        expect2(fmt, n, UnicodeString(str, ""));
156    }
157
158    void expect2(NumberFormat* fmt, const Formattable& n, const UnicodeString& str, UErrorCode ec);
159
160    void expect2(NumberFormat* fmt, const Formattable& n, const char* str, UErrorCode ec) {
161        expect2(fmt, n, UnicodeString(str, ""), ec);
162    }
163
164    void expect(NumberFormat& fmt, const UnicodeString& str, const Formattable& n);
165
166    void expect(NumberFormat& fmt, const char *str, const Formattable& n) {
167        expect(fmt, UnicodeString(str, ""), n);
168    }
169
170    void expect(NumberFormat& fmt, const Formattable& n,
171                const UnicodeString& exp, UBool rt=TRUE);
172
173    void expect(NumberFormat& fmt, const Formattable& n,
174                const char *exp, UBool rt=TRUE) {
175        expect(fmt, n, UnicodeString(exp, ""), rt);
176    }
177
178    void expect(NumberFormat* fmt, const Formattable& n,
179                const UnicodeString& exp, UErrorCode);
180
181    void expect(NumberFormat* fmt, const Formattable& n,
182                const char *exp, UErrorCode errorCode) {
183        expect(fmt, n, UnicodeString(exp, ""), errorCode);
184    }
185
186    void expectCurrency(NumberFormat& nf, const Locale& locale,
187                        double value, const UnicodeString& string);
188
189    void expectPad(DecimalFormat& fmt, const UnicodeString& pat,
190                   int32_t pos, int32_t width, UChar pad);
191
192    void expectPad(DecimalFormat& fmt, const char *pat,
193                   int32_t pos, int32_t width, UChar pad) {
194        expectPad(fmt, UnicodeString(pat, ""), pos, width, pad);
195    }
196
197    void expectPad(DecimalFormat& fmt, const UnicodeString& pat,
198                   int32_t pos, int32_t width, const UnicodeString& pad);
199
200    void expectPad(DecimalFormat& fmt, const char *pat,
201                   int32_t pos, int32_t width, const UnicodeString& pad) {
202        expectPad(fmt, UnicodeString(pat, ""), pos, width, pad);
203    }
204
205    void expectPat(DecimalFormat& fmt, const UnicodeString& exp);
206
207    void expectPat(DecimalFormat& fmt, const char *exp) {
208        expectPat(fmt, UnicodeString(exp, ""));
209    }
210
211    void expectPad(DecimalFormat& fmt, const UnicodeString& pat,
212                   int32_t pos);
213
214    void expectPad(DecimalFormat& fmt, const char *pat,
215                   int32_t pos) {
216        expectPad(fmt, pat, pos, 0, (UChar)0);
217    }
218
219    void expect_rbnf(NumberFormat& fmt, const UnicodeString& str, const Formattable& n);
220
221    void expect_rbnf(NumberFormat& fmt, const Formattable& n,
222                const UnicodeString& exp, UBool rt=TRUE);
223
224    // internal utility routine
225    static UnicodeString& escape(UnicodeString& s);
226
227    enum { ILLEGAL = -1 };
228
229    // internal subtest used by TestRounding487
230    void roundingTest(NumberFormat& nf, double x, int32_t maxFractionDigits, const char* expected);
231
232    // internal rounding checking for TestRounding
233    void checkRounding(DecimalFormat* df, double base, int iterations, double increment);
234
235    double checkRound(DecimalFormat* df, double iValue, double lastParsed);
236};
237
238#endif /* #if !UCONFIG_NO_FORMATTING */
239
240#endif // _NUMBERFORMATTEST_
241