2016-05-27 14:33:48 +09:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2003, 2016, Oracle and/or its affiliates. All rights reserved.
|
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
|
|
*
|
|
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
|
|
* accompanied this code).
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License version
|
|
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*
|
|
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
|
|
* questions.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @test
|
|
|
|
* @bug 4958050
|
|
|
|
* @summary Make sure that add() and roll() handle time zone offset changes (both raw and DST) correctly.
|
|
|
|
*/
|
|
|
|
|
|
|
|
import java.util.Locale;
|
|
|
|
import java.util.TimeZone;
|
2016-11-17 11:40:50 +05:30
|
|
|
|
2016-05-27 14:33:48 +09:00
|
|
|
import static java.util.Calendar.*;
|
|
|
|
|
|
|
|
public class Bug4958050 {
|
2016-11-17 11:40:50 +05:30
|
|
|
|
2016-05-27 14:33:48 +09:00
|
|
|
static int errorCount = 0;
|
|
|
|
|
|
|
|
public static void main(String[] args) {
|
|
|
|
// All the test cases depend on historical GMT offset changes
|
|
|
|
// of Asia/Novosibirsk.
|
|
|
|
Koyomi cal = new Koyomi(TimeZone.getTimeZone("Asia/Novosibirsk"), Locale.US);
|
|
|
|
System.out.println("Time zone = " + cal.getTimeZone().getID());
|
|
|
|
|
|
|
|
// Test the week fields
|
2016-11-17 11:40:50 +05:30
|
|
|
int[] weekFields = {WEEK_OF_YEAR, WEEK_OF_MONTH, DAY_OF_WEEK_IN_MONTH};
|
2016-05-27 14:33:48 +09:00
|
|
|
for (int i = 0; i < weekFields.length; i++) {
|
|
|
|
int field = weekFields[i];
|
|
|
|
// add()
|
|
|
|
cal.clear();
|
2016-11-17 11:40:50 +05:30
|
|
|
cal.set(1919, DECEMBER, 14 - 7, 23, 50, 00);
|
2016-05-27 14:33:48 +09:00
|
|
|
cal.add(weekFields[i], +1);
|
|
|
|
if (!cal.checkDate(1919, DECEMBER, 14)) {
|
2016-11-17 11:40:50 +05:30
|
|
|
error("1919/12/07: add(" + Koyomi.getFieldName(weekFields[i]) + ", +1)\n"
|
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
cal.clear();
|
2016-11-17 11:40:50 +05:30
|
|
|
cal.set(1930, JUNE, 21 - 7);
|
2016-05-27 14:33:48 +09:00
|
|
|
cal.add(weekFields[i], +1);
|
|
|
|
if (!cal.checkDateTime(1930, JUNE, 21, 01, 00, 00, 000)) {
|
2016-11-17 11:40:50 +05:30
|
|
|
error("1930/6/14: add(" + Koyomi.getFieldName(weekFields[i]) + ", +1)\n"
|
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
// roll()
|
|
|
|
cal.clear();
|
2016-11-17 11:40:50 +05:30
|
|
|
cal.set(1919, DECEMBER, 14 - 7, 23, 50, 00);
|
2016-05-27 14:33:48 +09:00
|
|
|
cal.roll(weekFields[i], +1);
|
|
|
|
if (!cal.checkDate(1919, DECEMBER, 14)) {
|
2016-11-17 11:40:50 +05:30
|
|
|
error("1919/12/07: roll(" + Koyomi.getFieldName(weekFields[i]) + ", +1)\n"
|
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
cal.clear();
|
2016-11-17 11:40:50 +05:30
|
|
|
cal.set(1930, JUNE, 21 - 7);
|
2016-05-27 14:33:48 +09:00
|
|
|
cal.roll(weekFields[i], +1);
|
|
|
|
if (!cal.checkDateTime(1930, JUNE, 21, 01, 00, 00, 000)) {
|
2016-11-17 11:40:50 +05:30
|
|
|
error("1930/6/14: roll(" + Koyomi.getFieldName(weekFields[i]) + ", +1)\n"
|
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Test the day fields
|
2016-11-17 11:40:50 +05:30
|
|
|
int[] dayFields = {DAY_OF_MONTH, DAY_OF_YEAR, DAY_OF_WEEK};
|
2016-05-27 14:33:48 +09:00
|
|
|
for (int i = 0; i < dayFields.length; i++) {
|
|
|
|
int field = dayFields[i];
|
|
|
|
// add()
|
|
|
|
cal.clear();
|
2016-11-17 11:40:50 +05:30
|
|
|
cal.set(1919, DECEMBER, 14 - 1, 23, 50, 00);
|
2016-05-27 14:33:48 +09:00
|
|
|
cal.add(field, +1);
|
|
|
|
if (!cal.checkDate(1919, DECEMBER, 14)) {
|
2016-11-17 11:40:50 +05:30
|
|
|
error("1919/12/13: add(" + Koyomi.getFieldName(field) + ", +1)\n"
|
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
cal.clear();
|
|
|
|
cal.set(1919, DECEMBER, 14, 00, 00, 00);
|
|
|
|
cal.add(field, -1);
|
|
|
|
if (!cal.checkDate(1919, DECEMBER, 13)) {
|
2016-11-17 11:40:50 +05:30
|
|
|
error("1919/12/14: add(" + Koyomi.getFieldName(field) + ", -1)\n"
|
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
cal.clear();
|
2016-11-17 11:40:50 +05:30
|
|
|
cal.set(1930, JUNE, 21 - 1);
|
2016-05-27 14:33:48 +09:00
|
|
|
cal.add(field, +1);
|
|
|
|
if (!cal.checkDateTime(1930, JUNE, 21, 01, 00, 00, 000)) {
|
2016-11-17 11:40:50 +05:30
|
|
|
error("1930/6/20: add(" + Koyomi.getFieldName(field) + ", +1)\n"
|
|
|
|
+ cal.getMessage() + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
cal.clear();
|
|
|
|
cal.set(1930, JUNE, 21, 01, 00, 00);
|
|
|
|
cal.add(field, -1);
|
|
|
|
if (!cal.checkDateTime(1930, JUNE, 20, 01, 00, 00, 000)) {
|
2016-11-17 11:40:50 +05:30
|
|
|
error("1930/6/21: add(" + Koyomi.getFieldName(field) + ", -1)\n"
|
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
// roll()
|
|
|
|
cal.clear();
|
2016-11-17 11:40:50 +05:30
|
|
|
cal.set(1930, JUNE, 21 - 1);
|
2016-05-27 14:33:48 +09:00
|
|
|
int amount = +1;
|
|
|
|
if (field == DAY_OF_WEEK) {
|
|
|
|
amount += 700;
|
|
|
|
}
|
|
|
|
cal.roll(field, amount);
|
|
|
|
if (!cal.checkDateTime(1930, JUNE, 21, 01, 00, 00, 000)) {
|
2016-11-17 11:40:50 +05:30
|
|
|
error("1930/6/20: roll(" + Koyomi.getFieldName(field) + ", +" + amount + ")\n"
|
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
cal.clear();
|
|
|
|
cal.set(1930, JUNE, 21, 01, 00, 00);
|
|
|
|
amount = -1;
|
|
|
|
if (field == DAY_OF_WEEK) {
|
|
|
|
amount -= 700;
|
|
|
|
}
|
|
|
|
cal.roll(field, amount);
|
|
|
|
if (!cal.checkDateTime(1930, JUNE, 20, 01, 00, 00, 000)) {
|
2016-11-17 11:40:50 +05:30
|
|
|
error("1930/6/21: roll(" + Koyomi.getFieldName(field) + ", " + amount + ")\n"
|
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Test the AM_PM field
|
|
|
|
// add()
|
|
|
|
cal.clear();
|
2016-11-17 11:40:50 +05:30
|
|
|
cal.set(1919, DECEMBER, 14 - 1, 23, 50, 00);
|
2016-05-27 14:33:48 +09:00
|
|
|
cal.add(AM_PM, +1);
|
|
|
|
if (!cal.checkDate(1919, DECEMBER, 14)
|
2016-11-17 11:40:50 +05:30
|
|
|
|| !cal.checkFieldValue(AM_PM, AM)) {
|
2016-05-27 14:33:48 +09:00
|
|
|
error("1919/12/13: add(AM_PM, +1)\n"
|
2016-11-17 11:40:50 +05:30
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
cal.clear();
|
2016-11-17 11:40:50 +05:30
|
|
|
cal.set(1930, JUNE, 21 - 1, 12, 00, 00);
|
2016-05-27 14:33:48 +09:00
|
|
|
cal.add(AM_PM, +1);
|
|
|
|
if (!cal.checkDate(1930, JUNE, 21)
|
2016-11-17 11:40:50 +05:30
|
|
|
|| !cal.checkFieldValue(AM_PM, AM)) {
|
2016-05-27 14:33:48 +09:00
|
|
|
error("1930/6/20: add(AM_PM, +1)\n"
|
2016-11-17 11:40:50 +05:30
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
cal.clear();
|
2016-11-17 11:40:50 +05:30
|
|
|
cal.set(1930, JUNE, 21 - 2, 12, 00, 00);
|
2016-05-27 14:33:48 +09:00
|
|
|
cal.add(AM_PM, +3);
|
|
|
|
if (!cal.checkDate(1930, JUNE, 21)
|
2016-11-17 11:40:50 +05:30
|
|
|
|| !cal.checkFieldValue(AM_PM, AM)) {
|
2016-05-27 14:33:48 +09:00
|
|
|
error("1930/6/10: add(AM_PM, +3)\n"
|
2016-11-17 11:40:50 +05:30
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
cal.clear();
|
|
|
|
cal.set(1919, DECEMBER, 14, 11, 50, 00);
|
|
|
|
cal.add(AM_PM, -1);
|
2016-11-17 11:40:50 +05:30
|
|
|
if (!cal.checkDateTime(1919, DECEMBER, 14 - 1, 23, 50, 00, 000)
|
|
|
|
|| !cal.checkFieldValue(AM_PM, PM)) {
|
2016-05-27 14:33:48 +09:00
|
|
|
error("1919/12/14 11:50:00: add(AM_PM, -1)\n"
|
2016-11-17 11:40:50 +05:30
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
cal.clear();
|
|
|
|
cal.set(1930, JUNE, 21, 01, 00, 00);
|
|
|
|
cal.add(AM_PM, -1);
|
2016-11-17 11:40:50 +05:30
|
|
|
if (!cal.checkDateTime(1930, JUNE, 21 - 1, 01 + 12, 00, 00, 000)
|
|
|
|
|| !cal.checkFieldValue(AM_PM, PM)) {
|
2016-05-27 14:33:48 +09:00
|
|
|
error("1930/6/20: add(AM_PM, -1)\n"
|
2016-11-17 11:40:50 +05:30
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
cal.clear();
|
|
|
|
cal.set(1930, JUNE, 21, 01, 00, 00);
|
|
|
|
cal.add(AM_PM, -3);
|
2016-11-17 11:40:50 +05:30
|
|
|
if (!cal.checkDateTime(1930, JUNE, 21 - 2, 01 + 12, 00, 00, 000)
|
|
|
|
|| !cal.checkFieldValue(AM_PM, PM)) {
|
2016-05-27 14:33:48 +09:00
|
|
|
error("1930/6/10: add(AM_PM, -3)\n"
|
2016-11-17 11:40:50 +05:30
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
// roll() (should NOT change the date)
|
|
|
|
cal.clear();
|
2016-11-17 11:40:50 +05:30
|
|
|
cal.set(1919, DECEMBER, 14 - 1, 23, 50, 00);
|
2016-05-27 14:33:48 +09:00
|
|
|
cal.roll(AM_PM, +1);
|
2016-11-17 11:40:50 +05:30
|
|
|
if (!cal.checkDateTime(1919, DECEMBER, 14 - 1, 23 - 12, 50, 00, 000)
|
|
|
|
|| !cal.checkFieldValue(AM_PM, AM)) {
|
2016-05-27 14:33:48 +09:00
|
|
|
error("1919/12/13: roll(AM_PM, +1)\n"
|
2016-11-17 11:40:50 +05:30
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
cal.clear();
|
2016-11-17 11:40:50 +05:30
|
|
|
cal.set(1930, JUNE, 21 - 1, 12, 00, 00);
|
2016-05-27 14:33:48 +09:00
|
|
|
cal.roll(AM_PM, +1);
|
2016-11-17 11:40:50 +05:30
|
|
|
if (!cal.checkDateTime(1930, JUNE, 21 - 1, 12 - 12, 00, 00, 000)
|
|
|
|
|| !cal.checkFieldValue(AM_PM, AM)) {
|
2016-05-27 14:33:48 +09:00
|
|
|
error("1930/6/20: roll(AM_PM, +1)\n"
|
2016-11-17 11:40:50 +05:30
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
cal.clear();
|
2016-11-17 11:40:50 +05:30
|
|
|
cal.set(1930, JUNE, 21 - 2, 12, 00, 00);
|
2016-05-27 14:33:48 +09:00
|
|
|
cal.roll(AM_PM, +3);
|
2016-11-17 11:40:50 +05:30
|
|
|
if (!cal.checkDateTime(1930, JUNE, 21 - 2, 12 - 12, 00, 00, 000)
|
|
|
|
|| !cal.checkFieldValue(AM_PM, AM)) {
|
2016-05-27 14:33:48 +09:00
|
|
|
error("1930/6/10: roll(AM_PM, +3)\n"
|
2016-11-17 11:40:50 +05:30
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
// Test the HOUR_OF_DAY field
|
|
|
|
// add()
|
|
|
|
cal.clear();
|
|
|
|
cal.set(1930, JUNE, 20, 23, 00, 00);
|
|
|
|
cal.add(HOUR_OF_DAY, +1);
|
|
|
|
if (!cal.checkDateTime(1930, JUNE, 21, 01, 00, 00, 000)) {
|
|
|
|
error("1930/6/20 23:00:00: add(HOUR_OF_DAY, +1)\n"
|
2016-11-17 11:40:50 +05:30
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
// roll() (should NOT change the date)
|
|
|
|
cal.clear();
|
|
|
|
cal.set(1930, JUNE, 20, 23, 00, 00);
|
|
|
|
cal.roll(HOUR_OF_DAY, +1);
|
|
|
|
if (!cal.checkDateTime(1930, JUNE, 20, 00, 00, 00, 000)) {
|
|
|
|
error("1930/6/20 23:00:00: roll(HOUR_OF_DAY, +1)\n"
|
2016-11-17 11:40:50 +05:30
|
|
|
+ cal.getMessage() + " " + cal.toDateTimeString());
|
2016-05-27 14:33:48 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
checkErrors();
|
|
|
|
}
|
|
|
|
|
|
|
|
static void error(String s) {
|
|
|
|
System.out.println(s);
|
|
|
|
errorCount++;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void checkErrors() {
|
|
|
|
if (errorCount > 0) {
|
|
|
|
throw new RuntimeException("Failed: " + errorCount + " error(s)");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|