ICU-6814 Updated useDaylightTime to return TRUE when DST is used at the beginning of the current year. Updated TimeZoneTest to make some test cases to check the current tzdata version and current year.
X-SVN-Rev: 25681
This commit is contained in:
parent
e070a8aeb1
commit
fc67192e07
@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
**********************************************************************
|
**********************************************************************
|
||||||
* Copyright (c) 2003-2008, International Business Machines
|
* Copyright (c) 2003-2009, International Business Machines
|
||||||
* Corporation and others. All Rights Reserved.
|
* Corporation and others. All Rights Reserved.
|
||||||
**********************************************************************
|
**********************************************************************
|
||||||
* Author: Alan Liu
|
* Author: Alan Liu
|
||||||
@ -526,8 +526,8 @@ UBool OlsonTimeZone::useDaylightTime() const {
|
|||||||
if (transitionTimes[i] >= limit) {
|
if (transitionTimes[i] >= limit) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (transitionTimes[i] >= start &&
|
if ((transitionTimes[i] >= start && dstOffset(typeData[i]) != 0)
|
||||||
dstOffset(typeData[i]) != 0) {
|
|| (transitionTimes[i] > start && i > 0 && dstOffset(typeData[i - 1]) != 0)) {
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
*******************************************************************************
|
*******************************************************************************
|
||||||
* Copyright (C) 1997-2008, International Business Machines Corporation and *
|
* Copyright (C) 1997-2009, International Business Machines Corporation and *
|
||||||
* others. All Rights Reserved. *
|
* others. All Rights Reserved. *
|
||||||
*******************************************************************************
|
*******************************************************************************
|
||||||
*
|
*
|
||||||
@ -1204,6 +1204,8 @@ TimeZone::getDisplayName(UBool daylight, EDisplayType style, const Locale& local
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// The display name for standard time was requested, but currently in DST
|
// The display name for standard time was requested, but currently in DST
|
||||||
|
// or display name for daylight saving time was requested, but this zone no longer
|
||||||
|
// observes DST.
|
||||||
tz = new SimpleTimeZone(rawOffset, tempID);
|
tz = new SimpleTimeZone(rawOffset, tempID);
|
||||||
if (U_FAILURE(status) || tz == NULL) {
|
if (U_FAILURE(status) || tz == NULL) {
|
||||||
if (U_SUCCESS(status)) {
|
if (U_SUCCESS(status)) {
|
||||||
|
@ -34,6 +34,11 @@
|
|||||||
// class TimeZoneTest
|
// class TimeZoneTest
|
||||||
// *****************************************************************************
|
// *****************************************************************************
|
||||||
|
|
||||||
|
// TODO: We should probably read following data at runtime, so we can update
|
||||||
|
// the these values every release with necessary data changes.
|
||||||
|
const int32_t TimeZoneTest::REFERENCE_YEAR = 2009;
|
||||||
|
const char * TimeZoneTest::REFERENCE_DATA_VERSION = "2009d";
|
||||||
|
|
||||||
void TimeZoneTest::runIndexedTest( int32_t index, UBool exec, const char* &name, char* /*par*/ )
|
void TimeZoneTest::runIndexedTest( int32_t index, UBool exec, const char* &name, char* /*par*/ )
|
||||||
{
|
{
|
||||||
if (exec) logln("TestSuite TestTimeZone");
|
if (exec) logln("TestSuite TestTimeZone");
|
||||||
@ -579,18 +584,13 @@ TimeZoneTest::TestGetAvailableIDs913()
|
|||||||
*/
|
*/
|
||||||
void TimeZoneTest::TestShortZoneIDs()
|
void TimeZoneTest::TestShortZoneIDs()
|
||||||
{
|
{
|
||||||
// TODO: This test case is tzdata sensitive.
|
|
||||||
// We should actually put the data version in this test code
|
|
||||||
// at build time. For now, we just hardcode the version string
|
|
||||||
// and display warning instead of error if non-reference tzdata
|
|
||||||
// version is used.
|
|
||||||
const char *REFERENCE_DATA_VERSION = "2008i";
|
|
||||||
|
|
||||||
UErrorCode status = U_ZERO_ERROR;
|
UErrorCode status = U_ZERO_ERROR;
|
||||||
|
|
||||||
|
// This test case is tzdata version sensitive.
|
||||||
UBool isNonReferenceTzdataVersion = FALSE;
|
UBool isNonReferenceTzdataVersion = FALSE;
|
||||||
const char *tzdataVer = TimeZone::getTZDataVersion(status);
|
const char *tzdataVer = TimeZone::getTZDataVersion(status);
|
||||||
if (failure(status, "getTZDataVersion")) return;
|
if (failure(status, "getTZDataVersion")) return;
|
||||||
if (uprv_strcmp(tzdataVer, REFERENCE_DATA_VERSION) != 0) {
|
if (uprv_strcmp(tzdataVer, TimeZoneTest::REFERENCE_DATA_VERSION) != 0) {
|
||||||
// Note: We want to display a warning message here if
|
// Note: We want to display a warning message here if
|
||||||
// REFERENCE_DATA_VERSION is out of date - so we
|
// REFERENCE_DATA_VERSION is out of date - so we
|
||||||
// do not forget to update the value before GA.
|
// do not forget to update the value before GA.
|
||||||
@ -603,11 +603,11 @@ void TimeZoneTest::TestShortZoneIDs()
|
|||||||
// Note: useDaylightTime returns true if DST is observed
|
// Note: useDaylightTime returns true if DST is observed
|
||||||
// in the time zone in the current calendar year. The test
|
// in the time zone in the current calendar year. The test
|
||||||
// data is valid for the date after the reference year below.
|
// data is valid for the date after the reference year below.
|
||||||
// If system clock is before the year, some test cases may fail.
|
// If system clock is before the year, some test cases may
|
||||||
const int32_t REFERENCE_YEAR = 2009;
|
// fail.
|
||||||
GregorianCalendar cal(*TimeZone::getGMT(), status);
|
GregorianCalendar cal(*TimeZone::getGMT(), status);
|
||||||
if (failure(status, "GregorianCalendar")) return;
|
if (failure(status, "GregorianCalendar")) return;
|
||||||
cal.set(REFERENCE_YEAR, UCAL_JANUARY, 2); // day 2 in GMT
|
cal.set(TimeZoneTest::REFERENCE_YEAR, UCAL_JANUARY, 2); // day 2 in GMT
|
||||||
|
|
||||||
UBool isDateBeforeReferenceYear = ucal_getNow() < cal.getTime(status);
|
UBool isDateBeforeReferenceYear = ucal_getNow() < cal.getTime(status);
|
||||||
if (failure(status, "Calendar::getTime")) return;
|
if (failure(status, "Calendar::getTime")) return;
|
||||||
@ -1875,9 +1875,8 @@ static struct {
|
|||||||
// Southern Hemisphere, all data from meta:Australia_Western
|
// Southern Hemisphere, all data from meta:Australia_Western
|
||||||
{"Australia/Perth", "en", FALSE, TimeZone::SHORT, "GMT+08:00"/*"AWST"*/},
|
{"Australia/Perth", "en", FALSE, TimeZone::SHORT, "GMT+08:00"/*"AWST"*/},
|
||||||
{"Australia/Perth", "en", FALSE, TimeZone::LONG, "Australian Western Standard Time"},
|
{"Australia/Perth", "en", FALSE, TimeZone::LONG, "Australian Western Standard Time"},
|
||||||
//FIXME: Temporary disable the test cases below. See #6814
|
{"Australia/Perth", "en", TRUE, TimeZone::SHORT, "GMT+09:00"/*"AWDT"*/},
|
||||||
// {"Australia/Perth", "en", TRUE, TimeZone::SHORT, "GMT+09:00"/*"AWDT"*/},
|
{"Australia/Perth", "en", TRUE, TimeZone::LONG, "Australian Western Daylight Time"},
|
||||||
// {"Australia/Perth", "en", TRUE, TimeZone::LONG, "Australian Western Daylight Time"},
|
|
||||||
|
|
||||||
{"America/Sao_Paulo", "en", FALSE, TimeZone::SHORT, "GMT-03:00"/*"BRT"*/},
|
{"America/Sao_Paulo", "en", FALSE, TimeZone::SHORT, "GMT-03:00"/*"BRT"*/},
|
||||||
{"America/Sao_Paulo", "en", FALSE, TimeZone::LONG, "Brasilia Time"},
|
{"America/Sao_Paulo", "en", FALSE, TimeZone::LONG, "Brasilia Time"},
|
||||||
@ -1899,6 +1898,15 @@ static struct {
|
|||||||
};
|
};
|
||||||
|
|
||||||
void TimeZoneTest::TestDisplayNamesMeta() {
|
void TimeZoneTest::TestDisplayNamesMeta() {
|
||||||
|
UErrorCode status = U_ZERO_ERROR;
|
||||||
|
GregorianCalendar cal(*TimeZone::getGMT(), status);
|
||||||
|
if (failure(status, "GregorianCalendar")) return;
|
||||||
|
|
||||||
|
UBool isReferenceYear = TRUE;
|
||||||
|
if (cal.get(UCAL_YEAR, status) != TimeZoneTest::REFERENCE_YEAR) {
|
||||||
|
isReferenceYear = FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
UBool sawAnError = FALSE;
|
UBool sawAnError = FALSE;
|
||||||
for (int testNum = 0; zoneDisplayTestData[testNum].zoneName != NULL; testNum++) {
|
for (int testNum = 0; zoneDisplayTestData[testNum].zoneName != NULL; testNum++) {
|
||||||
Locale locale = Locale::createFromName(zoneDisplayTestData[testNum].localeName);
|
Locale locale = Locale::createFromName(zoneDisplayTestData[testNum].localeName);
|
||||||
@ -1909,20 +1917,33 @@ void TimeZoneTest::TestDisplayNamesMeta() {
|
|||||||
locale,
|
locale,
|
||||||
displayName);
|
displayName);
|
||||||
if (displayName != zoneDisplayTestData[testNum].expectedDisplayName) {
|
if (displayName != zoneDisplayTestData[testNum].expectedDisplayName) {
|
||||||
sawAnError = TRUE;
|
|
||||||
char name[100];
|
char name[100];
|
||||||
UErrorCode status = U_ZERO_ERROR;
|
UErrorCode status = U_ZERO_ERROR;
|
||||||
displayName.extract(name, 100, NULL, status);
|
displayName.extract(name, 100, NULL, status);
|
||||||
errln("Incorrect time zone display name. zone = \"%s\",\n"
|
if (isReferenceYear) {
|
||||||
" locale = \"%s\", style = %s, Summertime = %d\n"
|
sawAnError = TRUE;
|
||||||
" Expected \"%s\", "
|
errln("Incorrect time zone display name. zone = \"%s\",\n"
|
||||||
" Got \"%s\"\n", zoneDisplayTestData[testNum].zoneName,
|
" locale = \"%s\", style = %s, Summertime = %d\n"
|
||||||
zoneDisplayTestData[testNum].localeName,
|
" Expected \"%s\", "
|
||||||
zoneDisplayTestData[testNum].style==TimeZone::SHORT ?
|
" Got \"%s\"\n", zoneDisplayTestData[testNum].zoneName,
|
||||||
"SHORT" : "LONG",
|
zoneDisplayTestData[testNum].localeName,
|
||||||
zoneDisplayTestData[testNum].summerTime,
|
zoneDisplayTestData[testNum].style==TimeZone::SHORT ?
|
||||||
zoneDisplayTestData[testNum].expectedDisplayName,
|
"SHORT" : "LONG",
|
||||||
name);
|
zoneDisplayTestData[testNum].summerTime,
|
||||||
|
zoneDisplayTestData[testNum].expectedDisplayName,
|
||||||
|
name);
|
||||||
|
} else {
|
||||||
|
logln("Incorrect time zone display name. zone = \"%s\",\n"
|
||||||
|
" locale = \"%s\", style = %s, Summertime = %d\n"
|
||||||
|
" Expected \"%s\", "
|
||||||
|
" Got \"%s\"\n", zoneDisplayTestData[testNum].zoneName,
|
||||||
|
zoneDisplayTestData[testNum].localeName,
|
||||||
|
zoneDisplayTestData[testNum].style==TimeZone::SHORT ?
|
||||||
|
"SHORT" : "LONG",
|
||||||
|
zoneDisplayTestData[testNum].summerTime,
|
||||||
|
zoneDisplayTestData[testNum].expectedDisplayName,
|
||||||
|
name);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
delete zone;
|
delete zone;
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
|
|
||||||
/********************************************************************
|
/********************************************************************
|
||||||
* Copyright (c) 1997-2008, International Business Machines
|
* Copyright (c) 1997-2009, International Business Machines
|
||||||
* Corporation and others. All Rights Reserved.
|
* Corporation and others. All Rights Reserved.
|
||||||
********************************************************************/
|
********************************************************************/
|
||||||
|
|
||||||
@ -98,6 +98,11 @@ private:
|
|||||||
// internal functions
|
// internal functions
|
||||||
static UnicodeString& formatOffset(int32_t offset, UnicodeString& rv);
|
static UnicodeString& formatOffset(int32_t offset, UnicodeString& rv);
|
||||||
static UnicodeString& formatTZID(int32_t offset, UnicodeString& rv);
|
static UnicodeString& formatTZID(int32_t offset, UnicodeString& rv);
|
||||||
|
|
||||||
|
// Some test case data is current date/tzdata version sensitive and producing errors
|
||||||
|
// when year/rule are changed.
|
||||||
|
static const int32_t REFERENCE_YEAR;
|
||||||
|
static const char *REFERENCE_DATA_VERSION;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* #if !UCONFIG_NO_FORMATTING */
|
#endif /* #if !UCONFIG_NO_FORMATTING */
|
||||||
|
Loading…
Reference in New Issue
Block a user