diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/TypeAnnotations.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/TypeAnnotations.java index 7690c78dbb6..40a0a51fa54 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/TypeAnnotations.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/TypeAnnotations.java @@ -1017,7 +1017,7 @@ public class TypeAnnotations { case METHOD_INVOCATION: { JCMethodInvocation invocation = (JCMethodInvocation)frame; if (!invocation.typeargs.contains(tree)) { - throw new AssertionError("{" + tree + "} is not an argument in the invocation: " + invocation); + return TypeAnnotationPosition.unknown; } MethodSymbol exsym = (MethodSymbol) TreeInfo.symbol(invocation.getMethodSelect()); final int type_index = invocation.typeargs.indexOf(tree); diff --git a/langtools/test/tools/javac/annotations/typeAnnotations/failures/AnnotatedMethodSelectorTest.java b/langtools/test/tools/javac/annotations/typeAnnotations/failures/AnnotatedMethodSelectorTest.java new file mode 100644 index 00000000000..eb81d337e6c --- /dev/null +++ b/langtools/test/tools/javac/annotations/typeAnnotations/failures/AnnotatedMethodSelectorTest.java @@ -0,0 +1,14 @@ +/* + * @test /nodynamiccopyright/ + * @bug 8145987 + * @summary Assertion failure when compiling stream with type annotation + * @compile/fail/ref=AnnotatedMethodSelectorTest.out -XDrawDiagnostics AnnotatedMethodSelectorTest.java + */ + + +class AnnotatedMethodSelectorTest { + @interface A {} + static public void main(String... args) { + java.util.@A() Arrays.stream(args); + } +} diff --git a/langtools/test/tools/javac/annotations/typeAnnotations/failures/AnnotatedMethodSelectorTest.out b/langtools/test/tools/javac/annotations/typeAnnotations/failures/AnnotatedMethodSelectorTest.out new file mode 100644 index 00000000000..2b586e8c207 --- /dev/null +++ b/langtools/test/tools/javac/annotations/typeAnnotations/failures/AnnotatedMethodSelectorTest.out @@ -0,0 +1,2 @@ +AnnotatedMethodSelectorTest.java:12:19: compiler.err.annotation.type.not.applicable.to.type: AnnotatedMethodSelectorTest.A +1 error diff --git a/langtools/test/tools/javac/annotations/typeAnnotations/failures/AnnotatedMethodSelectorTest2.java b/langtools/test/tools/javac/annotations/typeAnnotations/failures/AnnotatedMethodSelectorTest2.java new file mode 100644 index 00000000000..fa591ecbc37 --- /dev/null +++ b/langtools/test/tools/javac/annotations/typeAnnotations/failures/AnnotatedMethodSelectorTest2.java @@ -0,0 +1,16 @@ +/* + * @test /nodynamiccopyright/ + * @bug 8145987 + * @summary Assertion failure when compiling stream with type annotation + * @compile/fail/ref=AnnotatedMethodSelectorTest2.out -XDrawDiagnostics AnnotatedMethodSelectorTest2.java + */ + +class AnnotatedMethodSelectorTest2 { + @interface A {} + class Inner {} + static public void main(String... args) { + new AnnotatedMethodSelectorTest2<@A String>() { + java.util.@A List l; + }.hashCode(); + } +} diff --git a/langtools/test/tools/javac/annotations/typeAnnotations/failures/AnnotatedMethodSelectorTest2.out b/langtools/test/tools/javac/annotations/typeAnnotations/failures/AnnotatedMethodSelectorTest2.out new file mode 100644 index 00000000000..0e12296fe53 --- /dev/null +++ b/langtools/test/tools/javac/annotations/typeAnnotations/failures/AnnotatedMethodSelectorTest2.out @@ -0,0 +1,3 @@ +AnnotatedMethodSelectorTest2.java:12:42: compiler.err.annotation.type.not.applicable.to.type: AnnotatedMethodSelectorTest2.A +AnnotatedMethodSelectorTest2.java:13:23: compiler.err.annotation.type.not.applicable.to.type: AnnotatedMethodSelectorTest2.A +2 errors diff --git a/langtools/test/tools/javac/annotations/typeAnnotations/failures/AnnotatedMethodSelectorTest3.java b/langtools/test/tools/javac/annotations/typeAnnotations/failures/AnnotatedMethodSelectorTest3.java new file mode 100644 index 00000000000..f8e460a9927 --- /dev/null +++ b/langtools/test/tools/javac/annotations/typeAnnotations/failures/AnnotatedMethodSelectorTest3.java @@ -0,0 +1,17 @@ +/* + * @test /nodynamiccopyright/ + * @bug 8145987 + * @summary Assertion failure when compiling stream with type annotation + * @compile/fail/ref=AnnotatedMethodSelectorTest3.out -XDrawDiagnostics AnnotatedMethodSelectorTest3.java + */ + + +class AnnotatedMethodSelectorTest3 { + @interface A {} + static AnnotatedMethodSelectorTest3 id() { + return null; + } + static public void main(String... args) { + AnnotatedMethodSelectorTest3.<@A String> id().id().id().id().id(); + } +} diff --git a/langtools/test/tools/javac/annotations/typeAnnotations/failures/AnnotatedMethodSelectorTest3.out b/langtools/test/tools/javac/annotations/typeAnnotations/failures/AnnotatedMethodSelectorTest3.out new file mode 100644 index 00000000000..732c8187fb6 --- /dev/null +++ b/langtools/test/tools/javac/annotations/typeAnnotations/failures/AnnotatedMethodSelectorTest3.out @@ -0,0 +1,2 @@ +AnnotatedMethodSelectorTest3.java:15:39: compiler.err.annotation.type.not.applicable.to.type: AnnotatedMethodSelectorTest3.A +1 error