From 144143c2970a1e874d74cdbd0f8c622d4282a3c3 Mon Sep 17 00:00:00 2001 From: wisberg Date: Mon, 16 Dec 2002 18:51:06 +0000 Subject: initial version --- tests/base/test123/Driver.java | 48 ++++++++++++++++++++++++++++++++++++++++++ tests/base/test123/Readme.txt | 5 +++++ 2 files changed, 53 insertions(+) create mode 100644 tests/base/test123/Driver.java create mode 100644 tests/base/test123/Readme.txt (limited to 'tests/base/test123') diff --git a/tests/base/test123/Driver.java b/tests/base/test123/Driver.java new file mode 100644 index 000000000..41d099c07 --- /dev/null +++ b/tests/base/test123/Driver.java @@ -0,0 +1,48 @@ +import org.aspectj.testing.Tester; + +public class Driver { + public static void main(String[] args) { test(); } + + public static void test() { + C1 c1 = new C1(333); + Tester.checkEqual(c1.afterAdvises, 0, "C1(int)"); + c1 = new C1("asdfasdf"); + Tester.checkEqual(c1.afterAdvises, 1, "C1(String)"); + C2 c2 = new C2(333); + Tester.checkEqual(c2.afterAdvises, 0, "C2(int) -> C1(String)"); + c2 = new C2("foo"); + Tester.checkEqual(c2.afterAdvises, 1, "C2(String) -> C1(int)"); + c2 = new C2("foo", 42); + Tester.checkEqual(c2.afterAdvises, 1, "C2(String,int) -> C1(String)"); + } +} + +class C1 { + public int afterAdvises = 0; + + C1() { } + C1(int i) { } + C1(String s) { } +} + +class C2 extends C1 { + + C2(int i) { + super("asdf"); + } + + C2(String s) { + super(42); + } + + C2(String s, int i) { + super(s); + } +} + +aspect A { + after(/*C1 c1*/) returning(C1 c1): /*target(c1) && */ + call(new(String, ..)) { + c1.afterAdvises += 1; + } +} diff --git a/tests/base/test123/Readme.txt b/tests/base/test123/Readme.txt new file mode 100644 index 000000000..0de4cc836 --- /dev/null +++ b/tests/base/test123/Readme.txt @@ -0,0 +1,5 @@ +Mode: VM Run +Title: Crossing super calls in constructors. + +This tests how crossing super calls work with reception +advice in constructors. -- cgit v1.2.3