// Copyright (C) 2016 and later: Unicode, Inc. and others. // License & terms of use: http://www.unicode.org/copyright.html /******************************************************************** * COPYRIGHT: * Copyright (c) 1997-2010, International Business Machines Corporation and * others. All Rights Reserved. ********************************************************************/ #include "unicode/utypes.h" #if !UCONFIG_NO_FORMATTING #include "pptest.h" #include "unicode/numfmt.h" #include "unicode/decimfmt.h" // ***************************************************************************** // class ParsePositionTest // ***************************************************************************** #define CASE(id,test) case id: name = #test; if (exec) { logln(#test "---"); logln((UnicodeString)""); test(); } break; void ParsePositionTest::runIndexedTest( int32_t index, UBool exec, const char* &name, char* /*par*/ ) { // if (exec) logln((UnicodeString)"TestSuite ParsePositionTest"); switch (index) { CASE(0, TestParsePosition) CASE(1, TestFieldPosition) CASE(2, TestFieldPosition_example) CASE(3, Test4109023) default: name = ""; break; } } UBool ParsePositionTest::failure(UErrorCode status, const char* msg, UBool possibleDataError) { if(U_FAILURE(status)) { if (possibleDataError) { dataerrln(UnicodeString("FAIL: ") + msg + " failed, error " + u_errorName(status)); } else { errln(UnicodeString("FAIL: ") + msg + " failed, error " + u_errorName(status)); } return TRUE; } return FALSE; } void ParsePositionTest::TestParsePosition() { ParsePosition pp1(0); if (pp1.getIndex() == 0) { logln("PP constructor() tested."); }else{ errln("*** PP getIndex or constructor() result"); } { int to = 5; ParsePosition pp2( to ); if (pp2.getIndex() == 5) { logln("PP getIndex and constructor(int32_t) tested."); }else{ errln("*** PP getIndex or constructor(int32_t) result"); } pp2.setIndex( 3 ); if (pp2.getIndex() == 3) { logln("PP setIndex tested."); }else{ errln("*** PP getIndex or setIndex result"); } } ParsePosition pp2(3), pp3(5); //pp2 = new ParsePosition( 3 ); //pp3 = new ParsePosition( 5 ); ParsePosition pp4(5); if ( pp2 != pp3) { logln("PP not equals tested."); }else{ errln("*** PP not equals fails"); } if (pp3 == pp4) { logln("PP equals tested."); }else{ errln(UnicodeString("*** PP equals fails (") + pp3.getIndex() + " != " + pp4.getIndex() + ")"); } ParsePosition pp5; pp5 = pp4; if (pp4 == pp5) { logln("PP operator= tested."); }else{ errln("*** PP operator= operator== or operator != result"); } ParsePosition *ppp = pp5.clone(); if(ppp == &pp5 || *ppp != pp5) { errln("ParsePosition.clone() failed"); } delete ppp; } void ParsePositionTest::TestFieldPosition() { FieldPosition fp( 7 ); if (fp.getField() == 7) { logln("FP constructor(int) and getField tested."); }else{ errln("*** FP constructor(int) or getField"); } FieldPosition fpc(fp); if (fpc.getField() == 7) { logln("FP Constructor(FP&) passed"); } else { errln("*** FP Constructor(FP&)"); } FieldPosition fph( 3 ); if ( fph.getField() != 3) errln("*** FP getField or heap constr."); UBool err1 = FALSE; UBool err2 = FALSE; UBool err3 = FALSE; // for (long i = -50; i < 50; i++ ) { // fp.setField( i+8 ); // fp.setBeginIndex( i+6 ); // fp.setEndIndex( i+7 ); // if (fp.getField() != i+8) err1 = TRUE; // if (fp.getBeginIndex() != i+6) err2 = TRUE; // if (fp.getEndIndex() != i+7) err3 = TRUE; // } if (!err1) { logln("FP setField and getField tested."); }else{ errln("*** FP setField or getField"); } if (!err2) { logln("FP setBeginIndex and getBeginIndex tested."); }else{ errln("*** FP setBeginIndex or getBeginIndex"); } if (!err3) { logln("FP setEndIndex and getEndIndex tested."); }else{ errln("*** FP setEndIndex or getEndIndex"); } logln(""); FieldPosition *pfp = fp.clone(); if(pfp == &fp || *pfp != fp) { errln("FieldPosition.clone() failed"); } delete pfp; } void ParsePositionTest::TestFieldPosition_example() { //***** no error detection yet !!!!!!! //***** this test is for compiler checks and visual verification only. double doubleNum[] = { 123456789.0, -12345678.9, 1234567.89, -123456.789, 12345.6789, -1234.56789, 123.456789, -12.3456789, 1.23456789}; int dNumSize = 9; UErrorCode status = U_ZERO_ERROR; NumberFormat *nf = NumberFormat::createInstance(status); if (failure(status, "NumberFormat::createInstance", TRUE)){ delete nf; return; }; DecimalFormat *fmt = dynamic_cast<DecimalFormat *>(nf); if(fmt == NULL) { errln("NumberFormat::createInstance returned unexpected class type"); return; } fmt->setDecimalSeparatorAlwaysShown(TRUE); const int tempLen = 20; UnicodeString temp; for (int i=0; i < dNumSize; i++) { temp.remove(); //temp = new StringBuffer(); // Get new buffer FieldPosition pos(NumberFormat::INTEGER_FIELD); UnicodeString buf;// = new StringBuffer(); //char fmtText[tempLen]; //ToCharString(fmt->format(doubleNum[i], buf, pos), fmtText); UnicodeString res; res = fmt->format(doubleNum[i], buf, pos); int tempOffset = (tempLen <= (tempLen - pos.getEndIndex())) ? tempLen : (tempLen - pos.getEndIndex()); for (int j=0; j<tempOffset; j++) temp += UnicodeString("="/*'='*/); // initialize logln("FP " + temp + res); } logln(""); delete nf; } /* @bug 4109023 * Need to override ParsePosition.equals and FieldPosition.equals. */ void ParsePositionTest::Test4109023() { ParsePosition p(3); ParsePosition p2(3); if (p != p2) errln("Error : ParsePosition.equals() failed"); FieldPosition fp(2); FieldPosition fp2(2); if (fp != fp2) errln("Error : FieldPosition.equals() failed"); } #endif /* #if !UCONFIG_NO_FORMATTING */