提交 78cc45b9 编写于 作者: B bpb

8022094: BigDecimal/CompareToTests and BigInteger/CompareToTests are incorrect

Summary: Fail test if errors; fix test values; port BigDecimal version to BigInteger
Reviewed-by: smarks, alanb
Contributed-by: NBrian Burkhalter <brian.burkhalter@oracle.com>
上级 961f83f6
...@@ -53,12 +53,29 @@ public class CompareToTests { ...@@ -53,12 +53,29 @@ public class CompareToTests {
{valueOf(5,-1), valueOf(2), ONE}, {valueOf(5,-1), valueOf(2), ONE},
// Boundary and near boundary values // Boundary and near boundary values
{valueOf(Long.MAX_VALUE), valueOf(Long.MAX_VALUE), ZERO}, {valueOf(Long.MAX_VALUE), valueOf(Long.MAX_VALUE), ZERO},
{valueOf(Long.MAX_VALUE-1), valueOf(Long.MAX_VALUE), MINUS_ONE}, {valueOf(Long.MAX_VALUE).negate(), valueOf(Long.MAX_VALUE), MINUS_ONE},
{valueOf(Long.MIN_VALUE), valueOf(Long.MAX_VALUE), MINUS_ONE},
{valueOf(Long.MIN_VALUE+1), valueOf(Long.MAX_VALUE), MINUS_ONE}, {valueOf(Long.MAX_VALUE-1), valueOf(Long.MAX_VALUE), MINUS_ONE},
{valueOf(Long.MIN_VALUE), valueOf(Long.MIN_VALUE), ZERO}, {valueOf(Long.MAX_VALUE-1).negate(), valueOf(Long.MAX_VALUE), MINUS_ONE},
{valueOf(Long.MIN_VALUE+1), valueOf(Long.MAX_VALUE), ONE},
{valueOf(Long.MIN_VALUE), valueOf(Long.MAX_VALUE), MINUS_ONE},
{valueOf(Long.MIN_VALUE).negate(), valueOf(Long.MAX_VALUE), ONE},
{valueOf(Long.MIN_VALUE+1), valueOf(Long.MAX_VALUE), MINUS_ONE},
{valueOf(Long.MIN_VALUE+1).negate(), valueOf(Long.MAX_VALUE), ZERO},
{valueOf(Long.MAX_VALUE), valueOf(Long.MIN_VALUE), ONE},
{valueOf(Long.MAX_VALUE).negate(), valueOf(Long.MIN_VALUE), ONE},
{valueOf(Long.MAX_VALUE-1), valueOf(Long.MIN_VALUE), ONE},
{valueOf(Long.MAX_VALUE-1).negate(), valueOf(Long.MIN_VALUE), ONE},
{valueOf(Long.MIN_VALUE), valueOf(Long.MIN_VALUE), ZERO},
{valueOf(Long.MIN_VALUE).negate(), valueOf(Long.MIN_VALUE), ONE},
{valueOf(Long.MIN_VALUE+1), valueOf(Long.MIN_VALUE), ONE},
{valueOf(Long.MIN_VALUE+1).negate(), valueOf(Long.MIN_VALUE), ONE},
}; };
for (BigDecimal[] testCase : testCases) { for (BigDecimal[] testCase : testCases) {
...@@ -69,8 +86,6 @@ public class CompareToTests { ...@@ -69,8 +86,6 @@ public class CompareToTests {
int expected = testCase[2].intValue(); int expected = testCase[2].intValue();
failures += compareToTest(a, b, expected); failures += compareToTest(a, b, expected);
failures += compareToTest(a_negate, b, -1);
failures += compareToTest(a, b_negate, 1);
failures += compareToTest(a_negate, b_negate, -expected); failures += compareToTest(a_negate, b_negate, -expected);
} }
...@@ -81,11 +96,11 @@ public class CompareToTests { ...@@ -81,11 +96,11 @@ public class CompareToTests {
private static int compareToTest(BigDecimal a, BigDecimal b, int expected) { private static int compareToTest(BigDecimal a, BigDecimal b, int expected) {
int result = a.compareTo(b); int result = a.compareTo(b);
int failed = (result==expected) ? 0 : 1; int failed = (result==expected) ? 0 : 1;
if (result == 1) { if (failed == 1) {
System.err.println("(" + a + ").compareTo(" + b + ") => " + result + System.err.println("(" + a + ").compareTo(" + b + ") => " + result +
"\n\tExpected " + expected); "\n\tExpected " + expected);
} }
return result; return failed;
} }
public static void main(String argv[]) { public static void main(String argv[]) {
......
...@@ -24,20 +24,23 @@ ...@@ -24,20 +24,23 @@
/* /*
* @test * @test
* @bug 6473768 * @bug 6473768
* @summary Tests of BigDecimal.compareTo * @summary Tests of BigInteger.compareTo
* @author Joseph D. Darcy * @author Joseph D. Darcy
*/ */
import java.math.*; import java.math.*;
import static java.math.BigDecimal.*; import static java.math.BigInteger.*;
public class CompareToTests { public class CompareToTests {
private static int compareToTests() { private static int compareToTests() {
int failures = 0; int failures = 0;
final BigDecimal MINUS_ONE = BigDecimal.ONE.negate(); final BigInteger MINUS_ONE = BigInteger.ONE.negate();
final BigInteger TWO_POW_126 = ONE.shiftLeft(126);
final BigInteger TWO_POW_127 = ONE.shiftLeft(127);
final BigInteger TWO_POW_128 = ONE.shiftLeft(128);
// First operand, second operand, expected compareTo result // First operand, second operand, expected compareTo result
BigDecimal [][] testCases = { BigInteger [][] testCases = {
// Basics // Basics
{valueOf(0), valueOf(0), ZERO}, {valueOf(0), valueOf(0), ZERO},
{valueOf(0), valueOf(1), MINUS_ONE}, {valueOf(0), valueOf(1), MINUS_ONE},
...@@ -45,32 +48,56 @@ public class CompareToTests { ...@@ -45,32 +48,56 @@ public class CompareToTests {
{valueOf(2), valueOf(1), ONE}, {valueOf(2), valueOf(1), ONE},
{valueOf(10), valueOf(10), ZERO}, {valueOf(10), valueOf(10), ZERO},
// Significands would compare differently than scaled value // Various relative lengths of internal mag array.
{valueOf(2,1), valueOf(2), MINUS_ONE}, {TWO_POW_127, TWO_POW_127, ZERO},
{valueOf(2,-1), valueOf(2), ONE}, {TWO_POW_127.negate(), TWO_POW_127, MINUS_ONE},
{valueOf(1,1), valueOf(2), MINUS_ONE},
{valueOf(1,-1), valueOf(2), ONE}, {TWO_POW_128.or(TWO_POW_126), TWO_POW_128, ONE},
{valueOf(5,-1), valueOf(2), ONE}, {TWO_POW_128.or(TWO_POW_126), TWO_POW_128.negate(), ONE},
// Boundary and near boundary values {TWO_POW_128, TWO_POW_128.or(TWO_POW_126), MINUS_ONE},
{valueOf(Long.MAX_VALUE), valueOf(Long.MAX_VALUE), ZERO}, {TWO_POW_128.negate(), TWO_POW_128.or(TWO_POW_126), MINUS_ONE},
{valueOf(Long.MAX_VALUE-1), valueOf(Long.MAX_VALUE), MINUS_ONE},
{valueOf(Long.MIN_VALUE), valueOf(Long.MAX_VALUE), MINUS_ONE}, {TWO_POW_127, TWO_POW_128, MINUS_ONE},
{valueOf(Long.MIN_VALUE+1), valueOf(Long.MAX_VALUE), MINUS_ONE}, {TWO_POW_127.negate(), TWO_POW_128, MINUS_ONE},
{valueOf(Long.MIN_VALUE), valueOf(Long.MIN_VALUE), ZERO},
{valueOf(Long.MIN_VALUE+1), valueOf(Long.MAX_VALUE), ONE}, {TWO_POW_128, TWO_POW_127, ONE},
{TWO_POW_128.negate(), TWO_POW_127, MINUS_ONE},
// Long boundary and near boundary values
{valueOf(Long.MAX_VALUE), valueOf(Long.MAX_VALUE), ZERO},
{valueOf(Long.MAX_VALUE).negate(), valueOf(Long.MAX_VALUE), MINUS_ONE},
{valueOf(Long.MAX_VALUE-1), valueOf(Long.MAX_VALUE), MINUS_ONE},
{valueOf(Long.MAX_VALUE-1).negate(), valueOf(Long.MAX_VALUE), MINUS_ONE},
{valueOf(Long.MIN_VALUE), valueOf(Long.MAX_VALUE), MINUS_ONE},
{valueOf(Long.MIN_VALUE).negate(), valueOf(Long.MAX_VALUE), ONE},
{valueOf(Long.MIN_VALUE+1), valueOf(Long.MAX_VALUE), MINUS_ONE},
{valueOf(Long.MIN_VALUE+1).negate(), valueOf(Long.MAX_VALUE), ZERO},
{valueOf(Long.MAX_VALUE), valueOf(Long.MIN_VALUE), ONE},
{valueOf(Long.MAX_VALUE).negate(), valueOf(Long.MIN_VALUE), ONE},
{valueOf(Long.MAX_VALUE-1), valueOf(Long.MIN_VALUE), ONE},
{valueOf(Long.MAX_VALUE-1).negate(), valueOf(Long.MIN_VALUE), ONE},
{valueOf(Long.MIN_VALUE), valueOf(Long.MIN_VALUE), ZERO},
{valueOf(Long.MIN_VALUE).negate(), valueOf(Long.MIN_VALUE), ONE},
{valueOf(Long.MIN_VALUE+1), valueOf(Long.MIN_VALUE), ONE},
{valueOf(Long.MIN_VALUE+1).negate(), valueOf(Long.MIN_VALUE), ONE},
}; };
for (BigDecimal[] testCase : testCases) { for (BigInteger[] testCase : testCases) {
BigDecimal a = testCase[0]; BigInteger a = testCase[0];
BigDecimal a_negate = a.negate(); BigInteger a_negate = a.negate();
BigDecimal b = testCase[1]; BigInteger b = testCase[1];
BigDecimal b_negate = b.negate(); BigInteger b_negate = b.negate();
int expected = testCase[2].intValue(); int expected = testCase[2].intValue();
failures += compareToTest(a, b, expected); failures += compareToTest(a, b, expected);
failures += compareToTest(a_negate, b, -1);
failures += compareToTest(a, b_negate, 1);
failures += compareToTest(a_negate, b_negate, -expected); failures += compareToTest(a_negate, b_negate, -expected);
} }
...@@ -78,14 +105,14 @@ public class CompareToTests { ...@@ -78,14 +105,14 @@ public class CompareToTests {
return failures; return failures;
} }
private static int compareToTest(BigDecimal a, BigDecimal b, int expected) { private static int compareToTest(BigInteger a, BigInteger b, int expected) {
int result = a.compareTo(b); int result = a.compareTo(b);
int failed = (result==expected) ? 0 : 1; int failed = (result==expected) ? 0 : 1;
if (result == 1) { if (failed == 1) {
System.err.println("(" + a + ").compareTo(" + b + ") => " + result + System.err.println("(" + a + ").compareTo(" + b + ") => " + result +
"\n\tExpected " + expected); "\n\tExpected " + expected);
} }
return result; return failed;
} }
public static void main(String argv[]) { public static void main(String argv[]) {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册