From b26edc4adf9b7c9fe3f4df1e0c133b7149591111 Mon Sep 17 00:00:00 2001 From: Srikanth Sankaran Date: Wed, 23 Oct 2024 22:29:24 +0530 Subject: [PATCH] Regression tests for https://github.com/eclipse-jdt/eclipse.jdt.core/issues/3039 --- .../compiler/regression/SealedTypesTests.java | 83 +++++++++++++++++++ 1 file changed, 83 insertions(+) diff --git a/org.eclipse.jdt.core.tests.compiler/src/org/eclipse/jdt/core/tests/compiler/regression/SealedTypesTests.java b/org.eclipse.jdt.core.tests.compiler/src/org/eclipse/jdt/core/tests/compiler/regression/SealedTypesTests.java index db097a5a1cc..e7cfeb89efb 100644 --- a/org.eclipse.jdt.core.tests.compiler/src/org/eclipse/jdt/core/tests/compiler/regression/SealedTypesTests.java +++ b/org.eclipse.jdt.core.tests.compiler/src/org/eclipse/jdt/core/tests/compiler/regression/SealedTypesTests.java @@ -6434,4 +6434,87 @@ final class Y implements I { public void doit() {} } "A functional interface may not be declared sealed\n" + "----------\n"); } + + // https://github.com/eclipse-jdt/eclipse.jdt.core/issues/3039 + // [Sealed types] Broken program crashes the compiler + public void testIssue3039() { + runNegativeTest( + new String[] { + "X.java", + """ + public sealed class X permits X.C { + private final static class C extends X implements I {} + } + + sealed interface I permits X.C {} + record R(X.C xc, R.C rc) { + private class C {} + } + """ + }, + "----------\n" + + "1. ERROR in X.java (at line 5)\n" + + " sealed interface I permits X.C {}\n" + + " ^^^\n" + + "The type X.C is not visible\n" + + "----------\n" + + "2. ERROR in X.java (at line 6)\n" + + " record R(X.C xc, R.C rc) {\n" + + " ^^^\n" + + "The type X.C is not visible\n" + + "----------\n"); + } + + // https://github.com/eclipse-jdt/eclipse.jdt.core/issues/3039 + // [Sealed types] Broken program crashes the compiler + public void testIssue3039_2() { + runNegativeTest( + new String[] { + "X.java", + """ + public interface X { + + static Integer get(T object) { + return switch (object) { + case A ignored -> 42; + default -> 42; + }; + } + + public abstract sealed interface I2 permits , AB { + } + + + final class AB implements I2 {} + + } + """ + }, + "----------\n" + + "1. ERROR in X.java (at line 1)\n" + + " public interface X {\n" + + " ^\n" + + "Syntax error, insert \"}\" to complete InterfaceBody\n" + + "----------\n" + + "2. ERROR in X.java (at line 3)\n" + + " static Integer get(T object) {\n" + + " ^^\n" + + "I2 cannot be resolved to a type\n" + + "----------\n" + + "3. ERROR in X.java (at line 5)\n" + + " case A ignored -> 42;\n" + + " ^^^^^^^^^\n" + + "The Java feature 'Pattern Matching in Switch' is only available with source level 21 and above\n" + + "----------\n" + + "4. ERROR in X.java (at line 8)\n" + + " }\n" + + " ^\n" + + "Syntax error on token \"}\", delete this token\n" + + "----------\n" + + "5. ERROR in X.java (at line 10)\n" + + " public abstract sealed interface I2 permits , AB {\n" + + " ^^\n" + + "Syntax error on token \"I2\", permits expected after this token\n" + + "----------\n"); + } }