提交 3da964d6 编写于 作者: D darcy

8007115: Refactor regression tests for java.lang.reflect.Parameter

Reviewed-by: emc
上级 027ede90
...@@ -23,163 +23,152 @@ ...@@ -23,163 +23,152 @@
/* /*
* @test * @test
* @bug 8004729
* @summary javac should generate method parameters correctly. * @summary javac should generate method parameters correctly.
*/ */
import java.lang.*; import java.lang.*;
import java.lang.reflect.*; import java.lang.reflect.*;
import java.lang.annotation.*;
import java.util.List; import java.util.List;
import java.util.Objects;
import static java.lang.annotation.ElementType.*;
public class WithoutParameters { public class WithoutParameters {
int errors = 0;
private static final Class<?>[] qux_types = { private WithoutParameters() {}
int.class,
Foo.class,
List.class,
List.class,
List.class,
String[].class
};
public static void main(String argv[]) throws Exception { public static void main(String argv[]) throws Exception {
int error = 0; WithoutParameters wp = new WithoutParameters();
Method[] methods = Foo.class.getMethods(); wp.runTests(Foo.class.getMethods());
for(Method m : methods) { wp.runTests(Foo.Inner.class.getConstructors());
System.err.println("Inspecting method " + m); wp.checkForErrors();
Parameter[] parameters = m.getParameters(); }
if(parameters == null)
throw new Exception("getParameters should never be null"); void runTests(Method[] methods) throws Exception {
for(int i = 0; i < parameters.length; i++) { for(Method m : methods) {runTest(m);}
Parameter p = parameters[i]; }
if(!p.getDeclaringExecutable().equals(m)) {
System.err.println(p + ".getDeclaringExecutable != " + m); void runTests(Constructor[] constructors) throws Exception {
error++; for(Constructor c : constructors) {runTest(c);}
} }
if(null == p.getType()) {
System.err.println(p + ".getType() == null"); void runTest(Executable e) throws Exception {
error++; System.err.println("Inspecting executable " + e);
} Parameter[] parameters = e.getParameters();
if(null == p.getParameterizedType()) { Objects.requireNonNull(parameters, "getParameters should never be null");
System.err.println(p + ".getParameterizedType == null");
error++; ExpectedParameterInfo epi = e.getAnnotation(ExpectedParameterInfo.class);
} if (epi != null) {
} abortIfTrue(epi.parameterCount() != e.getParameterCount(), "Bad parameter count for "+ e);
if(m.getName().equals("qux")) { abortIfTrue(epi.isVarArgs() != e.isVarArgs(),"Bad varargs value for "+ e);
if(6 != parameters.length) { }
System.err.println("Wrong number of parameters for qux"); abortIfTrue(e.getParameterCount() != parameters.length, "Mismatched of parameter counts.");
error++;
} for(int i = 0; i < parameters.length; i++) {
for(int i = 0; i < parameters.length; i++) { Parameter p = parameters[i];
Parameter p = parameters[i]; errorIfTrue(!p.getDeclaringExecutable().equals(e), p + ".getDeclaringExecutable != " + e);
// The getType family work with or without Objects.requireNonNull(p.getType(), "getType() should not be null");
// parameter attributes compiled in. Objects.requireNonNull(p.getParameterizedType(), "getParameterizedType() should not be null");
if(!parameters[i].getType().equals(qux_types[i])) {
System.err.println("Wrong parameter type for " + parameters[0] + ": expected " + qux_types[i] + ", but got " + parameters[i].getType()); if (epi != null) {
error++; Class<?> expectedParameterType = epi.parameterTypes()[i];
} errorIfTrue(!p.getType().equals(expectedParameterType),
} "Wrong parameter type for " + p + ": expected " + expectedParameterType +
if(!parameters[0].getParameterizedType().equals(int.class)) { ", but got " + p.getType());
System.err.println("getParameterizedType for quux is wrong");
error++; ParameterizedInfo[] expectedParameterizedTypes = epi.parameterizedTypes();
} if (expectedParameterizedTypes.length > 0) {
if(!parameters[1].getParameterizedType().equals(Foo.class)) { Type parameterizedType = p.getParameterizedType();
System.err.println("getParameterizedType for quux is wrong"); Class<? extends Type> expectedParameterziedTypeType = expectedParameterizedTypes[i].value();
error++; errorIfTrue(!expectedParameterziedTypeType.isAssignableFrom(parameterizedType.getClass()),
} "Wrong class of parameteried type of " + p + ": expected " + expectedParameterziedTypeType +
if(!(parameters[2].getParameterizedType() instanceof ", but got " + parameterizedType.getClass());
ParameterizedType)) {
System.err.println("getParameterizedType for l is wrong"); if (expectedParameterziedTypeType.equals(Class.class)) {
error++; errorIfTrue(!parameterizedType.equals(expectedParameterType),
} else { "Wrong parameteried type for " + p + ": expected " + expectedParameterType +
ParameterizedType pt = ", but got " + parameterizedType);
(ParameterizedType) parameters[2].getParameterizedType();
if(!pt.getRawType().equals(List.class)) {
System.err.println("Raw type for l is wrong");
error++;
}
if(1 != pt.getActualTypeArguments().length) {
System.err.println("Number of type parameters for l is wrong");
error++;
}
if(!(pt.getActualTypeArguments()[0] instanceof WildcardType)) {
System.err.println("Type parameter for l is wrong");
error++;
}
}
if(!(parameters[3].getParameterizedType() instanceof
ParameterizedType)) {
System.err.println("getParameterizedType for l2 is wrong");
error++;
} else {
ParameterizedType pt =
(ParameterizedType) parameters[3].getParameterizedType();
if(!pt.getRawType().equals(List.class)) {
System.err.println("Raw type for l2 is wrong");
error++;
}
if(1 != pt.getActualTypeArguments().length) {
System.err.println("Number of type parameters for l2 is wrong");
error++;
}
if(!(pt.getActualTypeArguments()[0].equals(Foo.class))) {
System.err.println("Type parameter for l2 is wrong");
error++;
}
}
if(!(parameters[4].getParameterizedType() instanceof
ParameterizedType)) {
System.err.println("getParameterizedType for l3 is wrong");
error++;
} else {
ParameterizedType pt =
(ParameterizedType) parameters[4].getParameterizedType();
if(!pt.getRawType().equals(List.class)) {
System.err.println("Raw type for l3 is wrong");
error++;
}
if(1 != pt.getActualTypeArguments().length) {
System.err.println("Number of type parameters for l3 is wrong");
error++;
}
if(!(pt.getActualTypeArguments()[0] instanceof WildcardType)) {
System.err.println("Type parameter for l3 is wrong");
error++;
} else { } else {
WildcardType wt = (WildcardType) if (expectedParameterziedTypeType.equals(ParameterizedType.class)) {
pt.getActualTypeArguments()[0]; ParameterizedType ptype = (ParameterizedType)parameterizedType;
if(!wt.getUpperBounds()[0].equals(Foo.class)) { errorIfTrue(!ptype.getRawType().equals(expectedParameterType),
System.err.println("Upper bounds on type parameter fol l3 is wrong"); "Wrong raw type for " + p + ": expected " + expectedParameterType +
error++; ", but got " + ptype.getRawType());
} }
// Check string representation
String expectedStringOfType = epi.parameterizedTypes()[i].string();
errorIfTrue(!expectedStringOfType.equals(parameterizedType.toString()),
"Bad type string" + p + ": expected " + expectedStringOfType +
", but got " + parameterizedType.toString());
} }
} }
if(!parameters[5].isVarArgs()) {
System.err.println("isVarArg for rest is wrong");
error++;
}
if(!(parameters[5].getParameterizedType().equals(String[].class))) {
System.err.println("getParameterizedType for rest is wrong");
error++;
}
} }
} }
if(0 != error) }
throw new Exception("Failed " + error + " tests");
private void checkForErrors() {
if (errors > 0)
throw new RuntimeException("Failed " + errors + " tests");
}
private void errorIfTrue(boolean predicate, String errMessage) {
if (predicate) {
errors++;
System.err.println(errMessage);
}
}
private void abortIfTrue(boolean predicate, String errMessage) {
if (predicate) {
throw new RuntimeException(errMessage);
}
}
@Retention(RetentionPolicy.RUNTIME)
@Target({METHOD, CONSTRUCTOR})
@interface ExpectedParameterInfo {
int parameterCount() default 0;
Class<?>[] parameterTypes() default {};
ParameterizedInfo[] parameterizedTypes() default {};
boolean isVarArgs() default false;
}
@Target({})
@interface ParameterizedInfo {
Class<? extends Type> value() default Class.class;
String string() default "";
} }
public class Foo { public class Foo {
int thing; int thing;
@ExpectedParameterInfo(parameterCount = 6,
parameterTypes =
{int.class, Foo.class,
List.class, List.class,
List.class, String[].class},
parameterizedTypes =
{@ParameterizedInfo(Class.class),
@ParameterizedInfo(Class.class),
@ParameterizedInfo(value=ParameterizedType.class, string="java.util.List<?>"),
@ParameterizedInfo(value=ParameterizedType.class, string="java.util.List<WithoutParameters$Foo>"),
@ParameterizedInfo(value=ParameterizedType.class, string="java.util.List<? extends WithoutParameters$Foo>"),
@ParameterizedInfo(Class.class)},
isVarArgs = true)
public void qux(int quux, Foo quuux, public void qux(int quux, Foo quuux,
List<?> l, List<Foo> l2, List<?> l, List<Foo> l2,
List<? extends Foo> l3, List<? extends Foo> l3,
String... rest) {} String... rest) {}
public class Inner { public class Inner {
int thang; int thang;
@ExpectedParameterInfo(parameterCount = 2,
parameterTypes = {Foo.class, int.class})
public Inner(int theng) { public Inner(int theng) {
thang = theng + thing; thang = theng + thing;
} }
} }
} }
} }
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册