Allow a single test to be run

git-svn-id: https://svn.apache.org/repos/asf/commons/proper/math/branches/MATH_2_X@1062926 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Sebastian Bazley 2011-01-24 19:09:26 +00:00
parent aef1cb89bf
commit 77e64c0cb7
1 changed files with 13 additions and 4 deletions

View File

@ -32,6 +32,11 @@ import org.junit.runners.Parameterized.Parameters;
/** /**
* Test to compare FastMath results against StrictMath results for boundary values. * Test to compare FastMath results against StrictMath results for boundary values.
* <p>
* Running all tests independently: <br/>
* {@code mvn test -Dtest=FastMathStrictComparisonTest}<br/>
* or just run tests against a single method (e.g. scalb):<br/>
* {@code mvn test -Dtest=FastMathStrictComparisonTest -DargLine="-DtestMethod=scalb"}
*/ */
@RunWith(Parameterized.class) @RunWith(Parameterized.class)
public class FastMathStrictComparisonTest { public class FastMathStrictComparisonTest {
@ -57,13 +62,13 @@ public class FastMathStrictComparisonTest {
}; };
private static final Object [] LONG_SPECIAL_VALUES = { private static final Object [] LONG_SPECIAL_VALUES = {
-1,0,1, -1,0,1, // 1,2,3
Long.MIN_VALUE, Long.MAX_VALUE, Long.MIN_VALUE, Long.MAX_VALUE, // 4,5
}; };
private static final Object[] INT_SPECIAL_VALUES = { private static final Object[] INT_SPECIAL_VALUES = {
-1,0,1, -1,0,1, // 1,2,3
Integer.MIN_VALUE, Integer.MAX_VALUE, Integer.MIN_VALUE, Integer.MAX_VALUE, // 4,5
}; };
private final Method mathMethod; private final Method mathMethod;
@ -184,6 +189,7 @@ public class FastMathStrictComparisonTest {
@Parameters @Parameters
public static List<Object[]> data() throws Exception { public static List<Object[]> data() throws Exception {
String singleMethod = System.getProperty("testMethod");
List<Object[]> list = new ArrayList<Object[]>(); List<Object[]> list = new ArrayList<Object[]>();
for(Method mathMethod : StrictMath.class.getDeclaredMethods()) { for(Method mathMethod : StrictMath.class.getDeclaredMethods()) {
method: method:
@ -194,6 +200,9 @@ public class FastMathStrictComparisonTest {
// Get the corresponding FastMath method // Get the corresponding FastMath method
Method fastMethod = FastMath.class.getDeclaredMethod(mathMethod.getName(), (Class[]) types); Method fastMethod = FastMath.class.getDeclaredMethod(mathMethod.getName(), (Class[]) types);
if (Modifier.isPublic(fastMethod.getModifiers())) { // It must be public too if (Modifier.isPublic(fastMethod.getModifiers())) { // It must be public too
if (singleMethod != null && !fastMethod.getName().equals(singleMethod)) {
break method;
}
Object [][] values = new Object[types.length][]; Object [][] values = new Object[types.length][];
int index = 0; int index = 0;
for(Type t : types) { for(Type t : types) {