| /************************************************************************ |
| * COPYRIGHT: |
| * Copyright (c) 1997-2015, International Business Machines Corporation |
| * and others. All Rights Reserved. |
| ************************************************************************/ |
| #include "unicode/utypes.h" |
| |
| #if !UCONFIG_NO_FORMATTING |
| |
| #include "caltest.h" |
| #include "unicode/dtfmtsym.h" |
| #include "unicode/gregocal.h" |
| #include "unicode/localpointer.h" |
| #include "hebrwcal.h" |
| #include "unicode/smpdtfmt.h" |
| #include "unicode/simpletz.h" |
| #include "dbgutil.h" |
| #include "unicode/udat.h" |
| #include "unicode/ustring.h" |
| #include "cstring.h" |
| #include "unicode/localpointer.h" |
| #include "islamcal.h" |
| |
| #define mkcstr(U) u_austrcpy(calloc(8, u_strlen(U) + 1), U) |
| |
| #define TEST_CHECK_STATUS { \ |
| if (U_FAILURE(status)) { \ |
| if (status == U_MISSING_RESOURCE_ERROR) { \ |
| dataerrln("%s:%d: Test failure. status=%s", __FILE__, __LINE__, u_errorName(status)); \ |
| } else { \ |
| errln("%s:%d: Test failure. status=%s", __FILE__, __LINE__, u_errorName(status)); \ |
| } return;}} |
| |
| #define TEST_CHECK_STATUS_LOCALE(testlocale) { \ |
| if (U_FAILURE(status)) { \ |
| if (status == U_MISSING_RESOURCE_ERROR) { \ |
| dataerrln("%s:%d: Test failure, locale %s. status=%s", __FILE__, __LINE__, testlocale, u_errorName(status)); \ |
| } else { \ |
| errln("%s:%d: Test failure, locale %s. status=%s", __FILE__, __LINE__, testlocale, u_errorName(status)); \ |
| } return;}} |
| |
| #define TEST_ASSERT(expr) {if ((expr)==FALSE) {errln("%s:%d: Test failure \n", __FILE__, __LINE__);};} |
| |
| // ***************************************************************************** |
| // class CalendarTest |
| // ***************************************************************************** |
| |
| UnicodeString CalendarTest::calToStr(const Calendar & cal) |
| { |
| UnicodeString out; |
| UErrorCode status = U_ZERO_ERROR; |
| int i; |
| UDate d; |
| for(i = 0;i<UCAL_FIELD_COUNT;i++) { |
| out += (UnicodeString("") + fieldName((UCalendarDateFields)i) + "=" + cal.get((UCalendarDateFields)i, status) + UnicodeString(" ")); |
| } |
| out += "[" + UnicodeString(cal.getType()) + "]"; |
| |
| if(cal.inDaylightTime(status)) { |
| out += UnicodeString(" (in DST), zone="); |
| } |
| else { |
| out += UnicodeString(", zone="); |
| } |
| |
| UnicodeString str2; |
| out += cal.getTimeZone().getDisplayName(str2); |
| d = cal.getTime(status); |
| out += UnicodeString(" :","") + d; |
| |
| return out; |
| } |
| |
| void CalendarTest::runIndexedTest( int32_t index, UBool exec, const char* &name, char* /*par*/ ) |
| { |
| if (exec) logln("TestSuite TestCalendar"); |
| switch (index) { |
| case 0: |
| name = "TestDOW943"; |
| if (exec) { |
| logln("TestDOW943---"); logln(""); |
| TestDOW943(); |
| } |
| break; |
| case 1: |
| name = "TestClonesUnique908"; |
| if (exec) { |
| logln("TestClonesUnique908---"); logln(""); |
| TestClonesUnique908(); |
| } |
| break; |
| case 2: |
| name = "TestGregorianChange768"; |
| if (exec) { |
| logln("TestGregorianChange768---"); logln(""); |
| TestGregorianChange768(); |
| } |
| break; |
| case 3: |
| name = "TestDisambiguation765"; |
| if (exec) { |
| logln("TestDisambiguation765---"); logln(""); |
| TestDisambiguation765(); |
| } |
| break; |
| case 4: |
| name = "TestGMTvsLocal4064654"; |
| if (exec) { |
| logln("TestGMTvsLocal4064654---"); logln(""); |
| TestGMTvsLocal4064654(); |
| } |
| break; |
| case 5: |
| name = "TestAddSetOrder621"; |
| if (exec) { |
| logln("TestAddSetOrder621---"); logln(""); |
| TestAddSetOrder621(); |
| } |
| break; |
| case 6: |
| name = "TestAdd520"; |
| if (exec) { |
| logln("TestAdd520---"); logln(""); |
| TestAdd520(); |
| } |
| break; |
| case 7: |
| name = "TestFieldSet4781"; |
| if (exec) { |
| logln("TestFieldSet4781---"); logln(""); |
| TestFieldSet4781(); |
| } |
| break; |
| case 8: |
| name = "TestSerialize337"; |
| if (exec) { |
| logln("TestSerialize337---"); logln(""); |
| // TestSerialize337(); |
| } |
| break; |
| case 9: |
| name = "TestSecondsZero121"; |
| if (exec) { |
| logln("TestSecondsZero121---"); logln(""); |
| TestSecondsZero121(); |
| } |
| break; |
| case 10: |
| name = "TestAddSetGet0610"; |
| if (exec) { |
| logln("TestAddSetGet0610---"); logln(""); |
| TestAddSetGet0610(); |
| } |
| break; |
| case 11: |
| name = "TestFields060"; |
| if (exec) { |
| logln("TestFields060---"); logln(""); |
| TestFields060(); |
| } |
| break; |
| case 12: |
| name = "TestEpochStartFields"; |
| if (exec) { |
| logln("TestEpochStartFields---"); logln(""); |
| TestEpochStartFields(); |
| } |
| break; |
| case 13: |
| name = "TestDOWProgression"; |
| if (exec) { |
| logln("TestDOWProgression---"); logln(""); |
| TestDOWProgression(); |
| } |
| break; |
| case 14: |
| name = "TestGenericAPI"; |
| if (exec) { |
| logln("TestGenericAPI---"); logln(""); |
| TestGenericAPI(); |
| } |
| break; |
| case 15: |
| name = "TestAddRollExtensive"; |
| if (exec) { |
| logln("TestAddRollExtensive---"); logln(""); |
| TestAddRollExtensive(); |
| } |
| break; |
| case 16: |
| name = "TestDOW_LOCALandYEAR_WOY"; |
| if (exec) { |
| logln("TestDOW_LOCALandYEAR_WOY---"); logln(""); |
| TestDOW_LOCALandYEAR_WOY(); |
| } |
| break; |
| case 17: |
| name = "TestWOY"; |
| if (exec) { |
| logln("TestWOY---"); logln(""); |
| TestWOY(); |
| } |
| break; |
| case 18: |
| name = "TestRog"; |
| if (exec) { |
| logln("TestRog---"); logln(""); |
| TestRog(); |
| } |
| break; |
| case 19: |
| name = "TestYWOY"; |
| if (exec) { |
| logln("TestYWOY---"); logln(""); |
| TestYWOY(); |
| } |
| break; |
| case 20: |
| name = "TestJD"; |
| if(exec) { |
| logln("TestJD---"); logln(""); |
| TestJD(); |
| } |
| break; |
| case 21: |
| name = "TestDebug"; |
| if(exec) { |
| logln("TestDebug---"); logln(""); |
| TestDebug(); |
| } |
| break; |
| case 22: |
| name = "Test6703"; |
| if(exec) { |
| logln("Test6703---"); logln(""); |
| Test6703(); |
| } |
| break; |
| case 23: |
| name = "Test3785"; |
| if(exec) { |
| logln("Test3785---"); logln(""); |
| Test3785(); |
| } |
| break; |
| case 24: |
| name = "Test1624"; |
| if(exec) { |
| logln("Test1624---"); logln(""); |
| Test1624(); |
| } |
| break; |
| case 25: |
| name = "TestTimeStamp"; |
| if(exec) { |
| logln("TestTimeStamp---"); logln(""); |
| TestTimeStamp(); |
| } |
| break; |
| case 26: |
| name = "TestISO8601"; |
| if(exec) { |
| logln("TestISO8601---"); logln(""); |
| TestISO8601(); |
| } |
| break; |
| case 27: |
| name = "TestAmbiguousWallTimeAPIs"; |
| if(exec) { |
| logln("TestAmbiguousWallTimeAPIs---"); logln(""); |
| TestAmbiguousWallTimeAPIs(); |
| } |
| break; |
| case 28: |
| name = "TestRepeatedWallTime"; |
| if(exec) { |
| logln("TestRepeatedWallTime---"); logln(""); |
| TestRepeatedWallTime(); |
| } |
| break; |
| case 29: |
| name = "TestSkippedWallTime"; |
| if(exec) { |
| logln("TestSkippedWallTime---"); logln(""); |
| TestSkippedWallTime(); |
| } |
| break; |
| case 30: |
| name = "TestCloneLocale"; |
| if(exec) { |
| logln("TestCloneLocale---"); logln(""); |
| TestCloneLocale(); |
| } |
| break; |
| case 31: |
| name = "TestIslamicUmAlQura"; |
| if(exec) { |
| logln("TestIslamicUmAlQura---"); logln(""); |
| TestIslamicUmAlQura(); |
| } |
| break; |
| case 32: |
| name = "TestIslamicTabularDates"; |
| if(exec) { |
| logln("TestIslamicTabularDates---"); logln(""); |
| TestIslamicTabularDates(); |
| } |
| break; |
| case 33: |
| name = "TestHebrewMonthValidation"; |
| if(exec) { |
| logln("TestHebrewMonthValidation---"); logln(""); |
| TestHebrewMonthValidation(); |
| } |
| break; |
| case 34: |
| name = "TestWeekData"; |
| if(exec) { |
| logln("TestWeekData---"); logln(""); |
| TestWeekData(); |
| } |
| break; |
| case 35: |
| name = "TestAddAcrossZoneTransition"; |
| if(exec) { |
| logln("TestAddAcrossZoneTransition---"); logln(""); |
| TestAddAcrossZoneTransition(); |
| } |
| break; |
| default: name = ""; break; |
| } |
| } |
| |
| // --------------------------------------------------------------------------------- |
| |
| UnicodeString CalendarTest::fieldName(UCalendarDateFields f) { |
| switch (f) { |
| #define FIELD_NAME_STR(x) case x: return (#x+5) |
| FIELD_NAME_STR( UCAL_ERA ); |
| FIELD_NAME_STR( UCAL_YEAR ); |
| FIELD_NAME_STR( UCAL_MONTH ); |
| FIELD_NAME_STR( UCAL_WEEK_OF_YEAR ); |
| FIELD_NAME_STR( UCAL_WEEK_OF_MONTH ); |
| FIELD_NAME_STR( UCAL_DATE ); |
| FIELD_NAME_STR( UCAL_DAY_OF_YEAR ); |
| FIELD_NAME_STR( UCAL_DAY_OF_WEEK ); |
| FIELD_NAME_STR( UCAL_DAY_OF_WEEK_IN_MONTH ); |
| FIELD_NAME_STR( UCAL_AM_PM ); |
| FIELD_NAME_STR( UCAL_HOUR ); |
| FIELD_NAME_STR( UCAL_HOUR_OF_DAY ); |
| FIELD_NAME_STR( UCAL_MINUTE ); |
| FIELD_NAME_STR( UCAL_SECOND ); |
| FIELD_NAME_STR( UCAL_MILLISECOND ); |
| FIELD_NAME_STR( UCAL_ZONE_OFFSET ); |
| FIELD_NAME_STR( UCAL_DST_OFFSET ); |
| FIELD_NAME_STR( UCAL_YEAR_WOY ); |
| FIELD_NAME_STR( UCAL_DOW_LOCAL ); |
| FIELD_NAME_STR( UCAL_EXTENDED_YEAR ); |
| FIELD_NAME_STR( UCAL_JULIAN_DAY ); |
| FIELD_NAME_STR( UCAL_MILLISECONDS_IN_DAY ); |
| #undef FIELD_NAME_STR |
| default: |
| return UnicodeString("") + ((int32_t)f); |
| } |
| } |
| |
| /** |
| * Test various API methods for API completeness. |
| */ |
| void |
| CalendarTest::TestGenericAPI() |
| { |
| UErrorCode status = U_ZERO_ERROR; |
| UDate d; |
| UnicodeString str; |
| UBool eq = FALSE,b4 = FALSE,af = FALSE; |
| |
| UDate when = date(90, UCAL_APRIL, 15); |
| |
| UnicodeString tzid("TestZone"); |
| int32_t tzoffset = 123400; |
| |
| SimpleTimeZone *zone = new SimpleTimeZone(tzoffset, tzid); |
| Calendar *cal = Calendar::createInstance(zone->clone(), status); |
| if (failure(status, "Calendar::createInstance #1", TRUE)) return; |
| |
| if (*zone != cal->getTimeZone()) errln("FAIL: Calendar::getTimeZone failed"); |
| |
| Calendar *cal2 = Calendar::createInstance(cal->getTimeZone(), status); |
| if (failure(status, "Calendar::createInstance #2")) return; |
| cal->setTime(when, status); |
| cal2->setTime(when, status); |
| if (failure(status, "Calendar::setTime")) return; |
| |
| if (!(*cal == *cal2)) errln("FAIL: Calendar::operator== failed"); |
| if ((*cal != *cal2)) errln("FAIL: Calendar::operator!= failed"); |
| if (!cal->equals(*cal2, status) || |
| cal->before(*cal2, status) || |
| cal->after(*cal2, status) || |
| U_FAILURE(status)) errln("FAIL: equals/before/after failed"); |
| |
| logln(UnicodeString("cal=") +cal->getTime(status) + UnicodeString(calToStr(*cal))); |
| logln(UnicodeString("cal2=") +cal2->getTime(status) + UnicodeString(calToStr(*cal2))); |
| logln("cal2->setTime(when+1000)"); |
| cal2->setTime(when + 1000, status); |
| logln(UnicodeString("cal2=") +cal2->getTime(status) + UnicodeString(calToStr(*cal2))); |
| |
| if (failure(status, "Calendar::setTime")) return; |
| if (cal->equals(*cal2, status) || |
| cal2->before(*cal, status) || |
| cal->after(*cal2, status) || |
| U_FAILURE(status)) errln("FAIL: equals/before/after failed after setTime(+1000)"); |
| |
| logln("cal->roll(UCAL_SECOND)"); |
| cal->roll(UCAL_SECOND, (UBool) TRUE, status); |
| logln(UnicodeString("cal=") +cal->getTime(status) + UnicodeString(calToStr(*cal))); |
| cal->roll(UCAL_SECOND, (int32_t)0, status); |
| logln(UnicodeString("cal=") +cal->getTime(status) + UnicodeString(calToStr(*cal))); |
| if (failure(status, "Calendar::roll")) return; |
| |
| if (!(eq=cal->equals(*cal2, status)) || |
| (b4=cal->before(*cal2, status)) || |
| (af=cal->after(*cal2, status)) || |
| U_FAILURE(status)) { |
| errln("FAIL: equals[%c]/before[%c]/after[%c] failed after roll 1 second [should be T/F/F]", |
| eq?'T':'F', |
| b4?'T':'F', |
| af?'T':'F'); |
| logln(UnicodeString("cal=") +cal->getTime(status) + UnicodeString(calToStr(*cal))); |
| logln(UnicodeString("cal2=") +cal2->getTime(status) + UnicodeString(calToStr(*cal2))); |
| } |
| |
| // Roll back to January |
| cal->roll(UCAL_MONTH, (int32_t)(1 + UCAL_DECEMBER - cal->get(UCAL_MONTH, status)), status); |
| if (failure(status, "Calendar::roll")) return; |
| if (cal->equals(*cal2, status) || |
| cal2->before(*cal, status) || |
| cal->after(*cal2, status) || |
| U_FAILURE(status)) errln("FAIL: equals/before/after failed after rollback to January"); |
| |
| TimeZone *z = cal->orphanTimeZone(); |
| if (z->getID(str) != tzid || |
| z->getRawOffset() != tzoffset) |
| errln("FAIL: orphanTimeZone failed"); |
| |
| int32_t i; |
| for (i=0; i<2; ++i) |
| { |
| UBool lenient = ( i > 0 ); |
| cal->setLenient(lenient); |
| if (lenient != cal->isLenient()) errln("FAIL: setLenient/isLenient failed"); |
| // Later: Check for lenient behavior |
| } |
| |
| for (i=UCAL_SUNDAY; i<=UCAL_SATURDAY; ++i) |
| { |
| cal->setFirstDayOfWeek((UCalendarDaysOfWeek)i); |
| if (cal->getFirstDayOfWeek() != i) errln("FAIL: set/getFirstDayOfWeek failed"); |
| UErrorCode aStatus = U_ZERO_ERROR; |
| if (cal->getFirstDayOfWeek(aStatus) != i || U_FAILURE(aStatus)) errln("FAIL: getFirstDayOfWeek(status) failed"); |
| } |
| |
| for (i=1; i<=7; ++i) |
| { |
| cal->setMinimalDaysInFirstWeek((uint8_t)i); |
| if (cal->getMinimalDaysInFirstWeek() != i) errln("FAIL: set/getFirstDayOfWeek failed"); |
| } |
| |
| for (i=0; i<UCAL_FIELD_COUNT; ++i) |
| { |
| if (cal->getMinimum((UCalendarDateFields)i) > cal->getGreatestMinimum((UCalendarDateFields)i)) |
| errln(UnicodeString("FAIL: getMinimum larger than getGreatestMinimum for field ") + i); |
| if (cal->getLeastMaximum((UCalendarDateFields)i) > cal->getMaximum((UCalendarDateFields)i)) |
| errln(UnicodeString("FAIL: getLeastMaximum larger than getMaximum for field ") + i); |
| if (cal->getMinimum((UCalendarDateFields)i) >= cal->getMaximum((UCalendarDateFields)i)) |
| errln(UnicodeString("FAIL: getMinimum not less than getMaximum for field ") + i); |
| } |
| |
| cal->adoptTimeZone(TimeZone::createDefault()); |
| cal->clear(); |
| cal->set(1984, 5, 24); |
| if (cal->getTime(status) != date(84, 5, 24) || U_FAILURE(status)) |
| errln("FAIL: Calendar::set(3 args) failed"); |
| |
| cal->clear(); |
| cal->set(1985, 3, 2, 11, 49); |
| if (cal->getTime(status) != date(85, 3, 2, 11, 49) || U_FAILURE(status)) |
| errln("FAIL: Calendar::set(5 args) failed"); |
| |
| cal->clear(); |
| cal->set(1995, 9, 12, 1, 39, 55); |
| if (cal->getTime(status) != date(95, 9, 12, 1, 39, 55) || U_FAILURE(status)) |
| errln("FAIL: Calendar::set(6 args) failed"); |
| |
| cal->getTime(status); |
| if (failure(status, "Calendar::getTime")) return; |
| for (i=0; i<UCAL_FIELD_COUNT; ++i) |
| { |
| switch(i) { |
| case UCAL_YEAR: case UCAL_MONTH: case UCAL_DATE: |
| case UCAL_HOUR_OF_DAY: case UCAL_MINUTE: case UCAL_SECOND: |
| case UCAL_EXTENDED_YEAR: |
| if (!cal->isSet((UCalendarDateFields)i)) errln("FAIL: Calendar::isSet F, should be T " + fieldName((UCalendarDateFields)i)); |
| break; |
| default: |
| if (cal->isSet((UCalendarDateFields)i)) errln("FAIL: Calendar::isSet = T, should be F " + fieldName((UCalendarDateFields)i)); |
| } |
| cal->clear((UCalendarDateFields)i); |
| if (cal->isSet((UCalendarDateFields)i)) errln("FAIL: Calendar::clear/isSet failed " + fieldName((UCalendarDateFields)i)); |
| } |
| |
| if(cal->getActualMinimum(Calendar::SECOND, status) != 0){ |
| errln("Calendar is suppose to return 0 for getActualMinimum"); |
| } |
| |
| Calendar *cal3 = Calendar::createInstance(status); |
| cal3->roll(Calendar::SECOND, (int32_t)0, status); |
| if (failure(status, "Calendar::roll(EDateFields, int32_t, UErrorCode)")) return; |
| |
| delete cal; |
| delete cal2; |
| delete cal3; |
| |
| int32_t count; |
| const Locale* loc = Calendar::getAvailableLocales(count); |
| if (count < 1 || loc == 0) |
| { |
| dataerrln("FAIL: getAvailableLocales failed"); |
| } |
| else |
| { |
| for (i=0; i<count; ++i) |
| { |
| cal = Calendar::createInstance(loc[i], status); |
| if (U_FAILURE(status)) { |
| errcheckln(status, UnicodeString("FAIL: Calendar::createInstance #3, locale ") + loc[i].getName() + " , error " + u_errorName(status)); |
| return; |
| } |
| delete cal; |
| } |
| } |
| |
| cal = Calendar::createInstance(TimeZone::createDefault(), Locale::getEnglish(), status); |
| if (failure(status, "Calendar::createInstance #4")) return; |
| delete cal; |
| |
| cal = Calendar::createInstance(*zone, Locale::getEnglish(), status); |
| if (failure(status, "Calendar::createInstance #5")) return; |
| delete cal; |
| |
| GregorianCalendar *gc = new GregorianCalendar(*zone, status); |
| if (failure(status, "new GregorianCalendar")) return; |
| delete gc; |
| |
| gc = new GregorianCalendar(Locale::getEnglish(), status); |
| if (failure(status, "new GregorianCalendar")) return; |
| delete gc; |
| |
| gc = new GregorianCalendar(Locale::getEnglish(), status); |
| delete gc; |
| |
| gc = new GregorianCalendar(*zone, Locale::getEnglish(), status); |
| if (failure(status, "new GregorianCalendar")) return; |
| delete gc; |
| |
| gc = new GregorianCalendar(zone, status); |
| if (failure(status, "new GregorianCalendar")) return; |
| delete gc; |
| |
| gc = new GregorianCalendar(1998, 10, 14, 21, 43, status); |
| if (gc->getTime(status) != (d =date(98, 10, 14, 21, 43) )|| U_FAILURE(status)) |
| errln("FAIL: new GregorianCalendar(ymdhm) failed with " + UnicodeString(u_errorName(status)) + ", cal=" + gc->getTime(status) + UnicodeString(calToStr(*gc)) + ", d=" + d); |
| else |
| logln(UnicodeString("GOOD: cal=") +gc->getTime(status) + UnicodeString(calToStr(*gc)) + ", d=" + d); |
| delete gc; |
| |
| gc = new GregorianCalendar(1998, 10, 14, 21, 43, 55, status); |
| if (gc->getTime(status) != (d=date(98, 10, 14, 21, 43, 55)) || U_FAILURE(status)) |
| errln("FAIL: new GregorianCalendar(ymdhms) failed with " + UnicodeString(u_errorName(status))); |
| |
| GregorianCalendar gc2(Locale::getEnglish(), status); |
| if (failure(status, "new GregorianCalendar")) return; |
| gc2 = *gc; |
| if (gc2 != *gc || !(gc2 == *gc)) errln("FAIL: GregorianCalendar assignment/operator==/operator!= failed"); |
| delete gc; |
| delete z; |
| |
| /* Code coverage for Calendar class. */ |
| cal = Calendar::createInstance(status); |
| if (failure(status, "Calendar::createInstance #6")) { |
| return; |
| }else { |
| ((Calendar *)cal)->roll(UCAL_HOUR, (int32_t)100, status); |
| ((Calendar *)cal)->clear(UCAL_HOUR); |
| #if !UCONFIG_NO_SERVICE |
| URegistryKey key = cal->registerFactory(NULL, status); |
| cal->unregister(key, status); |
| #endif |
| } |
| delete cal; |
| |
| status = U_ZERO_ERROR; |
| cal = Calendar::createInstance(Locale("he_IL@calendar=hebrew"), status); |
| if (failure(status, "Calendar::createInstance #7")) { |
| return; |
| } else { |
| cal->roll(Calendar::MONTH, (int32_t)100, status); |
| } |
| |
| LocalPointer<StringEnumeration> values( |
| Calendar::getKeywordValuesForLocale("calendar", Locale("he"), FALSE, status)); |
| if (values.isNull() || U_FAILURE(status)) { |
| dataerrln("FAIL: Calendar::getKeywordValuesForLocale(he): %s", u_errorName(status)); |
| } else { |
| UBool containsHebrew = FALSE; |
| const char *charValue; |
| int32_t valueLength; |
| while ((charValue = values->next(&valueLength, status)) != NULL) { |
| if (valueLength == 6 && strcmp(charValue, "hebrew") == 0) { |
| containsHebrew = TRUE; |
| } |
| } |
| if (!containsHebrew) { |
| errln("Calendar::getKeywordValuesForLocale(he)->next() does not contain \"hebrew\""); |
| } |
| |
| values->reset(status); |
| containsHebrew = FALSE; |
| UnicodeString hebrew = UNICODE_STRING_SIMPLE("hebrew"); |
| const UChar *ucharValue; |
| while ((ucharValue = values->unext(&valueLength, status)) != NULL) { |
| UnicodeString value(FALSE, ucharValue, valueLength); |
| if (value == hebrew) { |
| containsHebrew = TRUE; |
| } |
| } |
| if (!containsHebrew) { |
| errln("Calendar::getKeywordValuesForLocale(he)->unext() does not contain \"hebrew\""); |
| } |
| |
| values->reset(status); |
| containsHebrew = FALSE; |
| const UnicodeString *stringValue; |
| while ((stringValue = values->snext(status)) != NULL) { |
| if (*stringValue == hebrew) { |
| containsHebrew = TRUE; |
| } |
| } |
| if (!containsHebrew) { |
| errln("Calendar::getKeywordValuesForLocale(he)->snext() does not contain \"hebrew\""); |
| } |
| } |
| delete cal; |
| } |
| |
| // ------------------------------------- |
| |
| /** |
| * This test confirms the correct behavior of add when incrementing |
| * through subsequent days. |
| */ |
| void |
| CalendarTest::TestRog() |
| { |
| UErrorCode status = U_ZERO_ERROR; |
| GregorianCalendar* gc = new GregorianCalendar(status); |
| if (failure(status, "new GregorianCalendar", TRUE)) return; |
| int32_t year = 1997, month = UCAL_APRIL, date = 1; |
| gc->set(year, month, date); |
| gc->set(UCAL_HOUR_OF_DAY, 23); |
| gc->set(UCAL_MINUTE, 0); |
| gc->set(UCAL_SECOND, 0); |
| gc->set(UCAL_MILLISECOND, 0); |
| for (int32_t i = 0; i < 9; i++, gc->add(UCAL_DATE, 1, status)) { |
| if (U_FAILURE(status)) { errln("Calendar::add failed"); return; } |
| if (gc->get(UCAL_YEAR, status) != year || |
| gc->get(UCAL_MONTH, status) != month || |
| gc->get(UCAL_DATE, status) != (date + i)) errln("FAIL: Date wrong"); |
| if (U_FAILURE(status)) { errln("Calendar::get failed"); return; } |
| } |
| delete gc; |
| } |
| |
| // ------------------------------------- |
| |
| /** |
| * Test the handling of the day of the week, checking for correctness and |
| * for correct minimum and maximum values. |
| */ |
| void |
| CalendarTest::TestDOW943() |
| { |
| dowTest(FALSE); |
| dowTest(TRUE); |
| } |
| |
| void CalendarTest::dowTest(UBool lenient) |
| { |
| UErrorCode status = U_ZERO_ERROR; |
| GregorianCalendar* cal = new GregorianCalendar(status); |
| if (failure(status, "new GregorianCalendar", TRUE)) return; |
| logln("cal - Aug 12, 1997\n"); |
| cal->set(1997, UCAL_AUGUST, 12); |
| cal->getTime(status); |
| if (U_FAILURE(status)) { errln("Calendar::getTime failed"); return; } |
| logln((lenient?UnicodeString("LENIENT0: "):UnicodeString("nonlenient0: ")) + UnicodeString(calToStr(*cal))); |
| cal->setLenient(lenient); |
| logln("cal - Dec 1, 1996\n"); |
| cal->set(1996, UCAL_DECEMBER, 1); |
| logln((lenient?UnicodeString("LENIENT: "):UnicodeString("nonlenient: ")) + UnicodeString(calToStr(*cal))); |
| int32_t dow = cal->get(UCAL_DAY_OF_WEEK, status); |
| if (U_FAILURE(status)) { errln("Calendar::get failed [%s]", u_errorName(status)); return; } |
| int32_t min = cal->getMinimum(UCAL_DAY_OF_WEEK); |
| int32_t max = cal->getMaximum(UCAL_DAY_OF_WEEK); |
| if (dow < min || |
| dow > max) errln(UnicodeString("FAIL: Day of week ") + (int32_t)dow + " out of range"); |
| if (dow != UCAL_SUNDAY) errln("FAIL: Day of week should be SUNDAY[%d] not %d", UCAL_SUNDAY, dow); |
| if (min != UCAL_SUNDAY || |
| max != UCAL_SATURDAY) errln("FAIL: Min/max bad"); |
| delete cal; |
| } |
| |
| // ------------------------------------- |
| |
| /** |
| * Confirm that cloned Calendar objects do not inadvertently share substructures. |
| */ |
| void |
| CalendarTest::TestClonesUnique908() |
| { |
| UErrorCode status = U_ZERO_ERROR; |
| Calendar *c = Calendar::createInstance(status); |
| if (failure(status, "Calendar::createInstance", TRUE)) return; |
| Calendar *d = (Calendar*) c->clone(); |
| c->set(UCAL_MILLISECOND, 123); |
| d->set(UCAL_MILLISECOND, 456); |
| if (c->get(UCAL_MILLISECOND, status) != 123 || |
| d->get(UCAL_MILLISECOND, status) != 456) { |
| errln("FAIL: Clones share fields"); |
| } |
| if (U_FAILURE(status)) { errln("Calendar::get failed"); return; } |
| delete c; |
| delete d; |
| } |
| |
| // ------------------------------------- |
| |
| /** |
| * Confirm that the Gregorian cutoff value works as advertised. |
| */ |
| void |
| CalendarTest::TestGregorianChange768() |
| { |
| UBool b; |
| UErrorCode status = U_ZERO_ERROR; |
| UnicodeString str; |
| GregorianCalendar* c = new GregorianCalendar(status); |
| if (failure(status, "new GregorianCalendar", TRUE)) return; |
| logln(UnicodeString("With cutoff ") + dateToString(c->getGregorianChange(), str)); |
| b = c->isLeapYear(1800); |
| logln(UnicodeString(" isLeapYear(1800) = ") + (b ? "true" : "false")); |
| logln(UnicodeString(" (should be FALSE)")); |
| if (b) errln("FAIL"); |
| c->setGregorianChange(date(0, 0, 1), status); |
| if (U_FAILURE(status)) { errln("GregorianCalendar::setGregorianChange failed"); return; } |
| logln(UnicodeString("With cutoff ") + dateToString(c->getGregorianChange(), str)); |
| b = c->isLeapYear(1800); |
| logln(UnicodeString(" isLeapYear(1800) = ") + (b ? "true" : "false")); |
| logln(UnicodeString(" (should be TRUE)")); |
| if (!b) errln("FAIL"); |
| delete c; |
| } |
| |
| // ------------------------------------- |
| |
| /** |
| * Confirm the functioning of the field disambiguation algorithm. |
| */ |
| void |
| CalendarTest::TestDisambiguation765() |
| { |
| UErrorCode status = U_ZERO_ERROR; |
| Calendar *c = Calendar::createInstance("en_US", status); |
| if (failure(status, "Calendar::createInstance", TRUE)) return; |
| c->setLenient(FALSE); |
| c->clear(); |
| c->set(UCAL_YEAR, 1997); |
| c->set(UCAL_MONTH, UCAL_JUNE); |
| c->set(UCAL_DATE, 3); |
| verify765("1997 third day of June = ", c, 1997, UCAL_JUNE, 3); |
| c->clear(); |
| c->set(UCAL_YEAR, 1997); |
| c->set(UCAL_DAY_OF_WEEK, UCAL_TUESDAY); |
| c->set(UCAL_MONTH, UCAL_JUNE); |
| c->set(UCAL_DAY_OF_WEEK_IN_MONTH, 1); |
| verify765("1997 first Tuesday in June = ", c, 1997, UCAL_JUNE, 3); |
| c->clear(); |
| c->set(UCAL_YEAR, 1997); |
| c->set(UCAL_DAY_OF_WEEK, UCAL_TUESDAY); |
| c->set(UCAL_MONTH, UCAL_JUNE); |
| c->set(UCAL_DAY_OF_WEEK_IN_MONTH, - 1); |
| verify765("1997 last Tuesday in June = ", c, 1997, UCAL_JUNE, 24); |
| |
| status = U_ZERO_ERROR; |
| c->clear(); |
| c->set(UCAL_YEAR, 1997); |
| c->set(UCAL_DAY_OF_WEEK, UCAL_TUESDAY); |
| c->set(UCAL_MONTH, UCAL_JUNE); |
| c->set(UCAL_DAY_OF_WEEK_IN_MONTH, 0); |
| c->getTime(status); |
| verify765("1997 zero-th Tuesday in June = ", status); |
| |
| c->clear(); |
| c->set(UCAL_YEAR, 1997); |
| c->set(UCAL_DAY_OF_WEEK, UCAL_TUESDAY); |
| c->set(UCAL_MONTH, UCAL_JUNE); |
| c->set(UCAL_WEEK_OF_MONTH, 1); |
| verify765("1997 Tuesday in week 1 of June = ", c, 1997, UCAL_JUNE, 3); |
| c->clear(); |
| c->set(UCAL_YEAR, 1997); |
| c->set(UCAL_DAY_OF_WEEK, UCAL_TUESDAY); |
| c->set(UCAL_MONTH, UCAL_JUNE); |
| c->set(UCAL_WEEK_OF_MONTH, 5); |
| verify765("1997 Tuesday in week 5 of June = ", c, 1997, UCAL_JULY, 1); |
| |
| status = U_ZERO_ERROR; |
| c->clear(); |
| c->set(UCAL_YEAR, 1997); |
| c->set(UCAL_DAY_OF_WEEK, UCAL_TUESDAY); |
| c->set(UCAL_MONTH, UCAL_JUNE); |
| c->set(UCAL_WEEK_OF_MONTH, 0); |
| c->setMinimalDaysInFirstWeek(1); |
| c->getTime(status); |
| verify765("1997 Tuesday in week 0 of June = ", status); |
| |
| /* Note: The following test used to expect YEAR 1997, WOY 1 to |
| * resolve to a date in Dec 1996; that is, to behave as if |
| * YEAR_WOY were 1997. With the addition of a new explicit |
| * YEAR_WOY field, YEAR_WOY must itself be set if that is what is |
| * desired. Using YEAR in combination with WOY is ambiguous, and |
| * results in the first WOY/DOW day of the year satisfying the |
| * given fields (there may be up to two such days). In this case, |
| * it propertly resolves to Tue Dec 30 1997, which has a WOY value |
| * of 1 (for YEAR_WOY 1998) and a DOW of Tuesday, and falls in the |
| * _calendar_ year 1997, as specified. - aliu */ |
| c->clear(); |
| c->set(UCAL_YEAR_WOY, 1997); // aliu |
| c->set(UCAL_DAY_OF_WEEK, UCAL_TUESDAY); |
| c->set(UCAL_WEEK_OF_YEAR, 1); |
| verify765("1997 Tuesday in week 1 of yearWOY = ", c, 1996, UCAL_DECEMBER, 31); |
| c->clear(); // - add test for YEAR |
| c->setMinimalDaysInFirstWeek(1); |
| c->set(UCAL_YEAR, 1997); |
| c->set(UCAL_DAY_OF_WEEK, UCAL_TUESDAY); |
| c->set(UCAL_WEEK_OF_YEAR, 1); |
| verify765("1997 Tuesday in week 1 of year = ", c, 1997, UCAL_DECEMBER, 30); |
| c->clear(); |
| c->set(UCAL_YEAR, 1997); |
| c->set(UCAL_DAY_OF_WEEK, UCAL_TUESDAY); |
| c->set(UCAL_WEEK_OF_YEAR, 10); |
| verify765("1997 Tuesday in week 10 of year = ", c, 1997, UCAL_MARCH, 4); |
| //try { |
| |
| // {sfb} week 0 is no longer a valid week of year |
| /*c->clear(); |
| c->set(Calendar::YEAR, 1997); |
| c->set(Calendar::DAY_OF_WEEK, Calendar::TUESDAY); |
| //c->set(Calendar::WEEK_OF_YEAR, 0); |
| c->set(Calendar::WEEK_OF_YEAR, 1); |
| verify765("1997 Tuesday in week 0 of year = ", c, 1996, Calendar::DECEMBER, 24);*/ |
| |
| //} |
| //catch(IllegalArgumentException ex) { |
| // errln("FAIL: Exception seen:"); |
| // ex.printStackTrace(log); |
| //} |
| delete c; |
| } |
| |
| // ------------------------------------- |
| |
| void |
| CalendarTest::verify765(const UnicodeString& msg, Calendar* c, int32_t year, int32_t month, int32_t day) |
| { |
| UnicodeString str; |
| UErrorCode status = U_ZERO_ERROR; |
| int32_t y = c->get(UCAL_YEAR, status); |
| int32_t m = c->get(UCAL_MONTH, status); |
| int32_t d = c->get(UCAL_DATE, status); |
| if ( y == year && |
| m == month && |
| d == day) { |
| if (U_FAILURE(status)) { errln("FAIL: Calendar::get failed"); return; } |
| logln("PASS: " + msg + dateToString(c->getTime(status), str)); |
| if (U_FAILURE(status)) { errln("Calendar::getTime failed"); return; } |
| } |
| else { |
| errln("FAIL: " + msg + dateToString(c->getTime(status), str) + "; expected " + (int32_t)year + "/" + (int32_t)(month + 1) + "/" + (int32_t)day + |
| "; got " + (int32_t)y + "/" + (int32_t)(m + 1) + "/" + (int32_t)d + " for Locale: " + c->getLocaleID(ULOC_ACTUAL_LOCALE,status)); |
| if (U_FAILURE(status)) { errln("Calendar::getTime failed"); return; } |
| } |
| } |
| |
| // ------------------------------------- |
| |
| void |
| CalendarTest::verify765(const UnicodeString& msg/*, IllegalArgumentException e*/, UErrorCode status) |
| { |
| if (status != U_ILLEGAL_ARGUMENT_ERROR) errln("FAIL: No IllegalArgumentException for " + msg); |
| else logln("PASS: " + msg + "IllegalArgument as expected"); |
| } |
| |
| // ------------------------------------- |
| |
| /** |
| * Confirm that the offset between local time and GMT behaves as expected. |
| */ |
| void |
| CalendarTest::TestGMTvsLocal4064654() |
| { |
| test4064654(1997, 1, 1, 12, 0, 0); |
| test4064654(1997, 4, 16, 18, 30, 0); |
| } |
| |
| // ------------------------------------- |
| |
| void |
| CalendarTest::test4064654(int32_t yr, int32_t mo, int32_t dt, int32_t hr, int32_t mn, int32_t sc) |
| { |
| UDate date; |
| UErrorCode status = U_ZERO_ERROR; |
| UnicodeString str; |
| Calendar *gmtcal = Calendar::createInstance(status); |
| if (failure(status, "Calendar::createInstance", TRUE)) return; |
| gmtcal->adoptTimeZone(TimeZone::createTimeZone("Africa/Casablanca")); |
| gmtcal->set(yr, mo - 1, dt, hr, mn, sc); |
| gmtcal->set(UCAL_MILLISECOND, 0); |
| date = gmtcal->getTime(status); |
| if (U_FAILURE(status)) { errln("Calendar::getTime failed"); return; } |
| logln("date = " + dateToString(date, str)); |
| Calendar *cal = Calendar::createInstance(status); |
| if (U_FAILURE(status)) { errln("Calendar::createInstance failed"); return; } |
| cal->setTime(date, status); |
| if (U_FAILURE(status)) { errln("Calendar::setTime failed"); return; } |
| int32_t offset = cal->getTimeZone().getOffset((uint8_t)cal->get(UCAL_ERA, status), |
| cal->get(UCAL_YEAR, status), |
| cal->get(UCAL_MONTH, status), |
| cal->get(UCAL_DATE, status), |
| (uint8_t)cal->get(UCAL_DAY_OF_WEEK, status), |
| cal->get(UCAL_MILLISECOND, status), status); |
| if (U_FAILURE(status)) { errln("Calendar::get failed"); return; } |
| logln("offset for " + dateToString(date, str) + "= " + (offset / 1000 / 60 / 60.0) + "hr"); |
| int32_t utc = ((cal->get(UCAL_HOUR_OF_DAY, status) * 60 + |
| cal->get(UCAL_MINUTE, status)) * 60 + |
| cal->get(UCAL_SECOND, status)) * 1000 + |
| cal->get(UCAL_MILLISECOND, status) - offset; |
| if (U_FAILURE(status)) { errln("Calendar::get failed"); return; } |
| int32_t expected = ((hr * 60 + mn) * 60 + sc) * 1000; |
| if (utc != expected) errln(UnicodeString("FAIL: Discrepancy of ") + (utc - expected) + |
| " millis = " + ((utc - expected) / 1000 / 60 / 60.0) + " hr"); |
| delete gmtcal; |
| delete cal; |
| } |
| |
| // ------------------------------------- |
| |
| /** |
| * The operations of adding and setting should not exhibit pathological |
| * dependence on the order of operations. This test checks for this. |
| */ |
| void |
| CalendarTest::TestAddSetOrder621() |
| { |
| UDate d = date(97, 4, 14, 13, 23, 45); |
| UErrorCode status = U_ZERO_ERROR; |
| Calendar *cal = Calendar::createInstance(status); |
| if (failure(status, "Calendar::createInstance", TRUE)) return; |
| |
| cal->setTime(d, status); |
| if (U_FAILURE(status)) { |
| errln("Calendar::setTime failed"); |
| delete cal; |
| return; |
| } |
| cal->add(UCAL_DATE, - 5, status); |
| if (U_FAILURE(status)) { |
| errln("Calendar::add failed"); |
| delete cal; |
| return; |
| } |
| cal->set(UCAL_HOUR_OF_DAY, 0); |
| cal->set(UCAL_MINUTE, 0); |
| cal->set(UCAL_SECOND, 0); |
| UnicodeString s; |
| dateToString(cal->getTime(status), s); |
| if (U_FAILURE(status)) { |
| errln("Calendar::getTime failed"); |
| delete cal; |
| return; |
| } |
| delete cal; |
| |
| cal = Calendar::createInstance(status); |
| if (U_FAILURE(status)) { |
| errln("Calendar::createInstance failed"); |
| delete cal; |
| return; |
| } |
| cal->setTime(d, status); |
| if (U_FAILURE(status)) { |
| errln("Calendar::setTime failed"); |
| delete cal; |
| return; |
| } |
| cal->set(UCAL_HOUR_OF_DAY, 0); |
| cal->set(UCAL_MINUTE, 0); |
| cal->set(UCAL_SECOND, 0); |
| cal->add(UCAL_DATE, - 5, status); |
| if (U_FAILURE(status)) { |
| errln("Calendar::add failed"); |
| delete cal; |
| return; |
| } |
| UnicodeString s2; |
| dateToString(cal->getTime(status), s2); |
| if (U_FAILURE(status)) { |
| errln("Calendar::getTime failed"); |
| delete cal; |
| return; |
| } |
| if (s == s2) |
| logln("Pass: " + s + " == " + s2); |
| else |
| errln("FAIL: " + s + " != " + s2); |
| delete cal; |
| } |
| |
| // ------------------------------------- |
| |
| /** |
| * Confirm that adding to various fields works. |
| */ |
| void |
| CalendarTest::TestAdd520() |
| { |
| int32_t y = 1997, m = UCAL_FEBRUARY, d = 1; |
| UErrorCode status = U_ZERO_ERROR; |
| GregorianCalendar *temp = new GregorianCalendar(y, m, d, status); |
| if (failure(status, "new GregorianCalendar", TRUE)) return; |
| check520(temp, y, m, d); |
| temp->add(UCAL_YEAR, 1, status); |
| if (U_FAILURE(status)) { errln("Calendar::add failed"); return; } |
| y++; |
| check520(temp, y, m, d); |
| temp->add(UCAL_MONTH, 1, status); |
| if (U_FAILURE(status)) { errln("Calendar::add failed"); return; } |
| m++; |
| check520(temp, y, m, d); |
| temp->add(UCAL_DATE, 1, status); |
| if (U_FAILURE(status)) { errln("Calendar::add failed"); return; } |
| d++; |
| check520(temp, y, m, d); |
| temp->add(UCAL_DATE, 2, status); |
| if (U_FAILURE(status)) { errln("Calendar::add failed"); return; } |
| d += 2; |
| check520(temp, y, m, d); |
| temp->add(UCAL_DATE, 28, status); |
| if (U_FAILURE(status)) { errln("Calendar::add failed"); return; } |
| d = 1;++m; |
| check520(temp, y, m, d); |
| delete temp; |
| } |
| |
| // ------------------------------------- |
| |
| /** |
| * Execute adding and rolling in GregorianCalendar extensively, |
| */ |
| void |
| CalendarTest::TestAddRollExtensive() |
| { |
| int32_t maxlimit = 40; |
| int32_t y = 1997, m = UCAL_FEBRUARY, d = 1, hr = 1, min = 1, sec = 0, ms = 0; |
| UErrorCode status = U_ZERO_ERROR; |
| GregorianCalendar *temp = new GregorianCalendar(y, m, d, status); |
| if (failure(status, "new GregorianCalendar", TRUE)) return; |
| |
| temp->set(UCAL_HOUR, hr); |
| temp->set(UCAL_MINUTE, min); |
| temp->set(UCAL_SECOND, sec); |
| temp->set(UCAL_MILLISECOND, ms); |
| temp->setMinimalDaysInFirstWeek(1); |
| |
| UCalendarDateFields e; |
| |
| logln("Testing GregorianCalendar add..."); |
| e = UCAL_YEAR; |
| while (e < UCAL_FIELD_COUNT) { |
| int32_t i; |
| int32_t limit = maxlimit; |
| status = U_ZERO_ERROR; |
| for (i = 0; i < limit; i++) { |
| temp->add(e, 1, status); |
| if (U_FAILURE(status)) { limit = i; status = U_ZERO_ERROR; } |
| } |
| for (i = 0; i < limit; i++) { |
| temp->add(e, -1, status); |
| if (U_FAILURE(status)) { errln("GregorianCalendar::add -1 failed"); return; } |
| } |
| check520(temp, y, m, d, hr, min, sec, ms, e); |
| |
| e = (UCalendarDateFields) ((int32_t) e + 1); |
| } |
| |
| logln("Testing GregorianCalendar roll..."); |
| e = UCAL_YEAR; |
| while (e < UCAL_FIELD_COUNT) { |
| int32_t i; |
| int32_t limit = maxlimit; |
| status = U_ZERO_ERROR; |
| for (i = 0; i < limit; i++) { |
| logln(calToStr(*temp) + UnicodeString(" " ) + fieldName(e) + UnicodeString("++") ); |
| temp->roll(e, 1, status); |
| if (U_FAILURE(status)) { |
| logln("caltest.cpp:%d e=%d, i=%d - roll(+) err %s\n", __LINE__, (int) e, (int) i, u_errorName(status)); |
| logln(calToStr(*temp)); |
| limit = i; status = U_ZERO_ERROR; |
| } |
| } |
| for (i = 0; i < limit; i++) { |
| logln("caltest.cpp:%d e=%d, i=%d\n", __LINE__, (int) e, (int) i); |
| logln(calToStr(*temp) + UnicodeString(" " ) + fieldName(e) + UnicodeString("--") ); |
| temp->roll(e, -1, status); |
| if (U_FAILURE(status)) { errln(UnicodeString("GregorianCalendar::roll ") + CalendarTest::fieldName(e) + " count=" + UnicodeString('@'+i) + " by -1 failed with " + u_errorName(status) ); return; } |
| } |
| check520(temp, y, m, d, hr, min, sec, ms, e); |
| |
| e = (UCalendarDateFields) ((int32_t) e + 1); |
| } |
| |
| delete temp; |
| } |
| |
| // ------------------------------------- |
| void |
| CalendarTest::check520(Calendar* c, |
| int32_t y, int32_t m, int32_t d, |
| int32_t hr, int32_t min, int32_t sec, |
| int32_t ms, UCalendarDateFields field) |
| |
| { |
| UErrorCode status = U_ZERO_ERROR; |
| if (c->get(UCAL_YEAR, status) != y || |
| c->get(UCAL_MONTH, status) != m || |
| c->get(UCAL_DATE, status) != d || |
| c->get(UCAL_HOUR, status) != hr || |
| c->get(UCAL_MINUTE, status) != min || |
| c->get(UCAL_SECOND, status) != sec || |
| c->get(UCAL_MILLISECOND, status) != ms) { |
| errln(UnicodeString("U_FAILURE for field ") + (int32_t)field + |
| ": Expected y/m/d h:m:s:ms of " + |
| y + "/" + (m + 1) + "/" + d + " " + |
| hr + ":" + min + ":" + sec + ":" + ms + |
| "; got " + c->get(UCAL_YEAR, status) + |
| "/" + (c->get(UCAL_MONTH, status) + 1) + |
| "/" + c->get(UCAL_DATE, status) + |
| " " + c->get(UCAL_HOUR, status) + ":" + |
| c->get(UCAL_MINUTE, status) + ":" + |
| c->get(UCAL_SECOND, status) + ":" + |
| c->get(UCAL_MILLISECOND, status) |
| ); |
| |
| if (U_FAILURE(status)) { errln("Calendar::get failed"); return; } |
| } |
| else |
| logln(UnicodeString("Confirmed: ") + y + "/" + |
| (m + 1) + "/" + d + " " + |
| hr + ":" + min + ":" + sec + ":" + ms); |
| } |
| |
| // ------------------------------------- |
| void |
| CalendarTest::check520(Calendar* c, |
| int32_t y, int32_t m, int32_t d) |
| |
| { |
| UErrorCode status = U_ZERO_ERROR; |
| if (c->get(UCAL_YEAR, status) != y || |
| c->get(UCAL_MONTH, status) != m || |
| c->get(UCAL_DATE, status) != d) { |
| errln(UnicodeString("FAILURE: Expected y/m/d of ") + |
| y + "/" + (m + 1) + "/" + d + " " + |
| "; got " + c->get(UCAL_YEAR, status) + |
| "/" + (c->get(UCAL_MONTH, status) + 1) + |
| "/" + c->get(UCAL_DATE, status) |
| ); |
| |
| if (U_FAILURE(status)) { errln("Calendar::get failed"); return; } |
| } |
| else |
| logln(UnicodeString("Confirmed: ") + y + "/" + |
| (m + 1) + "/" + d); |
| } |
| |
| // ------------------------------------- |
| |
| /** |
| * Test that setting of fields works. In particular, make sure that all instances |
| * of GregorianCalendar don't share a static instance of the fields array. |
| */ |
| void |
| CalendarTest::TestFieldSet4781() |
| { |
| // try { |
| UErrorCode status = U_ZERO_ERROR; |
| GregorianCalendar *g = new GregorianCalendar(status); |
| if (failure(status, "new GregorianCalendar", TRUE)) return; |
| GregorianCalendar *g2 = new GregorianCalendar(status); |
| if (U_FAILURE(status)) { errln("Couldn't create GregorianCalendar"); return; } |
| g2->set(UCAL_HOUR, 12, status); |
| g2->set(UCAL_MINUTE, 0, status); |
| g2->set(UCAL_SECOND, 0, status); |
| if (U_FAILURE(status)) { errln("Calendar::set failed"); return; } |
| if (*g == *g2) logln("Same"); |
| else logln("Different"); |
| //} |
| //catch(IllegalArgumentException e) { |
| //errln("Unexpected exception seen: " + e); |
| //} |
| delete g; |
| delete g2; |
| } |
| |
| // ------------------------------------- |
| |
| /* We don't support serialization on C++ |
| void |
| CalendarTest::TestSerialize337() |
| { |
| Calendar cal = Calendar::getInstance(); |
| UBool ok = FALSE; |
| try { |
| FileOutputStream f = new FileOutputStream(FILENAME); |
| ObjectOutput s = new ObjectOutputStream(f); |
| s.writeObject(PREFIX); |
| s.writeObject(cal); |
| s.writeObject(POSTFIX); |
| f.close(); |
| FileInputStream in = new FileInputStream(FILENAME); |
| ObjectInputStream t = new ObjectInputStream(in); |
| UnicodeString& pre = (UnicodeString&) t.readObject(); |
| Calendar c = (Calendar) t.readObject(); |
| UnicodeString& post = (UnicodeString&) t.readObject(); |
| in.close(); |
| ok = pre.equals(PREFIX) && |
| post.equals(POSTFIX) && |
| cal->equals(c); |
| File fl = new File(FILENAME); |
| fl.delete(); |
| } |
| catch(IOException e) { |
| errln("FAIL: Exception received:"); |
| e.printStackTrace(log); |
| } |
| catch(ClassNotFoundException e) { |
| errln("FAIL: Exception received:"); |
| e.printStackTrace(log); |
| } |
| if (!ok) errln("Serialization of Calendar object failed."); |
| } |
| |
| UnicodeString& CalendarTest::PREFIX = "abc"; |
| |
| UnicodeString& CalendarTest::POSTFIX = "def"; |
| |
| UnicodeString& CalendarTest::FILENAME = "tmp337.bin"; |
| */ |
| |
| // ------------------------------------- |
| |
| /** |
| * Verify that the seconds of a Calendar can be zeroed out through the |
| * expected sequence of operations. |
| */ |
| void |
| CalendarTest::TestSecondsZero121() |
| { |
| UErrorCode status = U_ZERO_ERROR; |
| Calendar *cal = new GregorianCalendar(status); |
| if (failure(status, "new GregorianCalendar", TRUE)) return; |
| cal->setTime(Calendar::getNow(), status); |
| if (U_FAILURE(status)) { errln("Calendar::setTime failed"); return; } |
| cal->set(UCAL_SECOND, 0); |
| if (U_FAILURE(status)) { errln("Calendar::set failed"); return; } |
| UDate d = cal->getTime(status); |
| if (U_FAILURE(status)) { errln("Calendar::getTime failed"); return; } |
| UnicodeString s; |
| dateToString(d, s); |
| if (s.indexOf("DATE_FORMAT_FAILURE") >= 0) { |
| dataerrln("Got: \"DATE_FORMAT_FAILURE\"."); |
| } else if (s.indexOf(":00 ") < 0) { |
| errln("Expected to see :00 in " + s); |
| } |
| delete cal; |
| } |
| |
| // ------------------------------------- |
| |
| /** |
| * Verify that a specific sequence of adding and setting works as expected; |
| * it should not vary depending on when and whether the get method is |
| * called. |
| */ |
| void |
| CalendarTest::TestAddSetGet0610() |
| { |
| UnicodeString EXPECTED_0610("1993/0/5", ""); |
| UErrorCode status = U_ZERO_ERROR; |
| { |
| Calendar *calendar = new GregorianCalendar(status); |
| if (failure(status, "new GregorianCalendar", TRUE)) return; |
| calendar->set(1993, UCAL_JANUARY, 4); |
| logln("1A) " + value(calendar)); |
| calendar->add(UCAL_DATE, 1, status); |
| if (U_FAILURE(status)) { errln("Calendar::add failed"); return; } |
| UnicodeString v = value(calendar); |
| logln("1B) " + v); |
| logln("--) 1993/0/5"); |
| if (!(v == EXPECTED_0610)) errln("Expected " + EXPECTED_0610 + "; saw " + v); |
| delete calendar; |
| } |
| { |
| Calendar *calendar = new GregorianCalendar(1993, UCAL_JANUARY, 4, status); |
| if (U_FAILURE(status)) { errln("Couldn't create GregorianCalendar"); return; } |
| logln("2A) " + value(calendar)); |
| calendar->add(UCAL_DATE, 1, status); |
| if (U_FAILURE(status)) { errln("Calendar::add failed"); return; } |
| UnicodeString v = value(calendar); |
| logln("2B) " + v); |
| logln("--) 1993/0/5"); |
| if (!(v == EXPECTED_0610)) errln("Expected " + EXPECTED_0610 + "; saw " + v); |
| delete calendar; |
| } |
| { |
| Calendar *calendar = new GregorianCalendar(1993, UCAL_JANUARY, 4, status); |
| if (U_FAILURE(status)) { errln("Couldn't create GregorianCalendar"); return; } |
| logln("3A) " + value(calendar)); |
| calendar->getTime(status); |
| if (U_FAILURE(status)) { errln("Calendar::getTime failed"); return; } |
| calendar->add(UCAL_DATE, 1, status); |
| if (U_FAILURE(status)) { errln("Calendar::add failed"); return; } |
| UnicodeString v = value(calendar); |
| logln("3B) " + v); |
| logln("--) 1993/0/5"); |
| if (!(v == EXPECTED_0610)) errln("Expected " + EXPECTED_0610 + "; saw " + v); |
| delete calendar; |
| } |
| } |
| |
| // ------------------------------------- |
| |
| UnicodeString |
| CalendarTest::value(Calendar* calendar) |
| { |
| UErrorCode status = U_ZERO_ERROR; |
| return UnicodeString("") + (int32_t)calendar->get(UCAL_YEAR, status) + |
| "/" + (int32_t)calendar->get(UCAL_MONTH, status) + |
| "/" + (int32_t)calendar->get(UCAL_DATE, status) + |
| (U_FAILURE(status) ? " FAIL: Calendar::get failed" : ""); |
| } |
| |
| |
| // ------------------------------------- |
| |
| /** |
| * Verify that various fields on a known date are set correctly. |
| */ |
| void |
| CalendarTest::TestFields060() |
| { |
| UErrorCode status = U_ZERO_ERROR; |
| int32_t year = 1997; |
| int32_t month = UCAL_OCTOBER; |
| int32_t dDate = 22; |
| GregorianCalendar *calendar = 0; |
| calendar = new GregorianCalendar(year, month, dDate, status); |
| if (failure(status, "new GregorianCalendar", TRUE)) return; |
| for (int32_t i = 0; i < EXPECTED_FIELDS_length;) { |
| UCalendarDateFields field = (UCalendarDateFields)EXPECTED_FIELDS[i++]; |
| int32_t expected = EXPECTED_FIELDS[i++]; |
| if (calendar->get(field, status) != expected) { |
| errln(UnicodeString("Expected field ") + (int32_t)field + " to have value " + (int32_t)expected + |
| "; received " + (int32_t)calendar->get(field, status) + " instead"); |
| if (U_FAILURE(status)) { errln("Calendar::get failed"); return; } |
| } |
| } |
| delete calendar; |
| } |
| |
| int32_t CalendarTest::EXPECTED_FIELDS[] = { |
| UCAL_YEAR, 1997, |
| UCAL_MONTH, UCAL_OCTOBER, |
| UCAL_DATE, 22, |
| UCAL_DAY_OF_WEEK, UCAL_WEDNESDAY, |
| UCAL_DAY_OF_WEEK_IN_MONTH, 4, |
| UCAL_DAY_OF_YEAR, 295 |
| }; |
| |
| const int32_t CalendarTest::EXPECTED_FIELDS_length = (int32_t)(sizeof(CalendarTest::EXPECTED_FIELDS) / |
| sizeof(CalendarTest::EXPECTED_FIELDS[0])); |
| |
| // ------------------------------------- |
| |
| /** |
| * Verify that various fields on a known date are set correctly. In this |
| * case, the start of the epoch (January 1 1970). |
| */ |
| void |
| CalendarTest::TestEpochStartFields() |
| { |
| UErrorCode status = U_ZERO_ERROR; |
| TimeZone *z = TimeZone::createDefault(); |
| Calendar *c = Calendar::createInstance(status); |
| if (failure(status, "Calendar::createInstance", TRUE)) return; |
| UDate d = - z->getRawOffset(); |
| GregorianCalendar *gc = new GregorianCalendar(status); |
| if (U_FAILURE(status)) { errln("Couldn't create GregorianCalendar"); return; } |
| gc->setTimeZone(*z); |
| gc->setTime(d, status); |
| if (U_FAILURE(status)) { errln("Calendar::setTime failed"); return; } |
| UBool idt = gc->inDaylightTime(status); |
| if (U_FAILURE(status)) { errln("GregorianCalendar::inDaylightTime failed"); return; } |
| if (idt) { |
| UnicodeString str; |
| logln("Warning: Skipping test because " + dateToString(d, str) + " is in DST."); |
| } |
| else { |
| c->setTime(d, status); |
| if (U_FAILURE(status)) { errln("Calendar::setTime failed"); return; } |
| for (int32_t i = 0; i < UCAL_ZONE_OFFSET;++i) { |
| if (c->get((UCalendarDateFields)i, status) != EPOCH_FIELDS[i]) |
| dataerrln(UnicodeString("Expected field ") + i + " to have value " + EPOCH_FIELDS[i] + |
| "; saw " + c->get((UCalendarDateFields)i, status) + " instead"); |
| if (U_FAILURE(status)) { errln("Calendar::get failed"); return; } |
| } |
| if (c->get(UCAL_ZONE_OFFSET, status) != z->getRawOffset()) |
| { |
| errln(UnicodeString("Expected field ZONE_OFFSET to have value ") + z->getRawOffset() + |
| "; saw " + c->get(UCAL_ZONE_OFFSET, status) + " instead"); |
| if (U_FAILURE(status)) { errln("Calendar::get failed"); return; } |
| } |
| if (c->get(UCAL_DST_OFFSET, status) != 0) |
| { |
| errln(UnicodeString("Expected field DST_OFFSET to have value 0") + |
| "; saw " + c->get(UCAL_DST_OFFSET, status) + " instead"); |
| if (U_FAILURE(status)) { errln("Calendar::get failed"); return; } |
| } |
| } |
| delete c; |
| delete z; |
| delete gc; |
| } |
| |
| int32_t CalendarTest::EPOCH_FIELDS[] = { |
| 1, 1970, 0, 1, 1, 1, 1, 5, 1, 0, 0, 0, 0, 0, 0, - 28800000, 0 |
| }; |
| |
| // ------------------------------------- |
| |
| /** |
| * Test that the days of the week progress properly when add is called repeatedly |
| * for increments of 24 days. |
| */ |
| void |
| CalendarTest::TestDOWProgression() |
| { |
| UErrorCode status = U_ZERO_ERROR; |
| Calendar *cal = new GregorianCalendar(1972, UCAL_OCTOBER, 26, status); |
| if (failure(status, "new GregorianCalendar", TRUE)) return; |
| marchByDelta(cal, 24); |
| delete cal; |
| } |
| |
| // ------------------------------------- |
| |
| void |
| CalendarTest::TestDOW_LOCALandYEAR_WOY() |
| { |
| /* Note: I've commented out the loop_addroll tests for YEAR and |
| * YEAR_WOY below because these two fields should NOT behave |
| * identically when adding. YEAR should keep the month/dom |
| * invariant. YEAR_WOY should keep the woy/dow invariant. I've |
| * added a new test that checks for this in place of the old call |
| * to loop_addroll. - aliu */ |
| UErrorCode status = U_ZERO_ERROR; |
| int32_t times = 20; |
| Calendar *cal=Calendar::createInstance(Locale::getGermany(), status); |
| if (failure(status, "Calendar::createInstance", TRUE)) return; |
| SimpleDateFormat *sdf=new SimpleDateFormat(UnicodeString("YYYY'-W'ww-ee"), Locale::getGermany(), status); |
| if (U_FAILURE(status)) { dataerrln("Couldn't create SimpleDateFormat - %s", u_errorName(status)); return; } |
| |
| // ICU no longer use localized date-time pattern characters by default. |
| // So we set pattern chars using 'J' instead of 'Y'. |
| DateFormatSymbols *dfs = new DateFormatSymbols(Locale::getGermany(), status); |
| dfs->setLocalPatternChars(UnicodeString("GyMdkHmsSEDFwWahKzJeugAZvcLQq")); |
| sdf->adoptDateFormatSymbols(dfs); |
| sdf->applyLocalizedPattern(UnicodeString("JJJJ'-W'ww-ee"), status); |
| if (U_FAILURE(status)) { errln("Couldn't apply localized pattern"); return; } |
| |
| cal->clear(); |
| cal->set(1997, UCAL_DECEMBER, 25); |
| doYEAR_WOYLoop(cal, sdf, times, status); |
| //loop_addroll(cal, /*sdf,*/ times, UCAL_YEAR_WOY, UCAL_YEAR, status); |
| yearAddTest(*cal, status); // aliu |
| loop_addroll(cal, /*sdf,*/ times, UCAL_DOW_LOCAL, UCAL_DAY_OF_WEEK, status); |
| if (U_FAILURE(status)) { errln("Error in parse/calculate test for 1997"); return; } |
| |
| cal->clear(); |
| cal->set(1998, UCAL_DECEMBER, 25); |
| doYEAR_WOYLoop(cal, sdf, times, status); |
| //loop_addroll(cal, /*sdf,*/ times, UCAL_YEAR_WOY, UCAL_YEAR, status); |
| yearAddTest(*cal, status); // aliu |
| loop_addroll(cal, /*sdf,*/ times, UCAL_DOW_LOCAL, UCAL_DAY_OF_WEEK, status); |
| if (U_FAILURE(status)) { errln("Error in parse/calculate test for 1998"); return; } |
| |
| cal->clear(); |
| cal->set(1582, UCAL_OCTOBER, 1); |
| doYEAR_WOYLoop(cal, sdf, times, status); |
| //loop_addroll(cal, /*sdf,*/ times, Calendar::YEAR_WOY, Calendar::YEAR, status); |
| yearAddTest(*cal, status); // aliu |
| loop_addroll(cal, /*sdf,*/ times, UCAL_DOW_LOCAL, UCAL_DAY_OF_WEEK, status); |
| if (U_FAILURE(status)) { errln("Error in parse/calculate test for 1582"); return; } |
| delete sdf; |
| delete cal; |
| |
| return; |
| } |
| |
| /** |
| * Confirm that adding a YEAR and adding a YEAR_WOY work properly for |
| * the given Calendar at its current setting. |
| */ |
| void CalendarTest::yearAddTest(Calendar& cal, UErrorCode& status) { |
| /** |
| * When adding the YEAR, the month and day should remain constant. |
| * When adding the YEAR_WOY, the WOY and DOW should remain constant. - aliu |
| * Examples: |
| * Wed Jan 14 1998 / 1998-W03-03 Add(YEAR_WOY, 1) -> Wed Jan 20 1999 / 1999-W03-03 |
| * Add(YEAR, 1) -> Thu Jan 14 1999 / 1999-W02-04 |
| * Thu Jan 14 1999 / 1999-W02-04 Add(YEAR_WOY, 1) -> Thu Jan 13 2000 / 2000-W02-04 |
| * Add(YEAR, 1) -> Fri Jan 14 2000 / 2000-W02-05 |
| * Sun Oct 31 1582 / 1582-W42-07 Add(YEAR_WOY, 1) -> Sun Oct 23 1583 / 1583-W42-07 |
| * Add(YEAR, 1) -> Mon Oct 31 1583 / 1583-W44-01 |
| */ |
| int32_t y = cal.get(UCAL_YEAR, status); |
| int32_t mon = cal.get(UCAL_MONTH, status); |
| int32_t day = cal.get(UCAL_DATE, status); |
| int32_t ywy = cal.get(UCAL_YEAR_WOY, status); |
| int32_t woy = cal.get(UCAL_WEEK_OF_YEAR, status); |
| int32_t dow = cal.get(UCAL_DOW_LOCAL, status); |
| UDate t = cal.getTime(status); |
| |
| if(U_FAILURE(status)){ |
| errln(UnicodeString("Failed to create Calendar for locale. Error: ") + UnicodeString(u_errorName(status))); |
| return; |
| } |
| UnicodeString str, str2; |
| SimpleDateFormat fmt(UnicodeString("EEE MMM dd yyyy / YYYY'-W'ww-ee"), status); |
| fmt.setCalendar(cal); |
| |
| fmt.format(t, str.remove()); |
| str += ".add(YEAR, 1) =>"; |
| cal.add(UCAL_YEAR, 1, status); |
| int32_t y2 = cal.get(UCAL_YEAR, status); |
| int32_t mon2 = cal.get(UCAL_MONTH, status); |
| int32_t day2 = cal.get(UCAL_DATE, status); |
| fmt.format(cal.getTime(status), str); |
| if (y2 != (y+1) || mon2 != mon || day2 != day) { |
| str += (UnicodeString)", expected year " + |
| (y+1) + ", month " + (mon+1) + ", day " + day; |
| errln((UnicodeString)"FAIL: " + str); |
| logln( UnicodeString(" -> ") + CalendarTest::calToStr(cal) ); |
| } else { |
| logln(str); |
| } |
| |
| fmt.format(t, str.remove()); |
| str += ".add(YEAR_WOY, 1)=>"; |
| cal.setTime(t, status); |
| logln( UnicodeString(" <- ") + CalendarTest::calToStr(cal) ); |
| cal.add(UCAL_YEAR_WOY, 1, status); |
| int32_t ywy2 = cal.get(UCAL_YEAR_WOY, status); |
| int32_t woy2 = cal.get(UCAL_WEEK_OF_YEAR, status); |
| int32_t dow2 = cal.get(UCAL_DOW_LOCAL, status); |
| fmt.format(cal.getTime(status), str); |
| if (ywy2 != (ywy+1) || woy2 != woy || dow2 != dow) { |
| str += (UnicodeString)", expected yearWOY " + |
| (ywy+1) + ", woy " + woy + ", dowLocal " + dow; |
| errln((UnicodeString)"FAIL: " + str); |
| logln( UnicodeString(" -> ") + CalendarTest::calToStr(cal) ); |
| } else { |
| logln(str); |
| } |
| } |
| |
| // ------------------------------------- |
| |
| void CalendarTest::loop_addroll(Calendar *cal, /*SimpleDateFormat *sdf,*/ int times, UCalendarDateFields field, UCalendarDateFields field2, UErrorCode& errorCode) { |
| Calendar *calclone; |
| SimpleDateFormat fmt(UnicodeString("EEE MMM dd yyyy / YYYY'-W'ww-ee"), errorCode); |
| fmt.setCalendar(*cal); |
| int i; |
| |
| for(i = 0; i<times; i++) { |
| calclone = cal->clone(); |
| UDate start = cal->getTime(errorCode); |
| cal->add(field,1,errorCode); |
| if (U_FAILURE(errorCode)) { errln("Error in add"); delete calclone; return; } |
| calclone->add(field2,1,errorCode); |
| if (U_FAILURE(errorCode)) { errln("Error in add"); delete calclone; return; } |
| if(cal->getTime(errorCode) != calclone->getTime(errorCode)) { |
| UnicodeString str("FAIL: Results of add differ. "), str2; |
| str += fmt.format(start, str2) + " "; |
| str += UnicodeString("Add(") + fieldName(field) + ", 1) -> " + |
| fmt.format(cal->getTime(errorCode), str2.remove()) + "; "; |
| str += UnicodeString("Add(") + fieldName(field2) + ", 1) -> " + |
| fmt.format(calclone->getTime(errorCode), str2.remove()); |
| errln(str); |
| delete calclone; |
| return; |
| } |
| delete calclone; |
| } |
| |
| for(i = 0; i<times; i++) { |
| calclone = cal->clone(); |
| cal->roll(field,(int32_t)1,errorCode); |
| if (U_FAILURE(errorCode)) { errln("Error in roll"); delete calclone; return; } |
| calclone->roll(field2,(int32_t)1,errorCode); |
| if (U_FAILURE(errorCode)) { errln("Error in roll"); delete calclone; return; } |
| if(cal->getTime(errorCode) != calclone->getTime(errorCode)) { |
| delete calclone; |
| errln("Results of roll differ!"); |
| return; |
| } |
| delete calclone; |
| } |
| } |
| |
| // ------------------------------------- |
| |
| void |
| CalendarTest::doYEAR_WOYLoop(Calendar *cal, SimpleDateFormat *sdf, |
| int32_t times, UErrorCode& errorCode) { |
| |
| UnicodeString us; |
| UDate tst, original; |
| Calendar *tstres = new GregorianCalendar(Locale::getGermany(), errorCode); |
| for(int i=0; i<times; ++i) { |
| sdf->format(Formattable(cal->getTime(errorCode),Formattable::kIsDate), us, errorCode); |
| //logln("expected: "+us); |
| if (U_FAILURE(errorCode)) { errln("Format error"); return; } |
| tst=sdf->parse(us,errorCode); |
| if (U_FAILURE(errorCode)) { errln("Parse error"); return; } |
| tstres->clear(); |
| tstres->setTime(tst, errorCode); |
| //logln((UnicodeString)"Parsed week of year is "+tstres->get(UCAL_WEEK_OF_YEAR, errorCode)); |
| if (U_FAILURE(errorCode)) { errln("Set time error"); return; } |
| original = cal->getTime(errorCode); |
| us.remove(); |
| sdf->format(Formattable(tst,Formattable::kIsDate), us, errorCode); |
| //logln("got: "+us); |
| if (U_FAILURE(errorCode)) { errln("Get time error"); return; } |
| if(original!=tst) { |
| us.remove(); |
| sdf->format(Formattable(original, Formattable::kIsDate), us, errorCode); |
| errln("FAIL: Parsed time doesn't match with regular"); |
| logln("expected "+us + " " + calToStr(*cal)); |
| us.remove(); |
| sdf->format(Formattable(tst, Formattable::kIsDate), us, errorCode); |
| logln("got "+us + " " + calToStr(*tstres)); |
| } |
| tstres->clear(); |
| tstres->set(UCAL_YEAR_WOY, cal->get(UCAL_YEAR_WOY, errorCode)); |
| tstres->set(UCAL_WEEK_OF_YEAR, cal->get(UCAL_WEEK_OF_YEAR, errorCode)); |
| tstres->set(UCAL_DOW_LOCAL, cal->get(UCAL_DOW_LOCAL, errorCode)); |
| if(cal->get(UCAL_YEAR, errorCode) != tstres->get(UCAL_YEAR, errorCode)) { |
| errln("FAIL: Different Year!"); |
| logln((UnicodeString)"Expected "+cal->get(UCAL_YEAR, errorCode)); |
| logln((UnicodeString)"Got "+tstres->get(UCAL_YEAR, errorCode)); |
| return; |
| } |
| if(cal->get(UCAL_DAY_OF_YEAR, errorCode) != tstres->get(UCAL_DAY_OF_YEAR, errorCode)) { |
| errln("FAIL: Different Day Of Year!"); |
| logln((UnicodeString)"Expected "+cal->get(UCAL_DAY_OF_YEAR, errorCode)); |
| logln((UnicodeString)"Got "+tstres->get(UCAL_DAY_OF_YEAR, errorCode)); |
| return; |
| } |
| //logln(calToStr(*cal)); |
| cal->add(UCAL_DATE, 1, errorCode); |
| if (U_FAILURE(errorCode)) { errln("Add error"); return; } |
| us.remove(); |
| } |
| delete (tstres); |
| } |
| // ------------------------------------- |
| |
| void |
| CalendarTest::marchByDelta(Calendar* cal, int32_t delta) |
| { |
| UErrorCode status = U_ZERO_ERROR; |
| Calendar *cur = (Calendar*) cal->clone(); |
| int32_t initialDOW = cur->get(UCAL_DAY_OF_WEEK, status); |
| if (U_FAILURE(status)) { errln("Calendar::get failed"); return; } |
| int32_t DOW, newDOW = initialDOW; |
| do { |
| UnicodeString str; |
| DOW = newDOW; |
| logln(UnicodeString("DOW = ") + DOW + " " + dateToString(cur->getTime(status), str)); |
| if (U_FAILURE(status)) { errln("Calendar::getTime failed"); return; } |
| cur->add(UCAL_DAY_OF_WEEK, delta, status); |
| if (U_FAILURE(status)) { errln("Calendar::add failed"); return; } |
| newDOW = cur->get(UCAL_DAY_OF_WEEK, status); |
| if (U_FAILURE(status)) { errln("Calendar::get failed"); return; } |
| int32_t expectedDOW = 1 + (DOW + delta - 1) % 7; |
| if (newDOW != expectedDOW) { |
| errln(UnicodeString("Day of week should be ") + expectedDOW + " instead of " + newDOW + |
| " on " + dateToString(cur->getTime(status), str)); |
| if (U_FAILURE(status)) { errln("Calendar::getTime failed"); return; } |
| return; |
| } |
| } |
| while (newDOW != initialDOW); |
| delete cur; |
| } |
| |
| #define CHECK(status, msg) \ |
| if (U_FAILURE(status)) { \ |
| errcheckln(status, msg); \ |
| return; \ |
| } |
| |
| void CalendarTest::TestWOY(void) { |
| /* |
| FDW = Mon, MDFW = 4: |
| Sun Dec 26 1999, WOY 51 |
| Mon Dec 27 1999, WOY 52 |
| Tue Dec 28 1999, WOY 52 |
| Wed Dec 29 1999, WOY 52 |
| Thu Dec 30 1999, WOY 52 |
| Fri Dec 31 1999, WOY 52 |
| Sat Jan 01 2000, WOY 52 *** |
| Sun Jan 02 2000, WOY 52 *** |
| Mon Jan 03 2000, WOY 1 |
| Tue Jan 04 2000, WOY 1 |
| Wed Jan 05 2000, WOY 1 |
| Thu Jan 06 2000, WOY 1 |
| Fri Jan 07 2000, WOY 1 |
| Sat Jan 08 2000, WOY 1 |
| Sun Jan 09 2000, WOY 1 |
| Mon Jan 10 2000, WOY 2 |
| |
| FDW = Mon, MDFW = 2: |
| Sun Dec 26 1999, WOY 52 |
| Mon Dec 27 1999, WOY 1 *** |
| Tue Dec 28 1999, WOY 1 *** |
| Wed Dec 29 1999, WOY 1 *** |
| Thu Dec 30 1999, WOY 1 *** |
| Fri Dec 31 1999, WOY 1 *** |
| Sat Jan 01 2000, WOY 1 |
| Sun Jan 02 2000, WOY 1 |
| Mon Jan 03 2000, WOY 2 |
| Tue Jan 04 2000, WOY 2 |
| Wed Jan 05 2000, WOY 2 |
| Thu Jan 06 2000, WOY 2 |
| Fri Jan 07 2000, WOY 2 |
| Sat Jan 08 2000, WOY 2 |
| Sun Jan 09 2000, WOY 2 |
| Mon Jan 10 2000, WOY 3 |
| */ |
| |
| UnicodeString str; |
| UErrorCode status = U_ZERO_ERROR; |
| int32_t i; |
| |
| GregorianCalendar cal(status); |
| SimpleDateFormat fmt(UnicodeString("EEE MMM dd yyyy', WOY' w"), status); |
| if (failure(status, "Cannot construct calendar/format", TRUE)) return; |
| |
| UCalendarDaysOfWeek fdw = (UCalendarDaysOfWeek) 0; |
| |
| //for (int8_t pass=2; pass<=2; ++pass) { |
| for (int8_t pass=1; pass<=2; ++pass) { |
| switch (pass) { |
| case 1: |
| fdw = UCAL_MONDAY; |
| cal.setFirstDayOfWeek(fdw); |
| cal.setMinimalDaysInFirstWeek(4); |
| fmt.adoptCalendar(cal.clone()); |
| break; |
| case 2: |
| fdw = UCAL_MONDAY; |
| cal.setFirstDayOfWeek(fdw); |
| cal.setMinimalDaysInFirstWeek(2); |
| fmt.adoptCalendar(cal.clone()); |
| break; |
| } |
| |
| //for (i=2; i<=6; ++i) { |
| for (i=0; i<16; ++i) { |
| UDate t, t2; |
| int32_t t_y, t_woy, t_dow; |
| cal.clear(); |
| cal.set(1999, UCAL_DECEMBER, 26 + i); |
| fmt.format(t = cal.getTime(status), str.remove()); |
| CHECK(status, "Fail: getTime failed"); |
| logln(UnicodeString("* ") + str); |
| int32_t dow = cal.get(UCAL_DAY_OF_WEEK, status); |
| int32_t woy = cal.get(UCAL_WEEK_OF_YEAR, status); |
| int32_t year = cal.get(UCAL_YEAR, status); |
| int32_t mon = cal.get(UCAL_MONTH, status); |
| logln(calToStr(cal)); |
| CHECK(status, "Fail: get failed"); |
| int32_t dowLocal = dow - fdw; |
| if (dowLocal < 0) dowLocal += 7; |
| dowLocal++; |
| int32_t yearWoy = year; |
| if (mon == UCAL_JANUARY) { |
| if (woy >= 52) --yearWoy; |
| } else { |
| if (woy == 1) ++yearWoy; |
| } |
| |
| // Basic fields->time check y/woy/dow |
| // Since Y/WOY is ambiguous, we do a check of the fields, |
| // not of the specific time. |
| cal.clear(); |
| cal.set(UCAL_YEAR, year); |
| cal.set(UCAL_WEEK_OF_YEAR, woy); |
| cal.set(UCAL_DAY_OF_WEEK, dow); |
| t_y = cal.get(UCAL_YEAR, status); |
| t_woy = cal.get(UCAL_WEEK_OF_YEAR, status); |
| t_dow = cal.get(UCAL_DAY_OF_WEEK, status); |
| CHECK(status, "Fail: get failed"); |
| if (t_y != year || t_woy != woy || t_dow != dow) { |
| str = "Fail: y/woy/dow fields->time => "; |
| fmt.format(cal.getTime(status), str); |
| errln(str); |
| logln(calToStr(cal)); |
| logln("[get!=set] Y%d!=%d || woy%d!=%d || dow%d!=%d\n", |
| t_y, year, t_woy, woy, t_dow, dow); |
| } else { |
| logln("y/woy/dow fields->time OK"); |
| } |
| |
| // Basic fields->time check y/woy/dow_local |
| // Since Y/WOY is ambiguous, we do a check of the fields, |
| // not of the specific time. |
| cal.clear(); |
| cal.set(UCAL_YEAR, year); |
| cal.set(UCAL_WEEK_OF_YEAR, woy); |
| cal.set(UCAL_DOW_LOCAL, dowLocal); |
| t_y = cal.get(UCAL_YEAR, status); |
| t_woy = cal.get(UCAL_WEEK_OF_YEAR, status); |
| t_dow = cal.get(UCAL_DOW_LOCAL, status); |
| CHECK(status, "Fail: get failed"); |
| if (t_y != year || t_woy != woy || t_dow != dowLocal) { |
| str = "Fail: y/woy/dow_local fields->time => "; |
| fmt.format(cal.getTime(status), str); |
| errln(str); |
| } |
| |
| // Basic fields->time check y_woy/woy/dow |
| cal.clear(); |
| cal.set(UCAL_YEAR_WOY, yearWoy); |
| cal.set(UCAL_WEEK_OF_YEAR, woy); |
| cal.set(UCAL_DAY_OF_WEEK, dow); |
| t2 = cal.getTime(status); |
| CHECK(status, "Fail: getTime failed"); |
| if (t != t2) { |
| str = "Fail: y_woy/woy/dow fields->time => "; |
| fmt.format(t2, str); |
| errln(str); |
| logln(calToStr(cal)); |
| logln("%.f != %.f\n", t, t2); |
| } else { |
| logln("y_woy/woy/dow OK"); |
| } |
| |
| // Basic fields->time check y_woy/woy/dow_local |
| cal.clear(); |
| cal.set(UCAL_YEAR_WOY, yearWoy); |
| cal.set(UCAL_WEEK_OF_YEAR, woy); |
| cal.set(UCAL_DOW_LOCAL, dowLocal); |
| t2 = cal.getTime(status); |
| CHECK(status, "Fail: getTime failed"); |
| if (t != t2) { |
| str = "Fail: y_woy/woy/dow_local fields->time => "; |
| fmt.format(t2, str); |
| errln(str); |
| } |
| |
| logln("Testing DOW_LOCAL.. dow%d\n", dow); |
| // Make sure DOW_LOCAL disambiguates over DOW |
| int32_t wrongDow = dow - 3; |
| if (wrongDow < 1) wrongDow += 7; |
| cal.setTime(t, status); |
| cal.set(UCAL_DAY_OF_WEEK, wrongDow); |
| cal.set(UCAL_DOW_LOCAL, dowLocal); |
| t2 = cal.getTime(status); |
| CHECK(status, "Fail: set/getTime failed"); |
| if (t != t2) { |
| str = "Fail: DOW_LOCAL fields->time => "; |
| fmt.format(t2, str); |
| errln(str); |
| logln(calToStr(cal)); |
| logln("%.f : DOW%d, DOW_LOCAL%d -> %.f\n", |
| t, wrongDow, dowLocal, t2); |
| } |
| |
| // Make sure DOW disambiguates over DOW_LOCAL |
| int32_t wrongDowLocal = dowLocal - 3; |
| if (wrongDowLocal < 1) wrongDowLocal += 7; |
| cal.setTime(t, status); |
| cal.set(UCAL_DOW_LOCAL, wrongDowLocal); |
| cal.set(UCAL_DAY_OF_WEEK, dow); |
| t2 = cal.getTime(status); |
| CHECK(status, "Fail: set/getTime failed"); |
| if (t != t2) { |
| str = "Fail: DOW fields->time => "; |
| fmt.format(t2, str); |
| errln(str); |
| } |
| |
| // Make sure YEAR_WOY disambiguates over YEAR |
| cal.setTime(t, status); |
| cal.set(UCAL_YEAR, year - 2); |
| cal.set(UCAL_YEAR_WOY, yearWoy); |
| t2 = cal.getTime(status); |
| CHECK(status, "Fail: set/getTime failed"); |
| if (t != t2) { |
| str = "Fail: YEAR_WOY fields->time => "; |
| fmt.format(t2, str); |
| errln(str); |
| } |
| |
| // Make sure YEAR disambiguates over YEAR_WOY |
| cal.setTime(t, status); |
| cal.set(UCAL_YEAR_WOY, yearWoy - 2); |
| cal.set(UCAL_YEAR, year); |
| t2 = cal.getTime(status); |
| CHECK(status, "Fail: set/getTime failed"); |
| if (t != t2) { |
| str = "Fail: YEAR fields->time => "; |
| fmt.format(t2, str); |
| errln(str); |
| } |
| } |
| } |
| |
| /* |
| FDW = Mon, MDFW = 4: |
| Sun Dec 26 1999, WOY 51 |
| Mon Dec 27 1999, WOY 52 |
| Tue Dec 28 1999, WOY 52 |
| Wed Dec 29 1999, WOY 52 |
| Thu Dec 30 1999, WOY 52 |
| Fri Dec 31 1999, WOY 52 |
| Sat Jan 01 2000, WOY 52 |
| Sun Jan 02 2000, WOY 52 |
| */ |
| |
| // Roll the DOW_LOCAL within week 52 |
| for (i=27; i<=33; ++i) { |
| int32_t amount; |
| for (amount=-7; amount<=7; ++amount) { |
| str = "roll("; |
| cal.set(1999, UCAL_DECEMBER, i); |
| UDate t, t2; |
| fmt.format(cal.getTime(status), str); |
| CHECK(status, "Fail: getTime failed"); |
| str += UnicodeString(", ") + amount + ") = "; |
| |
| cal.roll(UCAL_DOW_LOCAL, amount, status); |
| CHECK(status, "Fail: roll failed"); |
| |
| t = cal.getTime(status); |
| int32_t newDom = i + amount; |
| while (newDom < 27) newDom += 7; |
| while (newDom > 33) newDom -= 7; |
| cal.set(1999, UCAL_DECEMBER, newDom); |
| t2 = cal.getTime(status); |
| CHECK(status, "Fail: getTime failed"); |
| fmt.format(t, str); |
| |
| if (t != t2) { |
| str.append(", exp "); |
| fmt.format(t2, str); |
| errln(str); |
| } else { |
| logln(str); |
| } |
| } |
| } |
| } |
| |
| void CalendarTest::TestYWOY() |
| { |
| UnicodeString str; |
| UErrorCode status = U_ZERO_ERROR; |
| |
| GregorianCalendar cal(status); |
| if (failure(status, "construct GregorianCalendar", TRUE)) return; |
| |
| cal.setFirstDayOfWeek(UCAL_SUNDAY); |
| cal.setMinimalDaysInFirstWeek(1); |
| |
| logln("Setting: ywoy=2004, woy=1, dow=MONDAY"); |
| cal.clear(); |
| cal.set(UCAL_YEAR_WOY,2004); |
| cal.set(UCAL_WEEK_OF_YEAR,1); |
| cal.set(UCAL_DAY_OF_WEEK, UCAL_MONDAY); |
| |
| logln(calToStr(cal)); |
| if(cal.get(UCAL_YEAR, status) != 2003) { |
| errln("year not 2003"); |
| } |
| |
| logln("+ setting DOW to THURSDAY"); |
| cal.clear(); |
| cal.set(UCAL_YEAR_WOY,2004); |
| cal.set(UCAL_WEEK_OF_YEAR,1); |
| cal.set(UCAL_DAY_OF_WEEK, UCAL_THURSDAY); |
| |
| logln(calToStr(cal)); |
| if(cal.get(UCAL_YEAR, status) != 2004) { |
| errln("year not 2004"); |
| } |
| |
| logln("+ setting DOW_LOCAL to 1"); |
| cal.clear(); |
| cal.set(UCAL_YEAR_WOY,2004); |
| cal.set(UCAL_WEEK_OF_YEAR,1); |
| cal.set(UCAL_DAY_OF_WEEK, UCAL_THURSDAY); |
| cal.set(UCAL_DOW_LOCAL, 1); |
| |
| logln(calToStr(cal)); |
| if(cal.get(UCAL_YEAR, status) != 2003) { |
| errln("year not 2003"); |
| } |
| |
| cal.setFirstDayOfWeek(UCAL_MONDAY); |
| cal.setMinimalDaysInFirstWeek(4); |
| UDate t = 946713600000.; |
| cal.setTime(t, status); |
| cal.set(UCAL_DAY_OF_WEEK, 4); |
| cal.set(UCAL_DOW_LOCAL, 6); |
| if(cal.getTime(status) != t) { |
| logln(calToStr(cal)); |
| errln("FAIL: DOW_LOCAL did not take precedence"); |
| } |
| |
| } |
| |
| void CalendarTest::TestJD() |
| { |
| int32_t jd; |
| static const int32_t kEpochStartAsJulianDay = 2440588; |
| UErrorCode status = U_ZERO_ERROR; |
| GregorianCalendar cal(status); |
| if (failure(status, "construct GregorianCalendar", TRUE)) return; |
| cal.setTimeZone(*TimeZone::getGMT()); |
| cal.clear(); |
| jd = cal.get(UCAL_JULIAN_DAY, status); |
| if(jd != kEpochStartAsJulianDay) { |
| errln("Wanted JD of %d at time=0, [epoch 1970] but got %d\n", kEpochStartAsJulianDay, jd); |
| } else { |
| logln("Wanted JD of %d at time=0, [epoch 1970], got %d\n", kEpochStartAsJulianDay, jd); |
| } |
| |
| cal.setTime(Calendar::getNow(), status); |
| cal.clear(); |
| cal.set(UCAL_JULIAN_DAY, kEpochStartAsJulianDay); |
| UDate epochTime = cal.getTime(status); |
| if(epochTime != 0) { |
| errln("Wanted time of 0 at jd=%d, got %.1lf\n", kEpochStartAsJulianDay, epochTime); |
| } else { |
| logln("Wanted time of 0 at jd=%d, got %.1lf\n", kEpochStartAsJulianDay, epochTime); |
| } |
| |
| } |
| |
| // make sure the ctestfw utilities are in sync with the Calendar |
| void CalendarTest::TestDebug() |
| { |
| for(int32_t t=0;t<=UDBG_ENUM_COUNT;t++) { |
| int32_t count = udbg_enumCount((UDebugEnumType)t); |
| if(count == -1) { |
| logln("enumCount(%d) returned -1", count); |
| continue; |
| } |
| for(int32_t i=0;i<=count;i++) { |
| if(t<=UDBG_HIGHEST_CONTIGUOUS_ENUM && i<count) { |
| if( i!=udbg_enumArrayValue((UDebugEnumType)t, i)) { |
| errln("FAIL: udbg_enumArrayValue(%d,%d) returned %d, expected %d", t, i, udbg_enumArrayValue((UDebugEnumType)t,i), i); |
| } |
| } else { |
| logln("Testing count+1:"); |
| } |
| const char *name = udbg_enumName((UDebugEnumType)t,i); |
| if(name==NULL) { |
| if(i==count || t>UDBG_HIGHEST_CONTIGUOUS_ENUM ) { |
| logln(" null name - expected.\n"); |
| } else { |
| errln("FAIL: udbg_enumName(%d,%d) returned NULL", t, i); |
| } |
| name = "(null)"; |
| } |
| logln("udbg_enumArrayValue(%d,%d) = %s, returned %d", t, i, |
| name, udbg_enumArrayValue((UDebugEnumType)t,i)); |
| logln("udbg_enumString = " + udbg_enumString((UDebugEnumType)t,i)); |
| } |
| if(udbg_enumExpectedCount((UDebugEnumType)t) != count && t<=UDBG_HIGHEST_CONTIGUOUS_ENUM) { |
| errln("FAIL: udbg_enumExpectedCount(%d): %d, != UCAL_FIELD_COUNT=%d ", t, udbg_enumExpectedCount((UDebugEnumType)t), count); |
| } else { |
| logln("udbg_ucal_fieldCount: %d, UCAL_FIELD_COUNT=udbg_enumCount %d ", udbg_enumExpectedCount((UDebugEnumType)t), count); |
| } |
| } |
| } |
| |
| |
| #undef CHECK |
| |
| // List of interesting locales |
| const char *CalendarTest::testLocaleID(int32_t i) |
| { |
| switch(i) { |
| case 0: return "he_IL@calendar=hebrew"; |
| case 1: return "en_US@calendar=hebrew"; |
| case 2: return "fr_FR@calendar=hebrew"; |
| case 3: return "fi_FI@calendar=hebrew"; |
| case 4: return "nl_NL@calendar=hebrew"; |
| case 5: return "hu_HU@calendar=hebrew"; |
| case 6: return "nl_BE@currency=MTL;calendar=islamic"; |
| case 7: return "th_TH_TRADITIONAL@calendar=gregorian"; |
| case 8: return "ar_JO@calendar=islamic-civil"; |
| case 9: return "fi_FI@calendar=islamic"; |
| case 10: return "fr_CH@calendar=islamic-civil"; |
| case 11: return "he_IL@calendar=islamic-civil"; |
| case 12: return "hu_HU@calendar=buddhist"; |
| case 13: return "hu_HU@calendar=islamic"; |
| case 14: return "en_US@calendar=japanese"; |
| default: return NULL; |
| } |
| } |
| |
| int32_t CalendarTest::testLocaleCount() |
| { |
| static int32_t gLocaleCount = -1; |
| if(gLocaleCount < 0) { |
| int32_t i; |
| for(i=0;testLocaleID(i) != NULL;i++) { |
| ; |
| } |
| gLocaleCount = i; |
| } |
| return gLocaleCount; |
| } |
| |
| static UDate doMinDateOfCalendar(Calendar* adopt, UBool &isGregorian, UErrorCode& status) { |
| if(U_FAILURE(status)) return 0.0; |
| |
| adopt->clear(); |
| adopt->set(UCAL_EXTENDED_YEAR, adopt->getActualMinimum(UCAL_EXTENDED_YEAR, status)); |
| UDate ret = adopt->getTime(status); |
| isGregorian = dynamic_cast<GregorianCalendar*>(adopt) != NULL; |
| delete adopt; |
| return ret; |
| } |
| |
| UDate CalendarTest::minDateOfCalendar(const Locale& locale, UBool &isGregorian, UErrorCode& status) { |
| if(U_FAILURE(status)) return 0.0; |
| return doMinDateOfCalendar(Calendar::createInstance(locale, status), isGregorian, status); |
| } |
| |
| UDate CalendarTest::minDateOfCalendar(const Calendar& cal, UBool &isGregorian, UErrorCode& status) { |
| if(U_FAILURE(status)) return 0.0; |
| return doMinDateOfCalendar(cal.clone(), isGregorian, status); |
| } |
| |
| void CalendarTest::Test6703() |
| { |
| UErrorCode status = U_ZERO_ERROR; |
| Calendar *cal; |
| |
| Locale loc1("en@calendar=fubar"); |
| cal = Calendar::createInstance(loc1, status); |
| if (failure(status, "Calendar::createInstance", TRUE)) return; |
| delete cal; |
| |
| status = U_ZERO_ERROR; |
| Locale loc2("en"); |
| cal = Calendar::createInstance(loc2, status); |
| if (failure(status, "Calendar::createInstance")) return; |
| delete cal; |
| |
| status = U_ZERO_ERROR; |
| Locale loc3("en@calendar=roc"); |
| cal = Calendar::createInstance(loc3, status); |
| if (failure(status, "Calendar::createInstance")) return; |
| delete cal; |
| |
| return; |
| } |
| |
| void CalendarTest::Test3785() |
| { |
| UErrorCode status = U_ZERO_ERROR; |
| UnicodeString uzone = UNICODE_STRING_SIMPLE("Europe/Paris"); |
| UnicodeString exp1 = UNICODE_STRING_SIMPLE("Mon 30 Jumada II 1433 AH, 01:47:03"); |
| UnicodeString exp2 = UNICODE_STRING_SIMPLE("Mon 1 Rajab 1433 AH, 01:47:04"); |
| |
| LocalUDateFormatPointer df(udat_open(UDAT_NONE, UDAT_NONE, "en@calendar=islamic", uzone.getTerminatedBuffer(), |
| uzone.length(), NULL, 0, &status)); |
| if (df.isNull() || U_FAILURE(status)) return; |
| |
| UChar upattern[64]; |
| u_uastrcpy(upattern, "EEE d MMMM y G, HH:mm:ss"); |
| udat_applyPattern(df.getAlias(), FALSE, upattern, u_strlen(upattern)); |
| |
| UChar ubuffer[1024]; |
| UDate ud0 = 1337557623000.0; |
| |
| status = U_ZERO_ERROR; |
| udat_format(df.getAlias(), ud0, ubuffer, 1024, NULL, &status); |
| if (U_FAILURE(status)) { |
| errln("Error formatting date 1\n"); |
| return; |
| } |
| //printf("formatted: '%s'\n", mkcstr(ubuffer)); |
| |
| UnicodeString act1(ubuffer); |
| if ( act1 != exp1 ) { |
| errln("Unexpected result from date 1 format\n"); |
| } |
| ud0 += 1000.0; // add one second |
| |
| status = U_ZERO_ERROR; |
| udat_format(df.getAlias(), ud0, ubuffer, 1024, NULL, &status); |
| if (U_FAILURE(status)) { |
| errln("Error formatting date 2\n"); |
| return; |
| } |
| //printf("formatted: '%s'\n", mkcstr(ubuffer)); |
| UnicodeString act2(ubuffer); |
| if ( act2 != exp2 ) { |
| errln("Unexpected result from date 2 format\n"); |
| } |
| |
| return; |
| } |
| |
| void CalendarTest::Test1624() { |
| UErrorCode status = U_ZERO_ERROR; |
| Locale loc("he_IL@calendar=hebrew"); |
| HebrewCalendar hc(loc,status); |
| |
| for (int32_t year = 5600; year < 5800; year++ ) { |
| |
| for (int32_t month = HebrewCalendar::TISHRI; month <= HebrewCalendar::ELUL; month++) { |
| // skip the adar 1 month if year is not a leap year |
| if (HebrewCalendar::isLeapYear(year) == FALSE && month == HebrewCalendar::ADAR_1) { |
| continue; |
| } |
| int32_t day = 15; |
| hc.set(year,month,day); |
| int32_t dayHC = hc.get(UCAL_DATE,status); |
| int32_t monthHC = hc.get(UCAL_MONTH,status); |
| int32_t yearHC = hc.get(UCAL_YEAR,status); |
| |
| if (failure(status, "HebrewCalendar.get()", TRUE)) continue; |
| |
| if (dayHC != day) { |
| errln(" ==> day %d incorrect, should be: %d\n",dayHC,day); |
| break; |
| } |
| if (monthHC != month) { |
| errln(" ==> month %d incorrect, should be: %d\n",monthHC,month); |
| break; |
| } |
| if (yearHC != year) { |
| errln(" ==> day %d incorrect, should be: %d\n",yearHC,year); |
| break; |
| } |
| } |
| } |
| return; |
| } |
| |
| void CalendarTest::TestTimeStamp() { |
| UErrorCode status = U_ZERO_ERROR; |
| UDate start = 0.0, time; |
| Calendar *cal; |
| |
| // Create a new Gregorian Calendar. |
| cal = Calendar::createInstance("en_US@calender=gregorian", status); |
| if (U_FAILURE(status)) { |
| dataerrln("Error creating Gregorian calendar."); |
| return; |
| } |
| |
| for (int i = 0; i < 20000; i++) { |
| // Set the Gregorian Calendar to a specific date for testing. |
| cal->set(2009, UCAL_JULY, 3, 0, 49, 46); |
| |
| time = cal->getTime(status); |
| if (U_FAILURE(status)) { |
| errln("Error calling getTime()"); |
| break; |
| } |
| |
| if (i == 0) { |
| start = time; |
| } else { |
| if (start != time) { |
| errln("start and time not equal."); |
| break; |
| } |
| } |
| } |
| |
| delete cal; |
| } |
| |
| void CalendarTest::TestISO8601() { |
| const char* TEST_LOCALES[] = { |
| "en_US@calendar=iso8601", |
| "en_US@calendar=Iso8601", |
| "th_TH@calendar=iso8601", |
| "ar_EG@calendar=iso8601", |
| NULL |
| }; |
| |
| int32_t TEST_DATA[][3] = { |
| {2008, 1, 2008}, |
| {2009, 1, 2009}, |
| {2010, 53, 2009}, |
| {2011, 52, 2010}, |
| {2012, 52, 2011}, |
| {2013, 1, 2013}, |
| {2014, 1, 2014}, |
| {0, 0, 0}, |
| }; |
| |
| for (int i = 0; TEST_LOCALES[i] != NULL; i++) { |
| UErrorCode status = U_ZERO_ERROR; |
| Calendar *cal = Calendar::createInstance(TEST_LOCALES[i], status); |
| if (U_FAILURE(status)) { |
| errln("Error: Failed to create a calendar for locale: %s", TEST_LOCALES[i]); |
| continue; |
| } |
| if (uprv_strcmp(cal->getType(), "gregorian") != 0) { |
| errln("Error: Gregorian calendar is not used for locale: %s", TEST_LOCALES[i]); |
| continue; |
| } |
| for (int j = 0; TEST_DATA[j][0] != 0; j++) { |
| cal->set(TEST_DATA[j][0], UCAL_JANUARY, 1); |
| int32_t weekNum = cal->get(UCAL_WEEK_OF_YEAR, status); |
| int32_t weekYear = cal->get(UCAL_YEAR_WOY, status); |
| if (U_FAILURE(status)) { |
| errln("Error: Failed to get week of year"); |
| break; |
| } |
| if (weekNum != TEST_DATA[j][1] || weekYear != TEST_DATA[j][2]) { |
| errln("Error: Incorrect week of year on January 1st, %d for locale %s: Returned [weekNum=%d, weekYear=%d], Expected [weekNum=%d, weekYear=%d]", |
| TEST_DATA[j][0], TEST_LOCALES[i], weekNum, weekYear, TEST_DATA[j][1], TEST_DATA[j][2]); |
| } |
| } |
| delete cal; |
| } |
| |
| } |
| |
| void |
| CalendarTest::TestAmbiguousWallTimeAPIs(void) { |
| UErrorCode status = U_ZERO_ERROR; |
| Calendar* cal = Calendar::createInstance(status); |
| if (U_FAILURE(status)) { |
| errln("Fail: Error creating a calendar instance."); |
| return; |
| } |
| |
| if (cal->getRepeatedWallTimeOption() != UCAL_WALLTIME_LAST) { |
| errln("Fail: Default repeted time option is not UCAL_WALLTIME_LAST"); |
| } |
| if (cal->getSkippedWallTimeOption() != UCAL_WALLTIME_LAST) { |
| errln("Fail: Default skipped time option is not UCAL_WALLTIME_LAST"); |
| } |
| |
| Calendar* cal2 = cal->clone(); |
| |
| if (*cal != *cal2) { |
| errln("Fail: Cloned calendar != the original"); |
| } |
| if (!cal->equals(*cal2, status)) { |
| errln("Fail: The time of cloned calendar is not equal to the original"); |
| } else if (U_FAILURE(status)) { |
| errln("Fail: Error equals"); |
| } |
| status = U_ZERO_ERROR; |
| |
| cal2->setRepeatedWallTimeOption(UCAL_WALLTIME_FIRST); |
| cal2->setSkippedWallTimeOption(UCAL_WALLTIME_FIRST); |
| |
| if (*cal == *cal2) { |
| errln("Fail: Cloned and modified calendar == the original"); |
| } |
| if (!cal->equals(*cal2, status)) { |
| errln("Fail: The time of cloned calendar is not equal to the original after changing wall time options"); |
| } else if (U_FAILURE(status)) { |
| errln("Fail: Error equals after changing wall time options"); |
| } |
| status = U_ZERO_ERROR; |
| |
| if (cal2->getRepeatedWallTimeOption() != UCAL_WALLTIME_FIRST) { |
| errln("Fail: Repeted time option is not UCAL_WALLTIME_FIRST"); |
| } |
| if (cal2->getSkippedWallTimeOption() != UCAL_WALLTIME_FIRST) { |
| errln("Fail: Skipped time option is not UCAL_WALLTIME_FIRST"); |
| } |
| |
| cal2->setRepeatedWallTimeOption(UCAL_WALLTIME_NEXT_VALID); |
| if (cal2->getRepeatedWallTimeOption() != UCAL_WALLTIME_FIRST) { |
| errln("Fail: Repeated wall time option was updated other than UCAL_WALLTIME_FIRST"); |
| } |
| |
| delete cal; |
| delete cal2; |
| } |
| |
| class CalFields { |
| public: |
| CalFields(int32_t year, int32_t month, int32_t day, int32_t hour, int32_t min, int32_t sec, int32_t ms = 0); |
| CalFields(const Calendar& cal, UErrorCode& status); |
| void setTo(Calendar& cal) const; |
| char* toString(char* buf, int32_t len) const; |
| UBool operator==(const CalFields& rhs) const; |
| UBool operator!=(const CalFields& rhs) const; |
| UBool isEquivalentTo(const Calendar& cal, UErrorCode& status) const; |
| |
| private: |
| int32_t year; |
| int32_t month; |
| int32_t day; |
| int32_t hour; |
| int32_t min; |
| int32_t sec; |
| int32_t ms; |
| }; |
| |
| CalFields::CalFields(int32_t year, int32_t month, int32_t day, int32_t hour, int32_t min, int32_t sec, int32_t ms) |
| : year(year), month(month), day(day), hour(hour), min(min), sec(sec), ms(ms) { |
| } |
| |
| CalFields::CalFields(const Calendar& cal, UErrorCode& status) { |
| year = cal.get(UCAL_YEAR, status); |
| month = cal.get(UCAL_MONTH, status) + 1; |
| day = cal.get(UCAL_DAY_OF_MONTH, status); |
| hour = cal.get(UCAL_HOUR_OF_DAY, status); |
| min = cal.get(UCAL_MINUTE, status); |
| sec = cal.get(UCAL_SECOND, status); |
| ms = cal.get(UCAL_MILLISECOND, status); |
| } |
| |
| void |
| CalFields::setTo(Calendar& cal) const { |
| cal.clear(); |
| cal.set(year, month - 1, day, hour, min, sec); |
| cal.set(UCAL_MILLISECOND, ms); |
| } |
| |
| char* |
| CalFields::toString(char* buf, int32_t len) const { |
| char local[32]; |
| sprintf(local, "%04d-%02d-%02d %02d:%02d:%02d.%03d", year, month, day, hour, min, sec, ms); |
| uprv_strncpy(buf, local, len - 1); |
| buf[len - 1] = 0; |
| return buf; |
| } |
| |
| UBool |
| CalFields::operator==(const CalFields& rhs) const { |
| return year == rhs.year |
| && month == rhs.month |
| && day == rhs.day |
| && hour == rhs.hour |
| && min == rhs.min |
| && sec == rhs.sec |
| && ms == rhs.ms; |
| } |
| |
| UBool |
| CalFields::operator!=(const CalFields& rhs) const { |
| return !(*this == rhs); |
| } |
| |
| UBool |
| CalFields::isEquivalentTo(const Calendar& cal, UErrorCode& status) const { |
| return year == cal.get(UCAL_YEAR, status) |
| && month == cal.get(UCAL_MONTH, status) + 1 |
| && day == cal.get(UCAL_DAY_OF_MONTH, status) |
| && hour == cal.get(UCAL_HOUR_OF_DAY, status) |
| && min == cal.get(UCAL_MINUTE, status) |
| && sec == cal.get(UCAL_SECOND, status) |
| && ms == cal.get(UCAL_MILLISECOND, status); |
| } |
| |
| typedef struct { |
| const char* tzid; |
| const CalFields in; |
| const CalFields expLastGMT; |
| const CalFields expFirstGMT; |
| } RepeatedWallTimeTestData; |
| |
| static const RepeatedWallTimeTestData RPDATA[] = |
| { |
| // Time zone Input wall time WALLTIME_LAST in GMT WALLTIME_FIRST in GMT |
| {"America/New_York", CalFields(2011,11,6,0,59,59), CalFields(2011,11,6,4,59,59), CalFields(2011,11,6,4,59,59)}, |
| {"America/New_York", CalFields(2011,11,6,1,0,0), CalFields(2011,11,6,6,0,0), CalFields(2011,11,6,5,0,0)}, |
| {"America/New_York", CalFields(2011,11,6,1,0,1), CalFields(2011,11,6,6,0,1), CalFields(2011,11,6,5,0,1)}, |
| {"America/New_York", CalFields(2011,11,6,1,30,0), CalFields(2011,11,6,6,30,0), CalFields(2011,11,6,5,30,0)}, |
| {"America/New_York", CalFields(2011,11,6,1,59,59), CalFields(2011,11,6,6,59,59), CalFields(2011,11,6,5,59,59)}, |
| {"America/New_York", CalFields(2011,11,6,2,0,0), CalFields(2011,11,6,7,0,0), CalFields(2011,11,6,7,0,0)}, |
| {"America/New_York", CalFields(2011,11,6,2,0,1), CalFields(2011,11,6,7,0,1), CalFields(2011,11,6,7,0,1)}, |
| |
| {"Australia/Lord_Howe", CalFields(2011,4,3,1,29,59), CalFields(2011,4,2,14,29,59), CalFields(2011,4,2,14,29,59)}, |
| {"Australia/Lord_Howe", CalFields(2011,4,3,1,30,0), CalFields(2011,4,2,15,0,0), CalFields(2011,4,2,14,30,0)}, |
| {"Australia/Lord_Howe", CalFields(2011,4,3,1,45,0), CalFields(2011,4,2,15,15,0), CalFields(2011,4,2,14,45,0)}, |
| {"Australia/Lord_Howe", CalFields(2011,4,3,1,59,59), CalFields(2011,4,2,15,29,59), CalFields(2011,4,2,14,59,59)}, |
| {"Australia/Lord_Howe", CalFields(2011,4,3,2,0,0), CalFields(2011,4,2,15,30,0), CalFields(2011,4,2,15,30,0)}, |
| {"Australia/Lord_Howe", CalFields(2011,4,3,2,0,1), CalFields(2011,4,2,15,30,1), CalFields(2011,4,2,15,30,1)}, |
| |
| {NULL, CalFields(0,0,0,0,0,0), CalFields(0,0,0,0,0,0), CalFields(0,0,0,0,0,0)} |
| }; |
| |
| void CalendarTest::TestRepeatedWallTime(void) { |
| UErrorCode status = U_ZERO_ERROR; |
| GregorianCalendar calGMT((const TimeZone&)*TimeZone::getGMT(), status); |
| GregorianCalendar calDefault(status); |
| GregorianCalendar calLast(status); |
| GregorianCalendar calFirst(status); |
| |
| if (U_FAILURE(status)) { |
| errln("Fail: Failed to create a calendar object."); |
| return; |
| } |
| |
| calLast.setRepeatedWallTimeOption(UCAL_WALLTIME_LAST); |
| calFirst.setRepeatedWallTimeOption(UCAL_WALLTIME_FIRST); |
| |
| for (int32_t i = 0; RPDATA[i].tzid != NULL; i++) { |
| char buf[32]; |
| TimeZone *tz = TimeZone::createTimeZone(RPDATA[i].tzid); |
| |
| // UCAL_WALLTIME_LAST |
| status = U_ZERO_ERROR; |
| calLast.setTimeZone(*tz); |
| RPDATA[i].in.setTo(calLast); |
| calGMT.setTime(calLast.getTime(status), status); |
| CalFields outLastGMT(calGMT, status); |
| if (U_FAILURE(status)) { |
| errln(UnicodeString("Fail: Failed to get/set time calLast/calGMT (UCAL_WALLTIME_LAST) - ") |
| + RPDATA[i].in.toString(buf, sizeof(buf)) + "[" + RPDATA[i].tzid + "]"); |
| } else { |
| if (outLastGMT != RPDATA[i].expLastGMT) { |
| dataerrln(UnicodeString("Fail: UCAL_WALLTIME_LAST ") + RPDATA[i].in.toString(buf, sizeof(buf)) + "[" + RPDATA[i].tzid + "] is parsed as " |
| + outLastGMT.toString(buf, sizeof(buf)) + "[GMT]. Expected: " |