2008-09-19 19:05:37 +00:00
/********************************************************************
2011-04-28 16:42:58 +00:00
* Copyright ( c ) 2008 - 2011 , International Business Machines Corporation and
2008-09-19 19:05:37 +00:00
* others . All Rights Reserved .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# include "unicode/utypes.h"
# if !UCONFIG_NO_FORMATTING
# include "unicode/tmunit.h"
# include "unicode/tmutamt.h"
# include "unicode/tmutfmt.h"
# include "tufmtts.h"
2010-10-19 08:28:02 +00:00
# include "unicode/ustring.h"
2008-09-19 19:05:37 +00:00
2008-10-22 06:06:56 +00:00
//TODO: put as compilation flag
2008-09-19 19:05:37 +00:00
//#define TUFMTTS_DEBUG 1
# ifdef TUFMTTS_DEBUG
# include <iostream>
# endif
void TimeUnitTest : : runIndexedTest ( int32_t index , UBool exec , const char * & name , char * /*par*/ ) {
if ( exec ) logln ( " TestSuite TimeUnitTest " ) ;
switch ( index ) {
TESTCASE ( 0 , testBasic ) ;
TESTCASE ( 1 , testAPI ) ;
2010-10-19 08:28:02 +00:00
TESTCASE ( 2 , testGreek ) ;
2008-09-19 19:05:37 +00:00
default : name = " " ; break ;
}
}
/**
* Test basic
*/
void TimeUnitTest : : testBasic ( ) {
2010-10-19 08:28:02 +00:00
const char * locales [ ] = { " en " , " sl " , " fr " , " zh " , " ar " , " ru " , " zh_Hant " , " pa " } ;
2008-09-19 19:05:37 +00:00
for ( unsigned int locIndex = 0 ;
locIndex < sizeof ( locales ) / sizeof ( locales [ 0 ] ) ;
+ + locIndex ) {
UErrorCode status = U_ZERO_ERROR ;
Locale loc ( locales [ locIndex ] ) ;
TimeUnitFormat * * formats = new TimeUnitFormat * [ 2 ] ;
2011-04-28 16:42:58 +00:00
formats [ UTMUTFMT_FULL_STYLE ] = new TimeUnitFormat ( loc , status ) ;
2009-06-12 19:34:21 +00:00
if ( ! assertSuccess ( " TimeUnitFormat(full) " , status , TRUE ) ) return ;
2011-04-28 16:42:58 +00:00
formats [ UTMUTFMT_ABBREVIATED_STYLE ] = new TimeUnitFormat ( loc , UTMUTFMT_ABBREVIATED_STYLE , status ) ;
2008-09-19 19:05:37 +00:00
if ( ! assertSuccess ( " TimeUnitFormat(short) " , status ) ) return ;
# ifdef TUFMTTS_DEBUG
std : : cout < < " locale: " < < locales [ locIndex ] < < " \n " ;
# endif
2011-04-28 16:42:58 +00:00
for ( int style = UTMUTFMT_FULL_STYLE ;
style < = UTMUTFMT_ABBREVIATED_STYLE ;
2008-09-19 19:05:37 +00:00
+ + style ) {
for ( TimeUnit : : UTimeUnitFields j = TimeUnit : : UTIMEUNIT_YEAR ;
j < TimeUnit : : UTIMEUNIT_FIELD_COUNT ;
j = ( TimeUnit : : UTimeUnitFields ) ( j + 1 ) ) {
# ifdef TUFMTTS_DEBUG
std : : cout < < " time unit: " < < j < < " \n " ;
# endif
double tests [ ] = { 0 , 0.5 , 1 , 1.5 , 2 , 2.5 , 3 , 3.5 , 5 , 10 , 100 , 101.35 } ;
for ( unsigned int i = 0 ; i < sizeof ( tests ) / sizeof ( tests [ 0 ] ) ; + + i ) {
# ifdef TUFMTTS_DEBUG
std : : cout < < " number: " < < tests [ i ] < < " \n " ;
# endif
TimeUnitAmount * source = new TimeUnitAmount ( tests [ i ] , j , status ) ;
if ( ! assertSuccess ( " TimeUnitAmount() " , status ) ) return ;
UnicodeString formatted ;
Formattable formattable ;
formattable . adoptObject ( source ) ;
formatted = ( ( Format * ) formats [ style ] ) - > format ( formattable , formatted , status ) ;
if ( ! assertSuccess ( " format() " , status ) ) return ;
# ifdef TUFMTTS_DEBUG
char formatResult [ 1000 ] ;
formatted . extract ( 0 , formatted . length ( ) , formatResult , " UTF-8 " ) ;
std : : cout < < " format result: " < < formatResult < < " \n " ;
# endif
Formattable result ;
( ( Format * ) formats [ style ] ) - > parseObject ( formatted , result , status ) ;
if ( ! assertSuccess ( " parseObject() " , status ) ) return ;
if ( result ! = formattable ) {
dataerrln ( " No round trip: " ) ;
}
// other style parsing
Formattable result_1 ;
( ( Format * ) formats [ 1 - style ] ) - > parseObject ( formatted , result_1 , status ) ;
if ( ! assertSuccess ( " parseObject() " , status ) ) return ;
if ( result_1 ! = formattable ) {
dataerrln ( " No round trip: " ) ;
}
}
}
}
2011-04-28 16:42:58 +00:00
delete formats [ UTMUTFMT_FULL_STYLE ] ;
delete formats [ UTMUTFMT_ABBREVIATED_STYLE ] ;
2008-09-19 19:05:37 +00:00
delete [ ] formats ;
}
}
void TimeUnitTest : : testAPI ( ) {
//================= TimeUnit =================
UErrorCode status = U_ZERO_ERROR ;
TimeUnit * tmunit = TimeUnit : : createInstance ( TimeUnit : : UTIMEUNIT_YEAR , status ) ;
if ( ! assertSuccess ( " TimeUnit::createInstance " , status ) ) return ;
TimeUnit * another = ( TimeUnit * ) tmunit - > clone ( ) ;
TimeUnit third ( * tmunit ) ;
TimeUnit fourth = third ;
assertTrue ( " orig and clone are equal " , ( * tmunit = = * another ) ) ;
assertTrue ( " copied and assigned are equal " , ( third = = fourth ) ) ;
TimeUnit * tmunit_m = TimeUnit : : createInstance ( TimeUnit : : UTIMEUNIT_MONTH , status ) ;
assertTrue ( " year != month " , ( * tmunit ! = * tmunit_m ) ) ;
TimeUnit : : UTimeUnitFields field = tmunit_m - > getTimeUnitField ( ) ;
assertTrue ( " field of month time unit is month " , ( field = = TimeUnit : : UTIMEUNIT_MONTH ) ) ;
delete tmunit ;
delete another ;
delete tmunit_m ;
//
//================= TimeUnitAmount =================
2008-09-22 22:43:55 +00:00
Formattable formattable ( ( int32_t ) 2 ) ;
2008-09-19 19:05:37 +00:00
TimeUnitAmount tma_long ( formattable , TimeUnit : : UTIMEUNIT_DAY , status ) ;
if ( ! assertSuccess ( " TimeUnitAmount(formattable...) " , status ) ) return ;
formattable . setDouble ( 2 ) ;
TimeUnitAmount tma_double ( formattable , TimeUnit : : UTIMEUNIT_DAY , status ) ;
if ( ! assertSuccess ( " TimeUnitAmount(formattable...) " , status ) ) return ;
formattable . setDouble ( 3 ) ;
TimeUnitAmount tma_double_3 ( formattable , TimeUnit : : UTIMEUNIT_DAY , status ) ;
if ( ! assertSuccess ( " TimeUnitAmount(formattable...) " , status ) ) return ;
TimeUnitAmount tma ( 2 , TimeUnit : : UTIMEUNIT_DAY , status ) ;
if ( ! assertSuccess ( " TimeUnitAmount(number...) " , status ) ) return ;
TimeUnitAmount tma_h ( 2 , TimeUnit : : UTIMEUNIT_HOUR , status ) ;
if ( ! assertSuccess ( " TimeUnitAmount(number...) " , status ) ) return ;
TimeUnitAmount second ( tma ) ;
TimeUnitAmount third_tma = tma ;
TimeUnitAmount * fourth_tma = ( TimeUnitAmount * ) tma . clone ( ) ;
assertTrue ( " orig and copy are equal " , ( second = = tma ) ) ;
assertTrue ( " clone and assigned are equal " , ( third_tma = = * fourth_tma ) ) ;
assertTrue ( " different if number diff " , ( tma_double ! = tma_double_3 ) ) ;
assertTrue ( " different if number type diff " , ( tma_double ! = tma_long ) ) ;
assertTrue ( " different if time unit diff " , ( tma ! = tma_h ) ) ;
assertTrue ( " same even different constructor " , ( tma_double = = tma ) ) ;
assertTrue ( " getTimeUnitField " , ( tma . getTimeUnitField ( ) = = TimeUnit : : UTIMEUNIT_DAY ) ) ;
delete fourth_tma ;
//
//================= TimeUnitFormat =================
//
TimeUnitFormat * tmf_en = new TimeUnitFormat ( Locale ( " en " ) , status ) ;
2009-06-12 19:34:21 +00:00
if ( ! assertSuccess ( " TimeUnitFormat(en...) " , status , TRUE ) ) return ;
2008-09-19 19:05:37 +00:00
TimeUnitFormat tmf_fr ( Locale ( " fr " ) , status ) ;
if ( ! assertSuccess ( " TimeUnitFormat(fr...) " , status ) ) return ;
assertTrue ( " TimeUnitFormat: en and fr diff " , ( * tmf_en ! = tmf_fr ) ) ;
TimeUnitFormat tmf_assign = * tmf_en ;
assertTrue ( " TimeUnitFormat: orig and assign are equal " , ( * tmf_en = = tmf_assign ) ) ;
TimeUnitFormat tmf_copy ( tmf_fr ) ;
assertTrue ( " TimeUnitFormat: orig and copy are equal " , ( tmf_fr = = tmf_copy ) ) ;
TimeUnitFormat * tmf_clone = ( TimeUnitFormat * ) tmf_en - > clone ( ) ;
assertTrue ( " TimeUnitFormat: orig and clone are equal " , ( * tmf_en = = * tmf_clone ) ) ;
delete tmf_clone ;
tmf_en - > setLocale ( Locale ( " fr " ) , status ) ;
if ( ! assertSuccess ( " setLocale(fr...) " , status ) ) return ;
NumberFormat * numberFmt = NumberFormat : : createInstance (
Locale ( " fr " ) , status ) ;
if ( ! assertSuccess ( " NumberFormat::createInstance() " , status ) ) return ;
tmf_en - > setNumberFormat ( * numberFmt , status ) ;
if ( ! assertSuccess ( " setNumberFormat(en...) " , status ) ) return ;
assertTrue ( " TimeUnitFormat: setLocale " , ( * tmf_en = = tmf_fr ) ) ;
delete tmf_en ;
2011-04-28 16:42:58 +00:00
TimeUnitFormat * en_long = new TimeUnitFormat ( Locale ( " en " ) , UTMUTFMT_FULL_STYLE , status ) ;
2008-09-19 19:05:37 +00:00
if ( ! assertSuccess ( " TimeUnitFormat(en...) " , status ) ) return ;
delete en_long ;
2011-04-28 16:42:58 +00:00
TimeUnitFormat * en_short = new TimeUnitFormat ( Locale ( " en " ) , UTMUTFMT_ABBREVIATED_STYLE , status ) ;
2008-09-19 19:05:37 +00:00
if ( ! assertSuccess ( " TimeUnitFormat(en...) " , status ) ) return ;
delete en_short ;
TimeUnitFormat * format = new TimeUnitFormat ( status ) ;
format - > setLocale ( Locale ( " zh " ) , status ) ;
format - > setNumberFormat ( * numberFmt , status ) ;
if ( ! assertSuccess ( " TimeUnitFormat(en...) " , status ) ) return ;
delete numberFmt ;
delete format ;
}
2010-10-19 08:28:02 +00:00
/* @bug 7902
* Tests for Greek Language .
* This tests that requests for short unit names correctly fall back
* to long unit names for a locale where the locale data does not
* provide short unit names . As of CLDR 1.9 , Greek is one such language .
*/
void TimeUnitTest : : testGreek ( ) {
UErrorCode status = U_ZERO_ERROR ;
const char * locales [ ] = { " el-GR " , " el " } ;
TimeUnit : : UTimeUnitFields tunits [ ] = { TimeUnit : : UTIMEUNIT_SECOND , TimeUnit : : UTIMEUNIT_MINUTE , TimeUnit : : UTIMEUNIT_HOUR , TimeUnit : : UTIMEUNIT_DAY , TimeUnit : : UTIMEUNIT_MONTH , TimeUnit : : UTIMEUNIT_YEAR } ;
2011-04-28 16:42:58 +00:00
UTimeUnitFormatStyle styles [ ] = { UTMUTFMT_FULL_STYLE , UTMUTFMT_ABBREVIATED_STYLE } ;
2010-10-19 08:28:02 +00:00
const int numbers [ ] = { 1 , 7 } ;
const UChar oneSecond [ ] = { 0x0031 , 0x0020 , 0x03b4 , 0x03b5 , 0x03c5 , 0x03c4 , 0x03b5 , 0x03c1 , 0x03cc , 0x03bb , 0x03b5 , 0x03c0 , 0x03c4 , 0x03bf , 0 } ;
const UChar oneMinute [ ] = { 0x0031 , 0x0020 , 0x03bb , 0x03b5 , 0x03c0 , 0x03c4 , 0x03cc , 0 } ;
const UChar oneHour [ ] = { 0x0031 , 0x0020 , 0x03ce , 0x03c1 , 0x03b1 , 0 } ;
const UChar oneDay [ ] = { 0x0031 , 0x0020 , 0x03b7 , 0x03bc , 0x03ad , 0x03c1 , 0x03b1 , 0 } ;
const UChar oneMonth [ ] = { 0x0031 , 0x0020 , 0x03bc , 0x03ae , 0x03bd , 0x03b1 , 0x03c2 , 0 } ;
const UChar oneYear [ ] = { 0x0031 , 0x0020 , 0x03ad , 0x03c4 , 0x03bf , 0x03c2 , 0 } ;
const UChar sevenSeconds [ ] = { 0x0037 , 0x0020 , 0x03b4 , 0x03b5 , 0x03c5 , 0x03c4 , 0x03b5 , 0x03c1 , 0x03cc , 0x03bb , 0x03b5 , 0x03c0 , 0x03c4 , 0x03b1 , 0 } ;
const UChar sevenMinutes [ ] = { 0x0037 , 0x0020 , 0x03bb , 0x03b5 , 0x03c0 , 0x03c4 , 0x03ac , 0 } ;
const UChar sevenHours [ ] = { 0x0037 , 0x0020 , 0x03ce , 0x03c1 , 0x03b5 , 0x03c2 , 0 } ;
const UChar sevenDays [ ] = { 0x0037 , 0x0020 , 0x03b7 , 0x03bc , 0x03ad , 0x03c1 , 0x03b5 , 0x03c2 , 0 } ;
const UChar sevenMonths [ ] = { 0x0037 , 0x0020 , 0x03bc , 0x03ae , 0x03bd , 0x03b5 , 0x3c2 , 0 } ;
const UChar sevenYears [ ] = { 0x0037 , 0x0020 , 0x03ad , 0x03c4 , 0x03b7 , 0 } ;
const UnicodeString oneSecondStr ( oneSecond ) ;
const UnicodeString oneMinuteStr ( oneMinute ) ;
const UnicodeString oneHourStr ( oneHour ) ;
const UnicodeString oneDayStr ( oneDay ) ;
const UnicodeString oneMonthStr ( oneMonth ) ;
const UnicodeString oneYearStr ( oneYear ) ;
const UnicodeString sevenSecondsStr ( sevenSeconds ) ;
const UnicodeString sevenMinutesStr ( sevenMinutes ) ;
const UnicodeString sevenHoursStr ( sevenHours ) ;
const UnicodeString sevenDaysStr ( sevenDays ) ;
const UnicodeString sevenMonthsStr ( sevenMonths ) ;
const UnicodeString sevenYearsStr ( sevenYears ) ;
const UnicodeString expected [ ] = { oneSecondStr , oneMinuteStr , oneHourStr , oneDayStr , oneMonthStr , oneYearStr ,
oneSecondStr , oneMinuteStr , oneHourStr , oneDayStr , oneMonthStr , oneYearStr ,
sevenSecondsStr , sevenMinutesStr , sevenHoursStr , sevenDaysStr , sevenMonthsStr , sevenYearsStr ,
sevenSecondsStr , sevenMinutesStr , sevenHoursStr , sevenDaysStr , sevenMonthsStr , sevenYearsStr ,
oneSecondStr , oneMinuteStr , oneHourStr , oneDayStr , oneMonthStr , oneYearStr ,
oneSecondStr , oneMinuteStr , oneHourStr , oneDayStr , oneMonthStr , oneYearStr ,
sevenSecondsStr , sevenMinutesStr , sevenHoursStr , sevenDaysStr , sevenMonthsStr , sevenYearsStr ,
sevenSecondsStr , sevenMinutesStr , sevenHoursStr , sevenDaysStr , sevenMonthsStr , sevenYearsStr } ;
int counter = 0 ;
for ( unsigned int locIndex = 0 ;
locIndex < sizeof ( locales ) / sizeof ( locales [ 0 ] ) ;
+ + locIndex ) {
Locale l = Locale : : createFromName ( locales [ locIndex ] ) ;
for ( unsigned int numberIndex = 0 ;
numberIndex < sizeof ( numbers ) / sizeof ( int ) ;
+ + numberIndex ) {
for ( unsigned int styleIndex = 0 ;
styleIndex < sizeof ( styles ) / sizeof ( styles [ 0 ] ) ;
+ + styleIndex ) {
for ( unsigned int unitIndex = 0 ;
unitIndex < sizeof ( tunits ) / sizeof ( tunits [ 0 ] ) ;
+ + unitIndex ) {
TimeUnitAmount * tamt = new TimeUnitAmount ( numbers [ numberIndex ] , tunits [ unitIndex ] , status ) ;
2010-11-11 05:37:40 +00:00
if ( U_FAILURE ( status ) ) {
dataerrln ( " generating TimeUnitAmount Object failed. " ) ;
2010-10-19 08:28:02 +00:00
# ifdef TUFMTTS_DEBUG
std : : cout < < " Failed to get TimeUnitAmount for " < < tunits [ unitIndex ] < < " \n " ;
# endif
return ;
}
TimeUnitFormat * tfmt = new TimeUnitFormat ( l , styles [ styleIndex ] , status ) ;
2010-11-11 05:37:40 +00:00
if ( U_FAILURE ( status ) ) {
dataerrln ( " generating TimeUnitAmount Object failed. " ) ;
2010-10-19 08:28:02 +00:00
# ifdef TUFMTTS_DEBUG
std : : cout < < " Failed to get TimeUnitFormat for " < < locales [ locIndex ] < < " \n " ;
# endif
return ;
}
Formattable fmt ;
UnicodeString str ;
fmt . adoptObject ( tamt ) ;
str = ( ( Format * ) tfmt ) - > format ( fmt , str , status ) ;
if ( ! assertSuccess ( " formatting relative time failed " , status ) ) {
delete tfmt ;
# ifdef TUFMTTS_DEBUG
std : : cout < < " Failed to format " < < " \n " ;
# endif
return ;
}
# ifdef TUFMTTS_DEBUG
char tmp [ 128 ] ; //output
char tmp1 [ 128 ] ; //expected
int len = 0 ;
u_strToUTF8 ( tmp , 128 , & len , str . getTerminatedBuffer ( ) , str . length ( ) , & status ) ;
u_strToUTF8 ( tmp1 , 128 , & len , expected [ counter ] . unescape ( ) . getTerminatedBuffer ( ) , expected [ counter ] . unescape ( ) . length ( ) , & status ) ;
std : : cout < < " Formatted string : " < < tmp < < " expected : " < < tmp1 < < " \n " ;
# endif
if ( ! assertEquals ( " formatted time string is not expected, locale: " + UnicodeString ( locales [ locIndex ] ) + " style: " + ( int ) styles [ styleIndex ] + " units: " + ( int ) tunits [ unitIndex ] , expected [ counter ] , str ) ) {
delete tfmt ;
str . remove ( ) ;
return ;
}
delete tfmt ;
str . remove ( ) ;
+ + counter ;
}
}
}
}
}
2008-09-19 19:05:37 +00:00
# endif