diff options
author | wisberg <wisberg> | 2002-12-16 18:51:06 +0000 |
---|---|---|
committer | wisberg <wisberg> | 2002-12-16 18:51:06 +0000 |
commit | 144143c2970a1e874d74cdbd0f8c622d4282a3c3 (patch) | |
tree | b12383d3d9e76c7e1f25f7fbec83051ef17f81fb /tests/new/AdviceOrdering.java | |
parent | fafae443719b26159ab2d7dac1c9b46b5e00b671 (diff) | |
download | aspectj-144143c2970a1e874d74cdbd0f8c622d4282a3c3.tar.gz aspectj-144143c2970a1e874d74cdbd0f8c622d4282a3c3.zip |
initial version
Diffstat (limited to 'tests/new/AdviceOrdering.java')
-rw-r--r-- | tests/new/AdviceOrdering.java | 125 |
1 files changed, 125 insertions, 0 deletions
diff --git a/tests/new/AdviceOrdering.java b/tests/new/AdviceOrdering.java new file mode 100644 index 000000000..a67dc57c6 --- /dev/null +++ b/tests/new/AdviceOrdering.java @@ -0,0 +1,125 @@ +import org.aspectj.testing.*; + +public class AdviceOrdering { + public static void main(String[] args) { test(); } + + public static void test() { + new C().m(); + T.checkAndReset("before:aroundStart:m:aroundEnd:after:afterReturning"); + + new C().recur(2); + T.checkAndReset("P&&!cflowbelow(P):P:recur-2:P:recur-1:P:recur-0"); + + new C().a(); + T.checkAndReset("C1:C2:C3:C4:A3:A4:A1:A2:B1:a"); + } +} + + +class T { + private static StringBuffer order = new StringBuffer(); + public static void add(String s) { + if (order.length() > 0) { order.append(':'); } + order.append(s); + } + public static void reset() { order = new StringBuffer(); } + + public static void checkAndReset(String expectedValue) { + Tester.checkEqual(order.toString(), expectedValue); + order.setLength(0); + } +} + +class C { + public void m() { T.add("m"); } + public void a() { T.add("a"); } + public void b() { T.add("b"); } + public void c() { T.add("c"); } + + public void recur(int n) { + T.add("recur-"+n); + if (n > 0) recur(n-1); + } +} + +aspect A { + pointcut cut() : target(C) && call(void m()); + + before(): cut() { T.add("before"); } + void around(): cut() { + T.add("aroundStart"); + proceed(); + T.add("aroundEnd"); + } + + after(): cut() { T.add("after"); } + after() returning(): cut() { T.add("afterReturning"); } + +} + +//check that P && !cflow(P) never matches anything regardless of ordering issues +aspect FlowCheck { + pointcut cut() : target(C) && call(void recur(int)); + + before(): cut() && !cflow(cut()) { + // should never run + T.add("P&&!cflow(P)"); + } + before(): cut() && !cflowbelow(cut()) { + // should run once + T.add("P&&!cflowbelow(P)"); + } + + before(): cut() && cflow(cut() && !cflow(cut())) { + // should never run + T.add("cflow(P&&!cflow(P))"); + } + + before(): cut() { + T.add("P"); + } +} + + + +// This cluster of aspects checks that the partial order rules work +//aspect A1 dominates A2, B1 { +aspect A1 { declare dominates: A1, A2 || B1; + pointcut cut() : target(C) && call(void a()); + + before(): A1.cut() { T.add("A1"); } +} + +aspect A2 { declare dominates: A2, B1; + before(): A1.cut() { T.add("A2"); } +} + +aspect A3 { declare dominates: A3, A4, A1; + before(): A1.cut() { T.add("A3"); } +} + +aspect A4 { declare dominates: A4, A1; + before(): A1.cut() { T.add("A4"); } +} + +aspect B1 { + before(): A1.cut() { T.add("B1"); } +} + + + +//aspect C1 dominates C2, C3 { +aspect C1 { declare dominates: C1, C2 || C3; + before(): A1.cut() { T.add("C1"); } +} +aspect C2 { declare dominates: C2, C3; + before(): A1.cut() { T.add("C2"); } +} +aspect C3 { declare dominates: C3, C4; + before(): A1.cut() { T.add("C3"); } +} +//aspect C4 dominates A1, A2, A3, A4, B1 { +aspect C4 { declare dominates: C4, (A1 || A2 || A3 || A4 || B1); + before(): A1.cut() { T.add("C4"); } +} + |