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