提交 76d193f3 编写于 作者: I igerasim

8164366: ZoneOffset.ofHoursMinutesSeconds() does not reject invalid input

Reviewed-by: scolebourne, ntv, coffeys
上级 6d693369
/* /*
* Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2012, 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
...@@ -375,15 +375,15 @@ public final class ZoneOffset ...@@ -375,15 +375,15 @@ public final class ZoneOffset
} else if ((minutes > 0 && seconds < 0) || (minutes < 0 && seconds > 0)) { } else if ((minutes > 0 && seconds < 0) || (minutes < 0 && seconds > 0)) {
throw new DateTimeException("Zone offset minutes and seconds must have the same sign"); throw new DateTimeException("Zone offset minutes and seconds must have the same sign");
} }
if (Math.abs(minutes) > 59) { if (minutes < -59 || minutes > 59) {
throw new DateTimeException("Zone offset minutes not in valid range: abs(value) " + throw new DateTimeException("Zone offset minutes not in valid range: value " +
Math.abs(minutes) + " is not in the range 0 to 59"); minutes + " is not in the range -59 to 59");
} }
if (Math.abs(seconds) > 59) { if (seconds < -59 || seconds > 59) {
throw new DateTimeException("Zone offset seconds not in valid range: abs(value) " + throw new DateTimeException("Zone offset seconds not in valid range: value " +
Math.abs(seconds) + " is not in the range 0 to 59"); seconds + " is not in the range -59 to 59");
} }
if (Math.abs(hours) == 18 && (Math.abs(minutes) > 0 || Math.abs(seconds) > 0)) { if (Math.abs(hours) == 18 && (minutes | seconds) != 0) {
throw new DateTimeException("Zone offset not in valid range: -18:00 to +18:00"); throw new DateTimeException("Zone offset not in valid range: -18:00 to +18:00");
} }
} }
...@@ -411,7 +411,7 @@ public final class ZoneOffset ...@@ -411,7 +411,7 @@ public final class ZoneOffset
* @throws DateTimeException if the offset is not in the required range * @throws DateTimeException if the offset is not in the required range
*/ */
public static ZoneOffset ofTotalSeconds(int totalSeconds) { public static ZoneOffset ofTotalSeconds(int totalSeconds) {
if (Math.abs(totalSeconds) > MAX_SECONDS) { if (totalSeconds < -MAX_SECONDS || totalSeconds > MAX_SECONDS) {
throw new DateTimeException("Zone offset not in valid range: -18:00 to +18:00"); throw new DateTimeException("Zone offset not in valid range: -18:00 to +18:00");
} }
if (totalSeconds % (15 * SECONDS_PER_MINUTE) == 0) { if (totalSeconds % (15 * SECONDS_PER_MINUTE) == 0) {
...@@ -696,11 +696,12 @@ public final class ZoneOffset ...@@ -696,11 +696,12 @@ public final class ZoneOffset
* The comparison is "consistent with equals", as defined by {@link Comparable}. * The comparison is "consistent with equals", as defined by {@link Comparable}.
* *
* @param other the other date to compare to, not null * @param other the other date to compare to, not null
* @return the comparator value, negative if less, postive if greater * @return the comparator value, negative if less, positive if greater
* @throws NullPointerException if {@code other} is null * @throws NullPointerException if {@code other} is null
*/ */
@Override @Override
public int compareTo(ZoneOffset other) { public int compareTo(ZoneOffset other) {
// abs(totalSeconds) <= MAX_SECONDS, so no overflow can happen here
return other.totalSeconds - totalSeconds; return other.totalSeconds - totalSeconds;
} }
......
/* /*
* Copyright (c) 2012, 2013, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2012, 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
...@@ -419,6 +419,21 @@ public class TCKZoneOffset extends AbstractDateTimeTest { ...@@ -419,6 +419,21 @@ public class TCKZoneOffset extends AbstractDateTimeTest {
ZoneOffset.ofHoursMinutesSeconds(-19, 0, 0); ZoneOffset.ofHoursMinutesSeconds(-19, 0, 0);
} }
@Test(expectedExceptions=DateTimeException.class)
public void test_factory_int_hours_minutes_seconds_minutesMinValue() {
ZoneOffset.ofHoursMinutesSeconds(0, Integer.MIN_VALUE, -1);
}
@Test(expectedExceptions=DateTimeException.class)
public void test_factory_int_hours_minutes_seconds_secondsMinValue() {
ZoneOffset.ofHoursMinutesSeconds(0, 0, Integer.MIN_VALUE);
}
@Test(expectedExceptions=DateTimeException.class)
public void test_factory_int_hours_minutes_seconds_minutesAndSecondsMinValue() {
ZoneOffset.ofHoursMinutesSeconds(0, Integer.MIN_VALUE, Integer.MIN_VALUE);
}
//----------------------------------------------------------------------- //-----------------------------------------------------------------------
@Test @Test
public void test_factory_ofTotalSeconds() { public void test_factory_ofTotalSeconds() {
...@@ -437,6 +452,11 @@ public class TCKZoneOffset extends AbstractDateTimeTest { ...@@ -437,6 +452,11 @@ public class TCKZoneOffset extends AbstractDateTimeTest {
ZoneOffset.ofTotalSeconds(-18 * 60 * 60 - 1); ZoneOffset.ofTotalSeconds(-18 * 60 * 60 - 1);
} }
@Test(expectedExceptions=DateTimeException.class)
public void test_factory_ofTotalSeconds_minValue() {
ZoneOffset.ofTotalSeconds(Integer.MIN_VALUE);
}
//----------------------------------------------------------------------- //-----------------------------------------------------------------------
// from() // from()
//----------------------------------------------------------------------- //-----------------------------------------------------------------------
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册