aboutsummaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorAndy Clement <aclement@pivotal.io>2019-06-03 10:06:59 -0700
committerAndy Clement <aclement@pivotal.io>2019-06-03 10:06:59 -0700
commitff7f5a5441d4e2e8744a10c8f7c733fa208e0b89 (patch)
tree5334238d7461c41d869365232bcbded6a7a9f159 /tests
parent01f7d8ba8e3ff34ffacb95ae25787b0f0ce9f1d8 (diff)
downloadaspectj-ff7f5a5441d4e2e8744a10c8f7c733fa208e0b89.tar.gz
aspectj-ff7f5a5441d4e2e8744a10c8f7c733fa208e0b89.zip
Fix 547808: npe regression for multi @Around
Diffstat (limited to 'tests')
-rw-r--r--tests/bugs195/333274/Code.java39
-rw-r--r--tests/src/test/java/org/aspectj/systemtest/AllTests19.java21
-rw-r--r--tests/src/test/java/org/aspectj/systemtest/ajc195/Ajc195Tests.java34
-rw-r--r--tests/src/test/java/org/aspectj/systemtest/ajc195/AllTestsAspectJ195.java23
-rw-r--r--tests/src/test/resources/org/aspectj/systemtest/ajc195/ajc195.xml19
5 files changed, 127 insertions, 9 deletions
diff --git a/tests/bugs195/333274/Code.java b/tests/bugs195/333274/Code.java
new file mode 100644
index 000000000..d456c0a05
--- /dev/null
+++ b/tests/bugs195/333274/Code.java
@@ -0,0 +1,39 @@
+import org.aspectj.lang.annotation.*;
+import org.aspectj.lang.*;
+
+public class Code {
+ public static void main(String []argv) {
+try {
+ foo();
+} catch (Throwable t) {
+ System.out.println("Caught "+t);
+}
+ }
+
+ public static void foo() {
+ print1("abc");
+ print2("def");
+ print1("ghi");
+ }
+
+ public static void print1(String s) {
+ System.out.println(s);
+ }
+
+ public static void print2(String s) {
+ System.out.println(s);
+ }
+}
+
+@Aspect
+class Azpect {
+ @Around("call(* print2(..))")
+ public Object one(ProceedingJoinPoint pjp) {
+ return pjp.proceed();
+ }
+ @Around("call(* print2(..))")
+ public Object two(ProceedingJoinPoint pjp) {
+ //return pjp.proceed();
+ throw new IllegalStateException("");
+ }
+}
diff --git a/tests/src/test/java/org/aspectj/systemtest/AllTests19.java b/tests/src/test/java/org/aspectj/systemtest/AllTests19.java
index c2c798c32..eeff00b31 100644
--- a/tests/src/test/java/org/aspectj/systemtest/AllTests19.java
+++ b/tests/src/test/java/org/aspectj/systemtest/AllTests19.java
@@ -1,12 +1,9 @@
/*******************************************************************************
- * Copyright (c) 2013, 2014 Contributors
+ * Copyright (c) 2013, 2019 Contributors
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
- *
- * Contributors:
- * Andy Clement - initial API and implementation
*******************************************************************************/
package org.aspectj.systemtest;
@@ -14,19 +11,25 @@ import org.aspectj.systemtest.ajc190.AllTestsAspectJ190;
import org.aspectj.systemtest.ajc191.AllTestsAspectJ191;
import org.aspectj.systemtest.ajc192.AllTestsAspectJ192;
import org.aspectj.systemtest.ajc193.AllTestsAspectJ193;
+import org.aspectj.systemtest.ajc195.AllTestsAspectJ195;
import junit.framework.Test;
import junit.framework.TestSuite;
+/**
+ * @author Andy Clement
+ */
public class AllTests19 {
public static Test suite() {
TestSuite suite = new TestSuite("AspectJ System Test Suite - 1.9");
- // $JUnit-BEGIN$
- suite.addTest(AllTestsAspectJ190.suite());
- suite.addTest(AllTestsAspectJ191.suite());
- suite.addTest(AllTestsAspectJ192.suite());
- suite.addTest(AllTestsAspectJ193.suite());
+ // $JUnit-BEGIN$
+ suite.addTest(AllTestsAspectJ190.suite());
+ suite.addTest(AllTestsAspectJ191.suite());
+ suite.addTest(AllTestsAspectJ192.suite());
+ suite.addTest(AllTestsAspectJ193.suite());
+ // there were no new tests for 1.9.4
+ suite.addTest(AllTestsAspectJ195.suite());
suite.addTest(AllTests18.suite());
// $JUnit-END$
return suite;
diff --git a/tests/src/test/java/org/aspectj/systemtest/ajc195/Ajc195Tests.java b/tests/src/test/java/org/aspectj/systemtest/ajc195/Ajc195Tests.java
new file mode 100644
index 000000000..7c6034a3e
--- /dev/null
+++ b/tests/src/test/java/org/aspectj/systemtest/ajc195/Ajc195Tests.java
@@ -0,0 +1,34 @@
+/*******************************************************************************
+ * Copyright (c) 2019 Contributors
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution, and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *******************************************************************************/
+package org.aspectj.systemtest.ajc195;
+
+import org.aspectj.testing.XMLBasedAjcTestCase;
+
+import junit.framework.Test;
+
+/**
+ * @author Andy Clement
+ */
+public class Ajc195Tests extends XMLBasedAjcTestCase {
+
+ public void testFinallyBlocksAndUnlinkingAndExceptions() {
+ runTest("around finally blocks and unlinking");
+ }
+
+ // ---
+
+ public static Test suite() {
+ return XMLBasedAjcTestCase.loadSuite(Ajc195Tests.class);
+ }
+
+ @Override
+ protected java.net.URL getSpecFile() {
+ return getClassResource("ajc195.xml");
+ }
+
+}
diff --git a/tests/src/test/java/org/aspectj/systemtest/ajc195/AllTestsAspectJ195.java b/tests/src/test/java/org/aspectj/systemtest/ajc195/AllTestsAspectJ195.java
new file mode 100644
index 000000000..a7eb6604e
--- /dev/null
+++ b/tests/src/test/java/org/aspectj/systemtest/ajc195/AllTestsAspectJ195.java
@@ -0,0 +1,23 @@
+/*******************************************************************************
+ * Copyright (c) 2018-2019 Contributors
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution, and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ * Andy Clement - initial API and implementation
+ *******************************************************************************/
+package org.aspectj.systemtest.ajc195;
+
+import junit.framework.Test;
+import junit.framework.TestSuite;
+
+public class AllTestsAspectJ195 {
+
+ public static Test suite() {
+ TestSuite suite = new TestSuite("AspectJ 1.9.4 tests");
+ suite.addTest(Ajc195Tests.suite());
+ return suite;
+ }
+}
diff --git a/tests/src/test/resources/org/aspectj/systemtest/ajc195/ajc195.xml b/tests/src/test/resources/org/aspectj/systemtest/ajc195/ajc195.xml
new file mode 100644
index 000000000..10d1a0156
--- /dev/null
+++ b/tests/src/test/resources/org/aspectj/systemtest/ajc195/ajc195.xml
@@ -0,0 +1,19 @@
+<!DOCTYPE suite SYSTEM "../tests/ajcTestSuite.dtd"[]>
+
+<suite>
+
+ <ajc-test dir="bugs195/333274" vm="1.8" title="around finally blocks and unlinking">
+ <compile files="Code.java" options="-showWeaveInfo -1.8 -XnoInline">
+ <message kind="weave" text="Join point 'method-call(void Code.print2(java.lang.String))' in Type 'Code' (Code.java:15) advised by around advice from 'Azpect' (Code.java:35)"/>
+ <message kind="weave" text="Join point 'method-call(void Code.print2(java.lang.String))' in Type 'Code' (Code.java:15) advised by around advice from 'Azpect' (Code.java:31)"/>
+ </compile>
+
+ <run class="Code">
+ <stdout>
+ <line text="abc"/>
+ <line text="Caught java.lang.IllegalStateException"/>
+ </stdout>
+ </run>
+ </ajc-test>
+
+</suite>