diff options
author | jhugunin <jhugunin> | 2003-03-12 23:07:08 +0000 |
---|---|---|
committer | jhugunin <jhugunin> | 2003-03-12 23:07:08 +0000 |
commit | 7746fcb7e977c7a91bd70081a2197a999ec18ad3 (patch) | |
tree | 4e4e458141708cb69d58b31043883be4f6c2871b /tests | |
parent | 519aa42cff336a34041df665c4c7e8f738274973 (diff) | |
download | aspectj-7746fcb7e977c7a91bd70081a2197a999ec18ad3.tar.gz aspectj-7746fcb7e977c7a91bd70081a2197a999ec18ad3.zip |
fix and test for Bugzilla Bug 34858
Weaver crash
Diffstat (limited to 'tests')
-rw-r--r-- | tests/ajcTests.xml | 12 | ||||
-rw-r--r-- | tests/bugs/CflowBinding.java | 44 | ||||
-rw-r--r-- | tests/bugs/CflowBindingOrig.java | 36 | ||||
-rw-r--r-- | tests/jimTests.xml | 12 |
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> <!-- |