NumberUtils reports overflow when converting from BigInteger/BigDecimal to Long
Issue: SPR-11434
This commit is contained in:
parent
01b2f67f11
commit
4744180d3d
|
@ -1,5 +1,5 @@
|
|||
/*
|
||||
* Copyright 2002-2012 the original author or authors.
|
||||
* Copyright 2002-2014 the original author or authors.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
|
@ -33,6 +33,11 @@ import java.text.ParseException;
|
|||
*/
|
||||
public abstract class NumberUtils {
|
||||
|
||||
private static final BigInteger LONG_MIN = BigInteger.valueOf(Long.MIN_VALUE);
|
||||
|
||||
private static final BigInteger LONG_MAX = BigInteger.valueOf(Long.MAX_VALUE);
|
||||
|
||||
|
||||
/**
|
||||
* Convert the given number into an instance of the given target class.
|
||||
* @param number the number to convert
|
||||
|
@ -81,6 +86,17 @@ public abstract class NumberUtils {
|
|||
return (T) new Integer(number.intValue());
|
||||
}
|
||||
else if (targetClass.equals(Long.class)) {
|
||||
BigInteger bigInt = null;
|
||||
if (number instanceof BigInteger) {
|
||||
bigInt = (BigInteger) number;
|
||||
}
|
||||
else if (number instanceof BigDecimal) {
|
||||
bigInt = ((BigDecimal) number).toBigInteger();
|
||||
}
|
||||
// Effectively analogous to JDK 8's BigInteger.longValueExact()
|
||||
if (bigInt != null && (bigInt.compareTo(LONG_MIN) < 0 || bigInt.compareTo(LONG_MAX) > 0)) {
|
||||
raiseOverflowException(number, targetClass);
|
||||
}
|
||||
return (T) new Long(number.longValue());
|
||||
}
|
||||
else if (targetClass.equals(BigInteger.class)) {
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
/*
|
||||
* Copyright 2002-2008 the original author or authors.
|
||||
* Copyright 2002-2014 the original author or authors.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
|
@ -21,16 +21,17 @@ import java.math.BigInteger;
|
|||
import java.text.NumberFormat;
|
||||
import java.util.Locale;
|
||||
|
||||
import junit.framework.TestCase;
|
||||
import org.junit.Test;
|
||||
|
||||
import org.springframework.core.JdkVersion;
|
||||
import static org.junit.Assert.*;
|
||||
|
||||
/**
|
||||
* @author Rob Harrop
|
||||
* @author Juergen Hoeller
|
||||
*/
|
||||
public class NumberUtilsTests extends TestCase {
|
||||
public class NumberUtilsTests {
|
||||
|
||||
@Test
|
||||
public void testParseNumber() {
|
||||
String aByte = "" + Byte.MAX_VALUE;
|
||||
String aShort = "" + Short.MAX_VALUE;
|
||||
|
@ -47,6 +48,7 @@ public class NumberUtilsTests extends TestCase {
|
|||
assertEquals("Double did not parse", new Double(Double.MAX_VALUE), NumberUtils.parseNumber(aDouble, Double.class));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testParseNumberUsingNumberFormat() {
|
||||
NumberFormat nf = NumberFormat.getNumberInstance(Locale.US);
|
||||
String aByte = "" + Byte.MAX_VALUE;
|
||||
|
@ -64,6 +66,7 @@ public class NumberUtilsTests extends TestCase {
|
|||
assertEquals("Double did not parse", new Double(Double.MAX_VALUE), NumberUtils.parseNumber(aDouble, Double.class, nf));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testParseWithTrim() {
|
||||
String aByte = " " + Byte.MAX_VALUE + " ";
|
||||
String aShort = " " + Short.MAX_VALUE + " ";
|
||||
|
@ -80,6 +83,7 @@ public class NumberUtilsTests extends TestCase {
|
|||
assertEquals("Double did not parse", new Double(Double.MAX_VALUE), NumberUtils.parseNumber(aDouble, Double.class));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testParseWithTrimUsingNumberFormat() {
|
||||
NumberFormat nf = NumberFormat.getNumberInstance(Locale.US);
|
||||
String aByte = " " + Byte.MAX_VALUE + " ";
|
||||
|
@ -97,6 +101,7 @@ public class NumberUtilsTests extends TestCase {
|
|||
assertEquals("Double did not parse", new Double(Double.MAX_VALUE), NumberUtils.parseNumber(aDouble, Double.class, nf));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testParseAsHex() {
|
||||
String aByte = "0x" + Integer.toHexString(new Byte(Byte.MAX_VALUE).intValue());
|
||||
String aShort = "0x" + Integer.toHexString(new Short(Short.MAX_VALUE).intValue());
|
||||
|
@ -112,6 +117,7 @@ public class NumberUtilsTests extends TestCase {
|
|||
new BigInteger(aReallyBigInt, 16), NumberUtils.parseNumber("0x" + aReallyBigInt, BigInteger.class));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testParseNegativeHex() {
|
||||
String aByte = "-0x80";
|
||||
String aShort = "-0x8000";
|
||||
|
@ -127,70 +133,71 @@ public class NumberUtilsTests extends TestCase {
|
|||
new BigInteger(aReallyBigInt, 16).negate(), NumberUtils.parseNumber("-0x" + aReallyBigInt, BigInteger.class));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testDoubleToBigInteger() {
|
||||
Double decimal = new Double(3.14d);
|
||||
assertEquals(new BigInteger("3"), NumberUtils.convertNumberToTargetClass(decimal, BigInteger.class));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testBigDecimalToBigInteger() {
|
||||
String number = "987459837583750387355346";
|
||||
BigDecimal decimal = new BigDecimal(number);
|
||||
assertEquals(new BigInteger(number), NumberUtils.convertNumberToTargetClass(decimal, BigInteger.class));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testNonExactBigDecimalToBigInteger() {
|
||||
BigDecimal decimal = new BigDecimal("987459837583750387355346.14");
|
||||
assertEquals(new BigInteger("987459837583750387355346"), NumberUtils.convertNumberToTargetClass(decimal, BigInteger.class));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testParseBigDecimalNumber1() {
|
||||
String bigDecimalAsString = "0.10";
|
||||
Number bigDecimal = NumberUtils.parseNumber(bigDecimalAsString, BigDecimal.class);
|
||||
assertEquals(new BigDecimal(bigDecimalAsString), bigDecimal);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testParseBigDecimalNumber2() {
|
||||
String bigDecimalAsString = "0.001";
|
||||
Number bigDecimal = NumberUtils.parseNumber(bigDecimalAsString, BigDecimal.class);
|
||||
assertEquals(new BigDecimal(bigDecimalAsString), bigDecimal);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testParseBigDecimalNumber3() {
|
||||
String bigDecimalAsString = "3.14159265358979323846";
|
||||
Number bigDecimal = NumberUtils.parseNumber(bigDecimalAsString, BigDecimal.class);
|
||||
assertEquals(new BigDecimal(bigDecimalAsString), bigDecimal);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testParseLocalizedBigDecimalNumber1() {
|
||||
if (JdkVersion.getMajorJavaVersion() < JdkVersion.JAVA_15) {
|
||||
return;
|
||||
}
|
||||
String bigDecimalAsString = "0.10";
|
||||
NumberFormat numberFormat = NumberFormat.getInstance(Locale.ENGLISH);
|
||||
Number bigDecimal = NumberUtils.parseNumber(bigDecimalAsString, BigDecimal.class, numberFormat);
|
||||
assertEquals(new BigDecimal(bigDecimalAsString), bigDecimal);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testParseLocalizedBigDecimalNumber2() {
|
||||
if (JdkVersion.getMajorJavaVersion() < JdkVersion.JAVA_15) {
|
||||
return;
|
||||
}
|
||||
String bigDecimalAsString = "0.001";
|
||||
NumberFormat numberFormat = NumberFormat.getInstance(Locale.ENGLISH);
|
||||
Number bigDecimal = NumberUtils.parseNumber(bigDecimalAsString, BigDecimal.class, numberFormat);
|
||||
assertEquals(new BigDecimal(bigDecimalAsString), bigDecimal);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testParseLocalizedBigDecimalNumber3() {
|
||||
if (JdkVersion.getMajorJavaVersion() < JdkVersion.JAVA_15) {
|
||||
return;
|
||||
}
|
||||
String bigDecimalAsString = "3.14159265358979323846";
|
||||
NumberFormat numberFormat = NumberFormat.getInstance(Locale.ENGLISH);
|
||||
Number bigDecimal = NumberUtils.parseNumber(bigDecimalAsString, BigDecimal.class, numberFormat);
|
||||
assertEquals(new BigDecimal(bigDecimalAsString), bigDecimal);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testParseOverflow() {
|
||||
String aLong = "" + Long.MAX_VALUE;
|
||||
String aDouble = "" + Double.MAX_VALUE;
|
||||
|
@ -217,10 +224,10 @@ public class NumberUtilsTests extends TestCase {
|
|||
}
|
||||
|
||||
assertEquals(new Long(Long.MAX_VALUE), NumberUtils.parseNumber(aLong, Long.class));
|
||||
|
||||
assertEquals(new Double(Double.MAX_VALUE), NumberUtils.parseNumber(aDouble, Double.class));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testParseNegativeOverflow() {
|
||||
String aLong = "" + Long.MIN_VALUE;
|
||||
String aDouble = "" + Double.MIN_VALUE;
|
||||
|
@ -247,10 +254,10 @@ public class NumberUtilsTests extends TestCase {
|
|||
}
|
||||
|
||||
assertEquals(new Long(Long.MIN_VALUE), NumberUtils.parseNumber(aLong, Long.class));
|
||||
|
||||
assertEquals(new Double(Double.MIN_VALUE), NumberUtils.parseNumber(aDouble, Double.class));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testParseOverflowUsingNumberFormat() {
|
||||
NumberFormat nf = NumberFormat.getNumberInstance(Locale.US);
|
||||
String aLong = "" + Long.MAX_VALUE;
|
||||
|
@ -278,10 +285,10 @@ public class NumberUtilsTests extends TestCase {
|
|||
}
|
||||
|
||||
assertEquals(new Long(Long.MAX_VALUE), NumberUtils.parseNumber(aLong, Long.class, nf));
|
||||
|
||||
assertEquals(new Double(Double.MAX_VALUE), NumberUtils.parseNumber(aDouble, Double.class, nf));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testParseNegativeOverflowUsingNumberFormat() {
|
||||
NumberFormat nf = NumberFormat.getNumberInstance(Locale.US);
|
||||
String aLong = "" + Long.MIN_VALUE;
|
||||
|
@ -309,10 +316,103 @@ public class NumberUtilsTests extends TestCase {
|
|||
}
|
||||
|
||||
assertEquals(new Long(Long.MIN_VALUE), NumberUtils.parseNumber(aLong, Long.class, nf));
|
||||
|
||||
assertEquals(new Double(Double.MIN_VALUE), NumberUtils.parseNumber(aDouble, Double.class, nf));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testToNumberInteger() {
|
||||
assertEquals(Integer.valueOf(Integer.valueOf(-1)), NumberUtils.convertNumberToTargetClass(BigInteger.valueOf(-1), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.valueOf(0)), NumberUtils.convertNumberToTargetClass(BigInteger.valueOf(0), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.valueOf(1)), NumberUtils.convertNumberToTargetClass(BigInteger.valueOf(1), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.MAX_VALUE), NumberUtils.convertNumberToTargetClass(BigInteger.valueOf(Integer.MAX_VALUE), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.MIN_VALUE), NumberUtils.convertNumberToTargetClass(BigInteger.valueOf(Integer.MAX_VALUE + 1), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.MIN_VALUE), NumberUtils.convertNumberToTargetClass(BigInteger.valueOf(Integer.MIN_VALUE), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.MAX_VALUE), NumberUtils.convertNumberToTargetClass(BigInteger.valueOf(Integer.MIN_VALUE - 1), Integer.class));
|
||||
assertToNumberOverflow(BigInteger.valueOf(Integer.MAX_VALUE).add(BigInteger.ONE), Integer.class);
|
||||
assertToNumberOverflow(BigInteger.valueOf(Integer.MIN_VALUE).subtract(BigInteger.ONE), Integer.class);
|
||||
|
||||
assertEquals(Integer.valueOf(Integer.valueOf(-1)), NumberUtils.convertNumberToTargetClass(Long.valueOf(-1), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.valueOf(0)), NumberUtils.convertNumberToTargetClass(Long.valueOf(0), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.valueOf(1)), NumberUtils.convertNumberToTargetClass(Long.valueOf(1), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.MAX_VALUE), NumberUtils.convertNumberToTargetClass(Long.valueOf(Integer.MAX_VALUE), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.MIN_VALUE), NumberUtils.convertNumberToTargetClass(Long.valueOf(Integer.MAX_VALUE + 1), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.MIN_VALUE), NumberUtils.convertNumberToTargetClass(Long.valueOf(Integer.MIN_VALUE), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.MAX_VALUE), NumberUtils.convertNumberToTargetClass(Long.valueOf(Integer.MIN_VALUE - 1), Integer.class));
|
||||
assertToNumberOverflow(Long.valueOf(Long.MAX_VALUE + 1), Integer.class);
|
||||
assertToNumberOverflow(Long.valueOf(Long.MIN_VALUE - 1), Integer.class);
|
||||
|
||||
assertEquals(Integer.valueOf(Integer.valueOf(-1)), NumberUtils.convertNumberToTargetClass(Integer.valueOf(-1), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.valueOf(0)), NumberUtils.convertNumberToTargetClass(Integer.valueOf(0), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.valueOf(1)), NumberUtils.convertNumberToTargetClass(Integer.valueOf(1), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.MAX_VALUE), NumberUtils.convertNumberToTargetClass(Integer.valueOf(Integer.MAX_VALUE), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.MIN_VALUE), NumberUtils.convertNumberToTargetClass(Integer.valueOf(Integer.MAX_VALUE + 1), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.MIN_VALUE), NumberUtils.convertNumberToTargetClass(Integer.valueOf(Integer.MIN_VALUE), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.MAX_VALUE), NumberUtils.convertNumberToTargetClass(Integer.valueOf(Integer.MIN_VALUE - 1), Integer.class));
|
||||
|
||||
assertEquals(Integer.valueOf(Integer.valueOf(-1)), NumberUtils.convertNumberToTargetClass(Short.valueOf((short) -1), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.valueOf(0)), NumberUtils.convertNumberToTargetClass(Short.valueOf((short) 0), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.valueOf(1)), NumberUtils.convertNumberToTargetClass(Short.valueOf((short) 1), Integer.class));
|
||||
assertEquals(Integer.valueOf(Short.MAX_VALUE), NumberUtils.convertNumberToTargetClass(Short.valueOf(Short.MAX_VALUE), Integer.class));
|
||||
assertEquals(Integer.valueOf(Short.MIN_VALUE), NumberUtils.convertNumberToTargetClass(Short.valueOf((short) (Short.MAX_VALUE + 1)), Integer.class));
|
||||
assertEquals(Integer.valueOf(Short.MIN_VALUE), NumberUtils.convertNumberToTargetClass(Short.valueOf(Short.MIN_VALUE), Integer.class));
|
||||
assertEquals(Integer.valueOf(Short.MAX_VALUE), NumberUtils.convertNumberToTargetClass(Short.valueOf((short) (Short.MIN_VALUE - 1)), Integer.class));
|
||||
|
||||
assertEquals(Integer.valueOf(Integer.valueOf(-1)), NumberUtils.convertNumberToTargetClass(Byte.valueOf((byte) -1), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.valueOf(0)), NumberUtils.convertNumberToTargetClass(Byte.valueOf((byte) 0), Integer.class));
|
||||
assertEquals(Integer.valueOf(Integer.valueOf(1)), NumberUtils.convertNumberToTargetClass(Byte.valueOf((byte) 1), Integer.class));
|
||||
assertEquals(Integer.valueOf(Byte.MAX_VALUE), NumberUtils.convertNumberToTargetClass(Byte.valueOf(Byte.MAX_VALUE), Integer.class));
|
||||
assertEquals(Integer.valueOf(Byte.MIN_VALUE), NumberUtils.convertNumberToTargetClass(Byte.valueOf((byte) (Byte.MAX_VALUE + 1)), Integer.class));
|
||||
assertEquals(Integer.valueOf(Byte.MIN_VALUE), NumberUtils.convertNumberToTargetClass(Byte.valueOf(Byte.MIN_VALUE), Integer.class));
|
||||
assertEquals(Integer.valueOf(Byte.MAX_VALUE), NumberUtils.convertNumberToTargetClass(Byte.valueOf((byte) (Byte.MIN_VALUE - 1)), Integer.class));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testToNumberLong() {
|
||||
assertEquals(Long.valueOf(Long.valueOf(-1)), NumberUtils.convertNumberToTargetClass(BigInteger.valueOf(-1), Long.class));
|
||||
assertEquals(Long.valueOf(Long.valueOf(0)), NumberUtils.convertNumberToTargetClass(BigInteger.valueOf(0), Long.class));
|
||||
assertEquals(Long.valueOf(Long.valueOf(1)), NumberUtils.convertNumberToTargetClass(BigInteger.valueOf(1), Long.class));
|
||||
assertEquals(Long.valueOf(Long.MAX_VALUE), NumberUtils.convertNumberToTargetClass(BigInteger.valueOf(Long.MAX_VALUE), Long.class));
|
||||
assertEquals(Long.valueOf(Long.MIN_VALUE), NumberUtils.convertNumberToTargetClass(BigInteger.valueOf(Long.MAX_VALUE + 1), Long.class));
|
||||
assertEquals(Long.valueOf(Long.MIN_VALUE), NumberUtils.convertNumberToTargetClass(BigInteger.valueOf(Long.MIN_VALUE), Long.class));
|
||||
assertEquals(Long.valueOf(Long.MAX_VALUE), NumberUtils.convertNumberToTargetClass(BigInteger.valueOf(Long.MIN_VALUE - 1), Long.class));
|
||||
|
||||
assertToNumberOverflow(BigInteger.valueOf(Long.MAX_VALUE).add(BigInteger.ONE), Long.class);
|
||||
assertToNumberOverflow(BigInteger.valueOf(Long.MIN_VALUE).subtract(BigInteger.ONE), Long.class);
|
||||
|
||||
assertEquals(Long.valueOf(Long.valueOf(-1)), NumberUtils.convertNumberToTargetClass(Long.valueOf(-1), Long.class));
|
||||
assertEquals(Long.valueOf(Long.valueOf(0)), NumberUtils.convertNumberToTargetClass(Long.valueOf(0), Long.class));
|
||||
assertEquals(Long.valueOf(Long.valueOf(1)), NumberUtils.convertNumberToTargetClass(Long.valueOf(1), Long.class));
|
||||
assertEquals(Long.valueOf(Long.MAX_VALUE), NumberUtils.convertNumberToTargetClass(Long.valueOf(Long.MAX_VALUE), Long.class));
|
||||
assertEquals(Long.valueOf(Long.MIN_VALUE), NumberUtils.convertNumberToTargetClass(Long.valueOf(Long.MAX_VALUE + 1), Long.class));
|
||||
assertEquals(Long.valueOf(Long.MIN_VALUE), NumberUtils.convertNumberToTargetClass(Long.valueOf(Long.MIN_VALUE), Long.class));
|
||||
assertEquals(Long.valueOf(Long.MAX_VALUE), NumberUtils.convertNumberToTargetClass(Long.valueOf(Long.MIN_VALUE - 1), Long.class));
|
||||
|
||||
assertEquals(Long.valueOf(Integer.valueOf(-1)), NumberUtils.convertNumberToTargetClass(Integer.valueOf(-1), Long.class));
|
||||
assertEquals(Long.valueOf(Integer.valueOf(0)), NumberUtils.convertNumberToTargetClass(Integer.valueOf(0), Long.class));
|
||||
assertEquals(Long.valueOf(Integer.valueOf(1)), NumberUtils.convertNumberToTargetClass(Integer.valueOf(1), Long.class));
|
||||
assertEquals(Long.valueOf(Integer.MAX_VALUE), NumberUtils.convertNumberToTargetClass(Integer.valueOf(Integer.MAX_VALUE), Long.class));
|
||||
assertEquals(Long.valueOf(Integer.MIN_VALUE), NumberUtils.convertNumberToTargetClass(Integer.valueOf(Integer.MAX_VALUE + 1), Long.class));
|
||||
assertEquals(Long.valueOf(Integer.MIN_VALUE), NumberUtils.convertNumberToTargetClass(Integer.valueOf(Integer.MIN_VALUE), Long.class));
|
||||
assertEquals(Long.valueOf(Integer.MAX_VALUE), NumberUtils.convertNumberToTargetClass(Integer.valueOf(Integer.MIN_VALUE - 1), Long.class));
|
||||
|
||||
assertEquals(Long.valueOf(Integer.valueOf(-1)), NumberUtils.convertNumberToTargetClass(Short.valueOf((short) -1), Long.class));
|
||||
assertEquals(Long.valueOf(Integer.valueOf(0)), NumberUtils.convertNumberToTargetClass(Short.valueOf((short) 0), Long.class));
|
||||
assertEquals(Long.valueOf(Integer.valueOf(1)), NumberUtils.convertNumberToTargetClass(Short.valueOf((short) 1), Long.class));
|
||||
assertEquals(Long.valueOf(Short.MAX_VALUE), NumberUtils.convertNumberToTargetClass(Short.valueOf(Short.MAX_VALUE), Long.class));
|
||||
assertEquals(Long.valueOf(Short.MIN_VALUE), NumberUtils.convertNumberToTargetClass(Short.valueOf((short) (Short.MAX_VALUE + 1)), Long.class));
|
||||
assertEquals(Long.valueOf(Short.MIN_VALUE), NumberUtils.convertNumberToTargetClass(Short.valueOf(Short.MIN_VALUE), Long.class));
|
||||
assertEquals(Long.valueOf(Short.MAX_VALUE), NumberUtils.convertNumberToTargetClass(Short.valueOf((short) (Short.MIN_VALUE - 1)), Long.class));
|
||||
|
||||
assertEquals(Long.valueOf(Integer.valueOf(-1)), NumberUtils.convertNumberToTargetClass(Byte.valueOf((byte) -1), Long.class));
|
||||
assertEquals(Long.valueOf(Integer.valueOf(0)), NumberUtils.convertNumberToTargetClass(Byte.valueOf((byte) 0), Long.class));
|
||||
assertEquals(Long.valueOf(Integer.valueOf(1)), NumberUtils.convertNumberToTargetClass(Byte.valueOf((byte) 1), Long.class));
|
||||
assertEquals(Long.valueOf(Byte.MAX_VALUE), NumberUtils.convertNumberToTargetClass(Byte.valueOf(Byte.MAX_VALUE), Long.class));
|
||||
assertEquals(Long.valueOf(Byte.MIN_VALUE), NumberUtils.convertNumberToTargetClass(Byte.valueOf((byte) (Byte.MAX_VALUE + 1)), Long.class));
|
||||
assertEquals(Long.valueOf(Byte.MIN_VALUE), NumberUtils.convertNumberToTargetClass(Byte.valueOf(Byte.MIN_VALUE), Long.class));
|
||||
assertEquals(Long.valueOf(Byte.MAX_VALUE), NumberUtils.convertNumberToTargetClass(Byte.valueOf((byte) (Byte.MIN_VALUE - 1)), Long.class));
|
||||
}
|
||||
|
||||
|
||||
private void assertLongEquals(String aLong) {
|
||||
assertEquals("Long did not parse", Long.MAX_VALUE, NumberUtils.parseNumber(aLong, Long.class).longValue());
|
||||
}
|
||||
|
@ -345,4 +445,16 @@ public class NumberUtilsTests extends TestCase {
|
|||
assertEquals("Byte did not parse", Byte.MIN_VALUE, NumberUtils.parseNumber(aByte, Byte.class).byteValue());
|
||||
}
|
||||
|
||||
private void assertToNumberOverflow(Number number, Class<? extends Number> targetClass) {
|
||||
String msg = "Expected exception due to overflow: from=" + number + ", toClass=" + targetClass;
|
||||
try {
|
||||
NumberUtils.convertNumberToTargetClass(number, targetClass);
|
||||
fail(msg);
|
||||
}
|
||||
catch (IllegalArgumentException expected) {
|
||||
assertTrue(msg + ", with \"overflow\" in message but got message=" + expected.getMessage(),
|
||||
expected.getMessage().endsWith("overflow"));
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue