| Index: icu46/source/test/intltest/selfmts.cpp
|
| ===================================================================
|
| --- icu46/source/test/intltest/selfmts.cpp (revision 0)
|
| +++ icu46/source/test/intltest/selfmts.cpp (revision 0)
|
| @@ -0,0 +1,327 @@
|
| +/********************************************************************
|
| + * COPYRIGHT:
|
| + * Copyright (c) 1997-2010, International Business Machines Corporation and
|
| + * others. All Rights Reserved.
|
| + * Copyright (C) 2010 , Yahoo! Inc.
|
| + ********************************************************************/
|
| +
|
| +#include "unicode/utypes.h"
|
| +
|
| +#if !UCONFIG_NO_FORMATTING
|
| +
|
| +#include "selfmts.h"
|
| +#include "cmemory.h"
|
| +#include "unicode/selfmt.h"
|
| +#include "stdio.h"
|
| +
|
| +#define SIMPLE_PATTERN_STRING "feminine {feminineVerbValue} other{otherVerbValue}"
|
| +
|
| +
|
| +#define SELECT_PATTERN_DATA 4
|
| +#define SELECT_SYNTAX_DATA 10
|
| +#define EXP_FORMAT_RESULT_DATA 12
|
| +#define NUM_OF_FORMAT_ARGS 3
|
| +
|
| +#define VERBOSE_INT(x) {logln("%s:%d: int %s=%d\n", __FILE__, __LINE__, #x, (x));}
|
| +#define VERBOSE_USTRING(text) {logln("%s:%d: UnicodeString %s(%d) = ", __FILE__, __LINE__, #text, text.length()); logln(UnicodeString(" \"")+text+UnicodeString("\";"));}
|
| +
|
| +
|
| +void SelectFormatTest::runIndexedTest( int32_t index, UBool exec, const char* &name, char* /*par*/ )
|
| +{
|
| + if (exec) logln("TestSuite SelectFormat");
|
| + switch (index) {
|
| + TESTCASE(0, selectFormatAPITest);
|
| + TESTCASE(1, selectFormatUnitTest);
|
| + default: name = "";
|
| + break;
|
| + }
|
| +}
|
| +
|
| +/**
|
| + * Unit tests of SelectFormat class.
|
| + */
|
| +void SelectFormatTest::selectFormatUnitTest(/*char *par*/)
|
| +{
|
| + const UnicodeString SIMPLE_PATTERN(SIMPLE_PATTERN_STRING); /* Don't static init this! */
|
| +
|
| + UnicodeString patternTestData[SELECT_PATTERN_DATA] = {
|
| + UNICODE_STRING_SIMPLE("fem {femValue} other{even}"),
|
| + UNICODE_STRING_SIMPLE("other{odd or even}"),
|
| + UNICODE_STRING_SIMPLE("odd{The number {0, number, integer} is odd.}other{The number {0, number, integer} is even.}"),
|
| + UNICODE_STRING_SIMPLE("odd{The number {1} is odd}other{The number {1} is even}"),
|
| + };
|
| +
|
| + UnicodeString formatArgs[NUM_OF_FORMAT_ARGS] = {
|
| + UNICODE_STRING_SIMPLE("fem"),
|
| + UNICODE_STRING_SIMPLE("other"),
|
| + UNICODE_STRING_SIMPLE("odd")
|
| + };
|
| +
|
| + UnicodeString expFormatResult[][NUM_OF_FORMAT_ARGS] = {
|
| + {
|
| + UNICODE_STRING_SIMPLE("femValue"),
|
| + UNICODE_STRING_SIMPLE("even"),
|
| + UNICODE_STRING_SIMPLE("even")
|
| + },
|
| + {
|
| + UNICODE_STRING_SIMPLE("odd or even"),
|
| + UNICODE_STRING_SIMPLE("odd or even"),
|
| + UNICODE_STRING_SIMPLE("odd or even"),
|
| + },
|
| + {
|
| + UNICODE_STRING_SIMPLE("The number {0, number, integer} is even."),
|
| + UNICODE_STRING_SIMPLE("The number {0, number, integer} is even."),
|
| + UNICODE_STRING_SIMPLE("The number {0, number, integer} is odd."),
|
| + },
|
| + {
|
| + UNICODE_STRING_SIMPLE("The number {1} is even"),
|
| + UNICODE_STRING_SIMPLE("The number {1} is even"),
|
| + UNICODE_STRING_SIMPLE("The number {1} is odd"),
|
| + }
|
| + };
|
| +
|
| + UnicodeString checkSyntaxData[SELECT_SYNTAX_DATA] = {
|
| + UNICODE_STRING_SIMPLE("odd{foo} odd{bar} other{foobar}"),
|
| + UNICODE_STRING_SIMPLE("odd{foo} other{bar} other{foobar}"),
|
| + UNICODE_STRING_SIMPLE("odd{foo}"),
|
| + UNICODE_STRING_SIMPLE("1odd{foo} other{bar}"),
|
| + UNICODE_STRING_SIMPLE("odd{foo},other{bar}"),
|
| + UNICODE_STRING_SIMPLE("od d{foo} other{bar}"),
|
| + UNICODE_STRING_SIMPLE("odd{foo}{foobar}other{foo}"),
|
| + UNICODE_STRING_SIMPLE("odd{foo1}other{foo2}}"),
|
| + UNICODE_STRING_SIMPLE("odd{foo1}other{{foo2}"),
|
| + UNICODE_STRING_SIMPLE("odd{fo{o1}other{foo2}}")
|
| + };
|
| +
|
| + UErrorCode expErrorCodes[SELECT_SYNTAX_DATA]={
|
| + U_DUPLICATE_KEYWORD,
|
| + U_DUPLICATE_KEYWORD,
|
| + U_DEFAULT_KEYWORD_MISSING,
|
| + U_PATTERN_SYNTAX_ERROR,
|
| + U_PATTERN_SYNTAX_ERROR,
|
| + U_PATTERN_SYNTAX_ERROR,
|
| + U_PATTERN_SYNTAX_ERROR,
|
| + U_PATTERN_SYNTAX_ERROR,
|
| + U_PATTERN_SYNTAX_ERROR,
|
| + U_DEFAULT_KEYWORD_MISSING
|
| + };
|
| +
|
| + UErrorCode status = U_ZERO_ERROR;
|
| + VERBOSE_USTRING(SIMPLE_PATTERN);
|
| + SelectFormat* selFmt = new SelectFormat( SIMPLE_PATTERN , status);
|
| + if (U_FAILURE(status)) {
|
| + dataerrln("ERROR: SelectFormat Unit Test constructor failed in unit tests.- exitting");
|
| + return;
|
| + }
|
| +
|
| + // ======= Test SelectFormat pattern syntax.
|
| + logln("SelectFormat Unit Test : Testing SelectFormat pattern syntax.");
|
| + for (int32_t i=0; i<SELECT_SYNTAX_DATA; ++i) {
|
| + status = U_ZERO_ERROR;
|
| + VERBOSE_INT(i);
|
| + VERBOSE_USTRING(checkSyntaxData[i]);
|
| + selFmt->applyPattern(checkSyntaxData[i], status);
|
| + if( status!= expErrorCodes[i] ){
|
| + errln("\nERROR: Unexpected result - SelectFormat Unit Test failed to detect syntax error with pattern: "+checkSyntaxData[i]+" and expected status="+ u_errorName(expErrorCodes[i]) + " and resulted status="+u_errorName(status));
|
| + }
|
| + }
|
| +
|
| + delete selFmt;
|
| + selFmt = NULL;
|
| +
|
| + logln("SelectFormat Unit Test : Creating format object for Testing applying various patterns");
|
| + status = U_ZERO_ERROR;
|
| + selFmt = new SelectFormat( SIMPLE_PATTERN , status);
|
| + //SelectFormat* selFmt1 = new SelectFormat( SIMPLE_PATTERN , status);
|
| + if (U_FAILURE(status)) {
|
| + errln("ERROR: SelectFormat Unit Test constructor failed in unit tests.- exitting");
|
| + return;
|
| + }
|
| +
|
| + // ======= Test applying and formatting with various pattern
|
| + logln("SelectFormat Unit test: Testing applyPattern() and format() ...");
|
| + UnicodeString result;
|
| + FieldPosition ignore(FieldPosition::DONT_CARE);
|
| +
|
| + for(int32_t i=0; i<SELECT_PATTERN_DATA; ++i) {
|
| + status = U_ZERO_ERROR;
|
| + selFmt->applyPattern(patternTestData[i], status);
|
| + if (U_FAILURE(status)) {
|
| + errln("ERROR: SelectFormat Unit Test failed to apply pattern- "+patternTestData[i] );
|
| + continue;
|
| + }
|
| +
|
| + //Format with the keyword array
|
| + for(int32_t j=0; j<3; j++) {
|
| + result.remove();
|
| + selFmt->format( formatArgs[j], result , ignore , status);
|
| + if (U_FAILURE(status)) {
|
| + errln("ERROR: SelectFormat Unit test failed in format() with argument: "+ formatArgs[j] + " and error is " + u_errorName(status) );
|
| + }else{
|
| + if( result != expFormatResult[i][j] ){
|
| + errln("ERROR: SelectFormat Unit test failed in format() with unexpected result\n with argument: "+ formatArgs[j] + "\n result obtained: " + result + "\n and expected is: " + expFormatResult[i][j] );
|
| + }
|
| + }
|
| + }
|
| + }
|
| +
|
| + //Test with an invalid keyword
|
| + logln("SelectFormat Unit test: Testing format() with keyword method and with invalid keywords...");
|
| + status = U_ZERO_ERROR;
|
| + result.remove();
|
| + UnicodeString keywords[] = {
|
| + "9Keyword-_", //Starts with a digit
|
| + "-Keyword-_", //Starts with a hyphen
|
| + "_Keyword-_", //Starts with a underscore
|
| + "\\u00E9Keyword-_", //Starts with non-ASCII character
|
| + "Key*word-_", //Contains a sepial character not allowed
|
| + "*Keyword-_" //Starts with a sepial character not allowed
|
| + };
|
| +
|
| + delete selFmt;
|
| + selFmt = NULL;
|
| +
|
| + selFmt = new SelectFormat( SIMPLE_PATTERN , status);
|
| + for (int32_t i = 0; i< 6; i++ ){
|
| + status = U_ZERO_ERROR;
|
| + selFmt->format( keywords[i], result , ignore , status);
|
| + if (!U_FAILURE(status)) {
|
| + errln("ERROR: SelectFormat Unit test failed in format() with keyWord and with an invalid keyword as : "+ keywords[i]);
|
| + }
|
| + }
|
| +
|
| + delete selFmt;
|
| +}
|
| +
|
| +/**
|
| + * Test various generic API methods of SelectFormat for Basic API usage.
|
| + * This is to make sure the API test coverage is 100% .
|
| + */
|
| +void SelectFormatTest::selectFormatAPITest(/*char *par*/)
|
| +{
|
| + const UnicodeString SIMPLE_PATTERN(SIMPLE_PATTERN_STRING); /* Don't static init this! */
|
| + int numOfConstructors =3;
|
| + UErrorCode status[3];
|
| + SelectFormat* selFmt[3] = { NULL, NULL, NULL };
|
| +
|
| + // ========= Test constructors
|
| + logln("SelectFormat API test: Testing SelectFormat constructors ...");
|
| + for (int32_t i=0; i< numOfConstructors; ++i) {
|
| + status[i] = U_ZERO_ERROR;
|
| + }
|
| +
|
| + selFmt[0]= new SelectFormat(SIMPLE_PATTERN, status[0]);
|
| + if ( U_FAILURE(status[0]) ) {
|
| + errln("ERROR: SelectFormat API test constructor with pattern and status failed! with %s\n", u_errorName(status[0]));
|
| + return;
|
| + }
|
| +
|
| + // =========== Test copy constructor
|
| + logln("SelectFormat API test: Testing copy constructor and == operator ...");
|
| + SelectFormat fmt = *selFmt[0];
|
| + SelectFormat* dupPFmt = new SelectFormat(fmt);
|
| + if ((*selFmt[0]) != (*dupPFmt)) {
|
| + errln("ERROR: SelectFormat API test Failed in copy constructor or == operator!");
|
| + }
|
| + delete dupPFmt;
|
| +
|
| + // ======= Test clone && == operator.
|
| + logln("SelectFormat API test: Testing clone and == operator ...");
|
| + if ( U_SUCCESS(status[0]) ) {
|
| + selFmt[1] = (SelectFormat*)selFmt[0]->clone();
|
| + if (selFmt[1]!=NULL) {
|
| + if ( *selFmt[1] != *selFmt[0] ) {
|
| + errln("ERROR: SelectFormat API test clone test failed!");
|
| + }
|
| + } else {
|
| + errln("ERROR: SelectFormat API test clone test failed with NULL!");
|
| + return;
|
| + }
|
| + } else {
|
| + errln("ERROR: could not create [0]: %s\n", u_errorName(status[0]));
|
| + return;
|
| + }
|
| +
|
| + // ======= Test assignment operator && == operator.
|
| + logln("SelectFormat API test: Testing assignment operator and == operator ...");
|
| + selFmt[2]= new SelectFormat(SIMPLE_PATTERN, status[2]);
|
| + if ( U_SUCCESS(status[2]) ) {
|
| + *selFmt[1] = *selFmt[2];
|
| + if (selFmt[1]!=NULL) {
|
| + if ( (*selFmt[1] != *selFmt[2]) ) {
|
| + errln("ERROR: SelectFormat API test assignment operator test failed!");
|
| + }
|
| + }
|
| + delete selFmt[1];
|
| + }
|
| + else {
|
| + errln("ERROR: SelectFormat constructor failed in assignment operator!");
|
| + }
|
| + delete selFmt[0];
|
| + delete selFmt[2];
|
| +
|
| + // ======= Test getStaticClassID() and getStaticClassID()
|
| + logln("SelectFormat API test: Testing getStaticClassID() and getStaticClassID() ...");
|
| + UErrorCode status1 = U_ZERO_ERROR;
|
| + SelectFormat* selFmt1 = new SelectFormat( SIMPLE_PATTERN , status1);
|
| + if( U_FAILURE(status1)) {
|
| + errln("ERROR: SelectFormat constructor failed in staticClassID test! Exitting");
|
| + return;
|
| + }
|
| +
|
| + logln("Testing getStaticClassID()");
|
| + if(selFmt1->getDynamicClassID() !=SelectFormat::getStaticClassID()) {
|
| + errln("ERROR: SelectFormat API test getDynamicClassID() didn't return the expected value");
|
| + }
|
| +
|
| + // ======= Test applyPattern() and toPattern()
|
| + logln("SelectFormat API test: Testing applyPattern() and toPattern() ...");
|
| + UnicodeString pattern = UnicodeString("masculine{masculineVerbValue} other{otherVerbValue}");
|
| + status1 = U_ZERO_ERROR;
|
| + selFmt1->applyPattern( pattern, status1);
|
| + if (U_FAILURE(status1)) {
|
| + errln("ERROR: SelectFormat API test failed in applyPattern() with pattern: "+ pattern);
|
| + }else{
|
| + UnicodeString checkPattern;
|
| + selFmt1->toPattern( checkPattern);
|
| + if( checkPattern != pattern ){
|
| + errln("ERROR: SelectFormat API test failed in toPattern() with unexpected result with pattern: "+ pattern);
|
| + }
|
| + }
|
| +
|
| + // ======= Test different format() methods
|
| + logln("SelectFormat API test: Testing format() with keyword method ...");
|
| + status1 = U_ZERO_ERROR;
|
| + UnicodeString result;
|
| + FieldPosition ignore(FieldPosition::DONT_CARE);
|
| + UnicodeString keyWord = UnicodeString("masculine");
|
| +
|
| + selFmt1->format( keyWord, result , ignore , status1);
|
| + if (U_FAILURE(status1)) {
|
| + errln("ERROR: SelectFormat API test failed in format() with keyWord: "+ keyWord);
|
| + }else{
|
| + UnicodeString expected=UnicodeString("masculineVerbValue");
|
| + if( result != expected ){
|
| + errln("ERROR: SelectFormat API test failed in format() with unexpected result with keyWord: "+ keyWord);
|
| + }
|
| + }
|
| +
|
| + logln("SelectFormat API test: Testing format() with Formattable obj method ...");
|
| + status1 = U_ZERO_ERROR;
|
| + result.remove();
|
| + UnicodeString result1;
|
| + Formattable testArgs = Formattable("other");
|
| + selFmt1->format( testArgs, result1 , ignore , status1);
|
| + if (U_FAILURE(status1)) {
|
| + errln("ERROR: SelectFormat API test failed in format() with Formattable");
|
| + }else{
|
| + UnicodeString expected=UnicodeString("otherVerbValue");
|
| + if( result1 != expected ){
|
| + errln("ERROR: SelectFormat API test failed in format() with unexpected result with Formattable");
|
| + }
|
| + }
|
| +
|
| +
|
| + delete selFmt1;
|
| +}
|
| +#endif /* #if !UCONFIG_NO_FORMATTING */
|
|
|
| Property changes on: icu46/source/test/intltest/selfmts.cpp
|
| ___________________________________________________________________
|
| Added: svn:eol-style
|
| + LF
|
|
|
|
|