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