8213905: reflection not working for type annotations applied to exception types in the inner class constructor

Reviewed-by: jlahoda
This commit is contained in:
Vicente Romero 2022-01-26 00:33:10 +00:00
parent 295c0474c4
commit 2eab86b513
2 changed files with 15 additions and 5 deletions

View File

@ -132,7 +132,8 @@ public final class TypeAnnotationParser {
Class<?> declaringClass = ctor.getDeclaringClass(); Class<?> declaringClass = ctor.getDeclaringClass();
if (!declaringClass.isEnum() && if (!declaringClass.isEnum() &&
(declaringClass.isMemberClass() && (declaringClass.isMemberClass() &&
(declaringClass.getModifiers() & Modifier.STATIC) == 0) ) { (declaringClass.getModifiers() & Modifier.STATIC) == 0) &&
filter == TypeAnnotation.TypeAnnotationTarget.METHOD_FORMAL_PARAMETER) {
offset = true; offset = true;
} }
} }

View File

@ -39,7 +39,8 @@ public class TypeAnnotationReflection {
testReturnType(); testReturnType();
testNested(); testNested();
testArray(); testArray();
testRunException(); testRunException(TestClassException.class.getDeclaredMethod("foo", (Class<?>[])null));
testRunException(Outer2.TestClassException2.class.getDeclaredConstructor(Outer2.class));
testClassTypeVarBounds(); testClassTypeVarBounds();
testMethodTypeVarBounds(); testMethodTypeVarBounds();
testFields(); testFields();
@ -142,9 +143,8 @@ public class TypeAnnotationReflection {
check(((TypeAnno)annos[0]).value().equals("return4")); check(((TypeAnno)annos[0]).value().equals("return4"));
} }
private static void testRunException() throws Exception { private static void testRunException(Executable e) throws Exception {
Method m = TestClassException.class.getDeclaredMethod("foo", (Class<?>[])null); AnnotatedType[] ts = e.getAnnotatedExceptionTypes();
AnnotatedType[] ts = m.getAnnotatedExceptionTypes();
check(ts.length == 3); check(ts.length == 3);
AnnotatedType t; AnnotatedType t;
@ -624,6 +624,15 @@ abstract class TestClassException {
} }
} }
class Outer2 {
abstract class TestClassException2 {
public TestClassException2() throws
@TypeAnno("RE") @TypeAnno2("RE2") RuntimeException,
NullPointerException,
@TypeAnno("AIOOBE") ArrayIndexOutOfBoundsException {}
}
}
abstract class TestClassTypeVarAndField <T extends @TypeAnno("Object1") Object abstract class TestClassTypeVarAndField <T extends @TypeAnno("Object1") Object
& @TypeAnno("Runnable1") @TypeAnno2("Runnable2") Runnable, & @TypeAnno("Runnable1") @TypeAnno2("Runnable2") Runnable,
@TypeAnno("EE")EE extends @TypeAnno2("EEBound") Runnable, V > { @TypeAnno("EE")EE extends @TypeAnno2("EEBound") Runnable, V > {