aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlexander Kriegisch <Alexander@Kriegisch.name>2023-12-10 16:55:33 +0700
committerAlexander Kriegisch <Alexander@Kriegisch.name>2023-12-11 03:38:37 +0100
commit8c72d2da438d06885d48ffd3ade30b89a782b874 (patch)
treed80c381cff3c700115f5584cde1f9eaa38835bec
parent6be5a0a6a62e9afefad53a27f4c75d95ae7dac74 (diff)
downloadaspectj-8c72d2da438d06885d48ffd3ade30b89a782b874.tar.gz
aspectj-8c72d2da438d06885d48ffd3ade30b89a782b874.zip
Add tests for Java 21 unnamed patterns
TODO: Activate after https://github.com/eclipse-jdt/eclipse.jdt.core/issues/893 is done. Signed-off-by: Alexander Kriegisch <Alexander@Kriegisch.name>
-rw-r--r--tests/features1921/java21/UnnamedPatternsPreview1.java85
-rw-r--r--tests/features1921/java21/UnnamedPatternsPreview1Aspect.aj89
-rw-r--r--tests/src/test/java/org/aspectj/systemtest/ajc1921/Java21PreviewFeaturesTests.java22
-rw-r--r--tests/src/test/resources/org/aspectj/systemtest/ajc1921/ajc1921.xml41
4 files changed, 237 insertions, 0 deletions
diff --git a/tests/features1921/java21/UnnamedPatternsPreview1.java b/tests/features1921/java21/UnnamedPatternsPreview1.java
new file mode 100644
index 000000000..badb34c5c
--- /dev/null
+++ b/tests/features1921/java21/UnnamedPatternsPreview1.java
@@ -0,0 +1,85 @@
+import java.awt.*;
+import java.util.List;
+import java.util.PriorityQueue;
+import java.util.Queue;
+import java.util.stream.Collectors;
+import java.util.stream.Stream;
+
+/**
+ * Examples taken from <a href="https://openjdk.org/jeps/443">JEP 443</a>
+ */
+public class UnnamedPatternsPreview1 {
+ public static void main(String[] args) {
+ // An enhanced for loop with side effects
+ int acc = 0;
+ final int LIMIT = 2;
+ for (Order _ : List.of(new Order(), new Order(), new Order())) {
+ if (acc < LIMIT)
+ acc++;
+ }
+ System.out.println(acc);
+
+ // The initialisation of a basic for loop can declare unnamed local variables
+ for (int i = 0, _ = sideEffect(); i < 2; i++) {
+ System.out.println(i);
+ }
+
+ // An assignment statement, where the result of the expression on the right hand side is not needed
+ Queue<Integer> q = new PriorityQueue<>(List.of(1, 2, 3, 4, 5, 6));
+ while (q.size() >= 3) {
+ var x = q.remove();
+ var y = q.remove();
+ var _ = q.remove();
+ System.out.println(new Point(x, y));
+ }
+
+ // The same unnamed variable name '_' can be used in multiple assignment statements
+ q = new PriorityQueue<>(List.of(1, 2, 3, 4, 5, 6));
+ while (q.size() >= 3) {
+ var x = q.remove();
+ var _ = q.remove();
+ var _ = q.remove();
+ System.out.println(new Point(x, 0));
+ }
+
+ // Unnamed variables can be used in one or multiple catch blocks
+ String s = "123xy";
+ try {
+ int i = Integer.parseInt(s);
+ System.out.println(i);
+ } catch (NumberFormatException _) {
+ System.out.println("Bad number: " + s);
+ } catch (Exception _) {
+ System.out.println("Unexpected error");
+ }
+
+ // Try with resources
+ try (var _ = ScopedContext.acquire()) {
+ System.out.println("Doing something within scoped context");
+ }
+
+ // A lambda whose parameter is irrelevant
+ System.out.println(
+ Stream.of("one", "two", "three")
+ .collect(Collectors.toMap(String::toUpperCase, _ -> "NODATA"))
+ );
+ }
+
+ static int sideEffect() {
+ System.out.println("side effect");
+ return 42;
+ }
+
+ static class Order {}
+
+ static class ScopedContext implements AutoCloseable {
+ public static ScopedContext acquire() {
+ return new ScopedContext();
+ }
+
+ @Override
+ public void close() {
+ System.out.println("Closing scoped context");
+ }
+ }
+}
diff --git a/tests/features1921/java21/UnnamedPatternsPreview1Aspect.aj b/tests/features1921/java21/UnnamedPatternsPreview1Aspect.aj
new file mode 100644
index 000000000..d224a94fc
--- /dev/null
+++ b/tests/features1921/java21/UnnamedPatternsPreview1Aspect.aj
@@ -0,0 +1,89 @@
+import java.awt.*;
+import java.util.List;
+import java.util.PriorityQueue;
+import java.util.Queue;
+import java.util.stream.Collectors;
+import java.util.stream.Stream;
+
+/**
+ * Examples taken from <a href="https://openjdk.org/jeps/443">JEP 443</a>
+ */
+public class UnnamedPatternsPreview1Aspect {
+ public static void main(String[] args) {}
+
+ before() : execution(* main(String[])) {
+ System.out.println(thisJoinPoint);
+
+ // An enhanced for loop with side effects
+ int acc = 0;
+ final int LIMIT = 2;
+ for (Order _ : List.of(new Order(), new Order(), new Order())) {
+ if (acc < LIMIT)
+ acc++;
+ }
+ System.out.println(acc);
+
+ // The initialisation of a basic for loop can declare unnamed local variables
+ for (int i = 0, _ = sideEffect(); i < 2; i++) {
+ System.out.println(i);
+ }
+
+ // An assignment statement, where the result of the expression on the right hand side is not needed
+ Queue<Integer> q = new PriorityQueue<>(List.of(1, 2, 3, 4, 5, 6));
+ while (q.size() >= 3) {
+ var x = q.remove();
+ var y = q.remove();
+ var _ = q.remove();
+ System.out.println(new Point(x, y));
+ }
+
+ // The same unnamed variable name '_' can be used in multiple assignment statements
+ q = new PriorityQueue<>(List.of(1, 2, 3, 4, 5, 6));
+ while (q.size() >= 3) {
+ var x = q.remove();
+ var _ = q.remove();
+ var _ = q.remove();
+ System.out.println(new Point(x, 0));
+ }
+
+ // Unnamed variables can be used in one or multiple catch blocks
+ String s = "123xy";
+ try {
+ int i = Integer.parseInt(s);
+ System.out.println(i);
+ } catch (NumberFormatException _) {
+ System.out.println("Bad number: " + s);
+ } catch (Exception _) {
+ System.out.println("Unexpected error");
+ }
+
+ // Try with resources
+ try (var _ = ScopedContext.acquire()) {
+ System.out.println("Doing something within scoped context");
+ }
+
+ // A lambda whose parameter is irrelevant
+ System.out.println(
+ Stream.of("one", "two", "three")
+ .collect(Collectors.toMap(String::toUpperCase, _ -> "NODATA"))
+ );
+ }
+
+ static int sideEffect() {
+ System.out.println("side effect");
+ return 42;
+ }
+
+ static class Order {}
+
+ static class ScopedContext implements AutoCloseable {
+ public static ScopedContext acquire() {
+ return new ScopedContext();
+ }
+
+ @Override
+ public void close() {
+ System.out.println("Closing scoped context");
+ }
+ }
+}
diff --git a/tests/src/test/java/org/aspectj/systemtest/ajc1921/Java21PreviewFeaturesTests.java b/tests/src/test/java/org/aspectj/systemtest/ajc1921/Java21PreviewFeaturesTests.java
index 5ef087602..bdde4b67e 100644
--- a/tests/src/test/java/org/aspectj/systemtest/ajc1921/Java21PreviewFeaturesTests.java
+++ b/tests/src/test/java/org/aspectj/systemtest/ajc1921/Java21PreviewFeaturesTests.java
@@ -24,6 +24,28 @@ public class Java21PreviewFeaturesTests extends XMLBasedAjcTestCaseForJava21Only
runTest("string patterns aspect");
}
+ /**
+ * Still not implemented with the Java 21 release Eclipse 2023-12 (4.30),
+ * see <a href="https://github.com/eclipse-jdt/eclipse.jdt.core/issues/893">GitHub issue 893</a>.
+ * <p>
+ * TODO: Activate after JDT Core implementation and merge.
+ */
+ public void testUnnamedPatterns() {
+ //runTest("unnamed patterns");
+ System.out.println("Unnamed patterns still are not implemented with the Java 21 release Eclipse 2023-12 (4.30)");
+ }
+
+ /**
+ * Still not implemented with the Java 21 release Eclipse 2023-12 (4.30),
+ * see <a href="https://github.com/eclipse-jdt/eclipse.jdt.core/issues/893">GitHub issue 893</a>.
+ * <p>
+ * TODO: Activate after JDT Core implementation and merge.
+ */
+ public void testUnnamedPatternsAspect() {
+ //runTest("unnamed patterns aspect");
+ System.out.println("Unnamed patterns still are not implemented with the Java 21 release Eclipse 2023-12 (4.30)");
+ }
+
public static Test suite() {
return XMLBasedAjcTestCase.loadSuite(Java21PreviewFeaturesTests.class);
}
diff --git a/tests/src/test/resources/org/aspectj/systemtest/ajc1921/ajc1921.xml b/tests/src/test/resources/org/aspectj/systemtest/ajc1921/ajc1921.xml
index a7b5d0d95..edb41fb31 100644
--- a/tests/src/test/resources/org/aspectj/systemtest/ajc1921/ajc1921.xml
+++ b/tests/src/test/resources/org/aspectj/systemtest/ajc1921/ajc1921.xml
@@ -259,4 +259,45 @@
</run>
</ajc-test>
+ <!-- Java 21 preview -->
+ <!-- TODO: Activate after https://github.com/eclipse-jdt/eclipse.jdt.core/issues/893 is done -->
+ <ajc-test dir="features1921/java21" vm="21" title="unnamed patterns">
+ <compile files="UnnamedPatternsPreview1.java" options="--enable-preview -21"/>
+ <run class="UnnamedPatternsPreview1" vmargs="--enable-preview">
+ <stdout ordered="yes">
+ <line text="0"/>
+ <line text="1"/>
+ <line text="java.awt.Point[x=1,y=2]"/>
+ <line text="java.awt.Point[x=4,y=5]"/>
+ <line text="java.awt.Point[x=1,y=0]"/>
+ <line text="java.awt.Point[x=4,y=0]"/>
+ <line text="Bad number: 123xy"/>
+ <line text="Doing something within scoped context"/>
+ <line text="Closing scoped context"/>
+ <line text="{ONE=NODATA, TWO=NODATA, THREE=NODATA}"/>
+ </stdout>
+ </run>
+ </ajc-test>
+
+ <!-- Java 21 preview -->
+ <!-- TODO: Activate after https://github.com/eclipse-jdt/eclipse.jdt.core/issues/893 is done -->
+ <ajc-test dir="features1921/java21" vm="21" title="unnamed patterns aspect">
+ <compile files="UnnamedPatternsPreview1Aspect.java" options="--enable-preview -21"/>
+ <run class="UnnamedPatternsPreview1Aspect" vmargs="--enable-preview">
+ <stdout ordered="yes">
+ <line text="execution(void UnnamedPatternsPreview1Aspect.main(String[]))"/>
+ <line text="0"/>
+ <line text="1"/>
+ <line text="java.awt.Point[x=1,y=2]"/>
+ <line text="java.awt.Point[x=4,y=5]"/>
+ <line text="java.awt.Point[x=1,y=0]"/>
+ <line text="java.awt.Point[x=4,y=0]"/>
+ <line text="Bad number: 123xy"/>
+ <line text="Doing something within scoped context"/>
+ <line text="Closing scoped context"/>
+ <line text="{ONE=NODATA, TWO=NODATA, THREE=NODATA}"/>
+ </stdout>
+ </run>
+ </ajc-test>
+
</suite>