aboutsummaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorjhugunin <jhugunin>2003-03-12 23:07:08 +0000
committerjhugunin <jhugunin>2003-03-12 23:07:08 +0000
commit7746fcb7e977c7a91bd70081a2197a999ec18ad3 (patch)
tree4e4e458141708cb69d58b31043883be4f6c2871b /tests
parent519aa42cff336a34041df665c4c7e8f738274973 (diff)
downloadaspectj-7746fcb7e977c7a91bd70081a2197a999ec18ad3.tar.gz
aspectj-7746fcb7e977c7a91bd70081a2197a999ec18ad3.zip
fix and test for Bugzilla Bug 34858
Weaver crash
Diffstat (limited to 'tests')
-rw-r--r--tests/ajcTests.xml12
-rw-r--r--tests/bugs/CflowBinding.java44
-rw-r--r--tests/bugs/CflowBindingOrig.java36
-rw-r--r--tests/jimTests.xml12
4 files changed, 104 insertions, 0 deletions
diff --git a/tests/ajcTests.xml b/tests/ajcTests.xml
index b8486e3b5..40998854b 100644
--- a/tests/ajcTests.xml
+++ b/tests/ajcTests.xml
@@ -5685,4 +5685,16 @@
<message kind="error" line="85"/>
</compile>
</ajc-test>
+
+ <ajc-test dir="bugs" pr="34858"
+ title="cflow binding issues with ignoring state">
+ <compile files="CflowBinding.java"/>
+ <run class="CflowBinding"/>
+ </ajc-test>
+
+ <ajc-test dir="bugs" pr="34858"
+ title="cflow binding -- original weaver crash">
+ <compile files="CflowBindingOrig.java"/>
+ <run class="CflowBindingOrig"/>
+ </ajc-test>
</suite>
diff --git a/tests/bugs/CflowBinding.java b/tests/bugs/CflowBinding.java
new file mode 100644
index 000000000..f127811d9
--- /dev/null
+++ b/tests/bugs/CflowBinding.java
@@ -0,0 +1,44 @@
+// for Bugzilla Bug 34858
+// Weaver crash w/ coverage
+
+import org.aspectj.testing.Tester;
+
+public class CflowBinding {
+ public static void main(String[] args) {
+ new Bar().bar(10);
+ }
+
+
+ static aspect A {
+ pointcut flow(int i, Object o): cflow(execution(void bar(int)) && this(o) && args(i));
+
+ Object around() : call(void m()) && flow(int, Object) {
+ return proceed();
+ }
+
+ Object around(final int i) : call(void m()) && flow(i, Object) {
+ System.out.println("i: " + i);
+ return proceed(i);
+ }
+
+ Object around(final Object o) : call(void m()) && flow(int, o) {
+ System.out.println("o: " + o);
+ return proceed(o);
+ }
+
+ Object around(final Object o, final int i) : call(void m()) && flow(i, o) {
+ System.out.println("o: " + o + ", i: " + i);
+ return proceed(o, i);
+ }
+ }
+}
+
+class Bar {
+ void bar(int i) {
+ m();
+ }
+ void m() {
+ System.out.println("m");
+ }
+}
+
diff --git a/tests/bugs/CflowBindingOrig.java b/tests/bugs/CflowBindingOrig.java
new file mode 100644
index 000000000..cd0f00b9d
--- /dev/null
+++ b/tests/bugs/CflowBindingOrig.java
@@ -0,0 +1,36 @@
+// for Bugzilla Bug 34858
+// Weaver crash
+
+import org.aspectj.testing.Tester;
+
+/**
+ * Almost an exact duplicate of the reported issue
+ */
+public class CflowBindingOrig {
+ public static void main(String[] args) {
+ new Bar().foo();
+ }
+
+ static aspect MockProcessing {
+ pointcut testFlow(final Thread thread) :
+ cflow(execution(void run()) && this(thread) && within(Thread)); // the within is an optimization
+
+ Object around() :
+ call(* DummyConfiguration.createRootApplicationModule(..)) && testFlow(Thread)
+ {
+ return null;
+ }
+ }
+}
+
+class Bar {
+ void foo() {
+ DummyConfiguration.createRootApplicationModule();
+ }
+}
+
+class DummyConfiguration {
+ static Object createRootApplicationModule() {
+ return null;
+ }
+}
diff --git a/tests/jimTests.xml b/tests/jimTests.xml
index f4adb0f97..c03e61f44 100644
--- a/tests/jimTests.xml
+++ b/tests/jimTests.xml
@@ -1,7 +1,19 @@
<!DOCTYPE suite SYSTEM "../tests/ajcTestSuite.dtd">
<suite>
+ <ajc-test dir="errors"
+ title="type not imported in around advice">
+ <compile files="TypeNotImportedInAroundCE.java">
+ <message kind="error" line="10"/>
+ </compile>
+ </ajc-test>
+ <ajc-test dir="errors"
+ title="type not imported in aspect">
+ <compile files="TypeInAspectNotImportedCE.java">
+ <message kind="error" line="6"/>
+ </compile>
+ </ajc-test>
<!--