]> git.saurik.com Git - apple/icu.git/blobdiff - icuSources/test/intltest/numfmtst.h
ICU-531.31.tar.gz
[apple/icu.git] / icuSources / test / intltest / numfmtst.h
index 60e32b80b9f01f03b13644c5e3a957e09f70dd4f..f25a4250a69b77efa9526d43c5426a0fe9068f8e 100644 (file)
@@ -1,9 +1,9 @@
-/********************************************************************
- * COPYRIGHT: 
- * Copyright (c) 1997-2003, International Business Machines Corporation and
- * others. All Rights Reserved.
- ********************************************************************/
+/************************************************************************
+ * COPYRIGHT:
+ * Copyright (c) 1997-2014, International Business Machines Corporation
+ * and others. All Rights Reserved.
+ ************************************************************************/
+
 #ifndef _NUMBERFORMATTEST_
 #define _NUMBERFORMATTEST_
 
@@ -12,7 +12,7 @@
 #if !UCONFIG_NO_FORMATTING
 
 #include "unicode/numfmt.h"
-#include "unicode/decimfmt.h" 
+#include "unicode/decimfmt.h"
 #include "caltztst.h"
 
 /**
@@ -26,8 +26,11 @@ class NumberFormatTest: public CalendarTimeZoneTest {
 
     /**
      * Test APIs (to increase code coverage)
-     */   
+     */
     void TestAPI(void);
+
+    void TestCoverage(void);
+
     /**
      * Test the handling of quotes
      **/
