numfmtst.h revision b13da9df870a61b11249bf741347908dbea0edd8
1/********************************************************************
2 * COPYRIGHT:
3 * Copyright (c) 1997-2007, 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 private:
133
134    static UBool equalValue(const Formattable& a, const Formattable& b);
135
136    void expect2(NumberFormat& fmt, const Formattable& n, const UnicodeString& str);
137
138    void expect2(NumberFormat& fmt, const Formattable& n, const char* str) {
139        expect2(fmt, n, UnicodeString(str, ""));
140    }
141
142    void expect2(NumberFormat* fmt, const Formattable& n, const UnicodeString& str, UErrorCode ec);
143
144    void expect2(NumberFormat* fmt, const Formattable& n, const char* str, UErrorCode ec) {
145        expect2(fmt, n, UnicodeString(str, ""), ec);
146    }
147
148    void expect(NumberFormat& fmt, const UnicodeString& str, const Formattable& n);
149
150    void expect(NumberFormat& fmt, const char *str, const Formattable& n) {
151        expect(fmt, UnicodeString(str, ""), n);
152    }
153
154    void expect(NumberFormat& fmt, const Formattable& n,
155                const UnicodeString& exp, UBool rt=TRUE);
156
157    void expect(NumberFormat& fmt, const Formattable& n,
158                const char *exp, UBool rt=TRUE) {
159        expect(fmt, n, UnicodeString(exp, ""), rt);
160    }
161
162    void expect(NumberFormat* fmt, const Formattable& n,
163                const UnicodeString& exp, UErrorCode);
164
165    void expect(NumberFormat* fmt, const Formattable& n,
166                const char *exp, UErrorCode errorCode) {
167        expect(fmt, n, UnicodeString(exp, ""), errorCode);
168    }
169
170    void expectCurrency(NumberFormat& nf, const Locale& locale,
171                        double value, const UnicodeString& string);
172
173    void expectPad(DecimalFormat& fmt, const UnicodeString& pat,
174                   int32_t pos, int32_t width, UChar pad);
175
176    void expectPad(DecimalFormat& fmt, const char *pat,
177                   int32_t pos, int32_t width, UChar pad) {
178        expectPad(fmt, UnicodeString(pat, ""), pos, width, pad);
179    }
180
181    void expectPad(DecimalFormat& fmt, const UnicodeString& pat,
182                   int32_t pos, int32_t width, const UnicodeString& pad);
183
184    void expectPad(DecimalFormat& fmt, const char *pat,
185                   int32_t pos, int32_t width, const UnicodeString& pad) {
186        expectPad(fmt, UnicodeString(pat, ""), pos, width, pad);
187    }
188
189    void expectPat(DecimalFormat& fmt, const UnicodeString& exp);
190
191    void expectPat(DecimalFormat& fmt, const char *exp) {
192        expectPat(fmt, UnicodeString(exp, ""));
193    }
194
195    void expectPad(DecimalFormat& fmt, const UnicodeString& pat,
196                   int32_t pos);
197
198    void expectPad(DecimalFormat& fmt, const char *pat,
199                   int32_t pos) {
200        expectPad(fmt, pat, pos, 0, (UChar)0);
201    }
202
203    // internal utility routine
204    static UnicodeString& escape(UnicodeString& s);
205
206    enum { ILLEGAL = -1 };
207
208    // internal subtest used by TestRounding487
209    void roundingTest(NumberFormat& nf, double x, int32_t maxFractionDigits, const char* expected);
210
211    // internal rounding checking for TestRounding
212    void checkRounding(DecimalFormat* df, double base, int iterations, double increment);
213
214    double checkRound(DecimalFormat* df, double iValue, double lastParsed);
215};
216
217#endif /* #if !UCONFIG_NO_FORMATTING */
218
219#endif // _NUMBERFORMATTEST_
220