@@ -47,8 +50,8 @@ class NumberFormatTest: public CalendarTimeZoneTest {
     /**
      * API coverage for DigitList
      **/
-    void TestDigitList(void);
-    
+    //void TestDigitList(void);
+
     /**
      * Test localized currency patterns.
      */
@@ -75,6 +78,12 @@ class NumberFormatTest: public CalendarTimeZoneTest {
 
     void TestScientific(void);
 
+    void TestScientific2(void);
+
+    void TestScientificGrouping(void);
+
+    void TestInt64(void);
+
     void TestSurrogateSupport(void);
 
     /**
@@ -83,9 +92,9 @@ class NumberFormatTest: public CalendarTimeZoneTest {
     void TestSecondaryGrouping(void);
 
     void TestWhiteSpaceParsing(void);
-        
+
     void TestComplexCurrency(void);
-        
+
     void TestPad(void);
     void TestPatterns2(void);
 
@@ -94,16 +103,102 @@ class NumberFormatTest: public CalendarTimeZoneTest {
      */
     void TestRegCurrency(void);
 
+    void TestCurrencyNames(void);
+
+    void TestCurrencyAmount(void);
+
+    void TestCurrencyUnit(void);
+
     void TestSymbolsWithBadLocale(void);
 
     void TestAdoptDecimalFormatSymbols(void);
 
+    void TestPerMill(void);
+
+    void TestIllegalPatterns(void);
+
+    void TestCases(void);
+
+    void TestJB3832(void);
+
+    void TestHost(void);
+
+    void TestHostClone(void);
+
+    void TestCurrencyFormat(void);
+
+    /* Port of ICU4J rounding test. */
+    void TestRounding(void);
+
+    void TestRoundingPattern(void);
+
+    void TestNonpositiveMultiplier(void);
+
+    void TestNumberingSystems();
+
+
+    void TestSpaceParsing();
+    void TestMultiCurrencySign();
+    void TestCurrencyFormatForMixParsing();
+    void TestDecimalFormatCurrencyParse();
+    void TestCurrencyIsoPluralFormat();
+    void TestCurrencyParsing();
+    void TestParseCurrencyInUCurr();
+    void TestFormatAttributes();
+    void TestFieldPositionIterator();
+
+    void TestLenientParse();
+
+    void TestDecimal();
+    void TestCurrencyFractionDigits();
+
+    void TestExponentParse();
+    void TestExplicitParents();
+    void TestAvailableNumberingSystems();
+    void Test9087();
+    void TestFormatFastpaths();
+
+    void TestFormattableSize();
+
+    void TestUFormattable();
+
+    void TestEnumSet();
+
+    void TestSignificantDigits();
+    void TestShowZero();
+
+    void TestCompatibleCurrencies();
+    void TestBug9936();
+    void TestParseNegativeWithFaLocale();
+    void TestParseNegativeWithAlternateMinusSign();
+
+    void TestCustomCurrencySignAndSeparator();
+
+    void TestParseSignsAndMarks();
+    void Test10419RoundingWith0FractionDigits();
+    void Test10468ApplyPattern();
+    void TestRoundingScientific10542();
+    void TestZeroScientific10547();
+    void TestAccountingCurrency();
+    void TestEquality();
+
  private:
+    UBool testFormattableAsUFormattable(const char *file, int line, Formattable &f);
+
+    void expectParseCurrency(const NumberFormat &fmt, const UChar* currency, double amount, const char *text);
 
     static UBool equalValue(const Formattable& a, const Formattable& b);
 
+    void expectPositions(FieldPositionIterator& iter, int32_t *values, int32_t tupleCount,
+                         const UnicodeString& str);
+
+    void expectPosition(FieldPosition& pos, int32_t id, int32_t start, int32_t limit,
+                        const UnicodeString& str);
+
     void expect2(NumberFormat& fmt, const Formattable& n, const UnicodeString& str);
 
+    void expect3(NumberFormat& fmt, const Formattable& n, const UnicodeString& str);
+
     void expect2(NumberFormat& fmt, const Formattable& n, const char* str) {
         expect2(fmt, n, UnicodeString(str, ""));
     }
@@ -129,30 +224,26 @@ class NumberFormatTest: public CalendarTimeZoneTest {
     }
 
     void expect(NumberFormat* fmt, const Formattable& n,
-                const UnicodeString& exp, UErrorCode);
+                const UnicodeString& exp, UBool rt, UErrorCode errorCode);
 
     void expect(NumberFormat* fmt, const Formattable& n,
-                const char *exp, UErrorCode errorCode) {
-        expect(fmt, n, UnicodeString(exp, ""), errorCode);
+                const char *exp, UBool rt, UErrorCode errorCode) {
+        expect(fmt, n, UnicodeString(exp, ""), rt, errorCode);
     }
 
-    void expectCurrency(NumberFormat& nf, const Locale& locale,
-                        double value, const UnicodeString& string);
-
-    void expectPat(DecimalFormat& fmt, const UnicodeString& exp);
-
-    void expectPat(DecimalFormat& fmt, const char *exp) {
-        expectPat(fmt, UnicodeString(exp, ""));
+    void expect(NumberFormat* fmt, const Formattable& n,
+                const UnicodeString& exp, UErrorCode errorCode) {
+        expect(fmt, n, exp, TRUE, errorCode);
     }
 
-    void expectPad(DecimalFormat& fmt, const UnicodeString& pat,
-                   int32_t pos);
-
-    void expectPad(DecimalFormat& fmt, const char *pat,
-                   int32_t pos) {
-        expectPad(fmt, pat, pos, 0, (UChar)0);
+    void expect(NumberFormat* fmt, const Formattable& n,
+                const char *exp, UErrorCode errorCode) {
+        expect(fmt, n, UnicodeString(exp, ""), TRUE, errorCode);
     }
 
+    void expectCurrency(NumberFormat& nf, const Locale& locale,
+                        double value, const UnicodeString& string);
+
     void expectPad(DecimalFormat& fmt, const UnicodeString& pat,
                    int32_t pos, int32_t width, UChar pad);
 
@@ -169,6 +260,25 @@ class NumberFormatTest: public CalendarTimeZoneTest {
         expectPad(fmt, UnicodeString(pat, ""), pos, width, pad);
     }
 
+    void expectPat(DecimalFormat& fmt, const UnicodeString& exp);
+
+    void expectPat(DecimalFormat& fmt, const char *exp) {
+        expectPat(fmt, UnicodeString(exp, ""));
+    }
+
+    void expectPad(DecimalFormat& fmt, const UnicodeString& pat,
+                   int32_t pos);
+
+    void expectPad(DecimalFormat& fmt, const char *pat,
+                   int32_t pos) {
+        expectPad(fmt, pat, pos, 0, (UChar)0);
+    }
+
+    void expect_rbnf(NumberFormat& fmt, const UnicodeString& str, const Formattable& n);
+
+    void expect_rbnf(NumberFormat& fmt, const Formattable& n,
+                const UnicodeString& exp, UBool rt=TRUE);
+
     // internal utility routine
     static UnicodeString& escape(UnicodeString& s);
 
@@ -176,8 +286,23 @@ class NumberFormatTest: public CalendarTimeZoneTest {
 
     // internal subtest used by TestRounding487
     void roundingTest(NumberFormat& nf, double x, int32_t maxFractionDigits, const char* expected);
+
+    // internal rounding checking for TestRounding
+    void checkRounding(DecimalFormat* df, double base, int iterations, double increment);
+
+    double checkRound(DecimalFormat* df, double iValue, double lastParsed);
+
+    void verifyRounding(
+        DecimalFormat& format,
+        const double *values,
+        const char * const *expected,
+        const DecimalFormat::ERoundingMode *roundingModes,
+        const char * const *descriptions,
+        int32_t valueSize,
+        int32_t roundingModeSize);
+
 };
 
 #endif /* #if !UCONFIG_NO_FORMATTING */
+
 #endif // _NUMBERFORMATTEST_