From: aclement Date: Tue, 18 May 2004 15:54:05 +0000 (+0000) Subject: Tests for Bugzilla Bug 62458 X-Git-Tag: V1_2_0~3 X-Git-Url: https://source.dussan.org/?a=commitdiff_plain;h=68bc96dd1086d5832e96395b09f49da2b8e5f995;p=aspectj.git Tests for Bugzilla Bug 62458 An if() pointcut inside a perthis() clause causes an ABORT - null pointer exception in ajc --- diff --git a/tests/ajcTests.xml b/tests/ajcTests.xml index d30ddb380..e540a046e 100644 --- a/tests/ajcTests.xml +++ b/tests/ajcTests.xml @@ -7733,5 +7733,28 @@ + + + + + + + + + + + + + + + + + + + + diff --git a/tests/bugs/IfPerThis/Testcase1.java b/tests/bugs/IfPerThis/Testcase1.java new file mode 100644 index 000000000..38ea7b16c --- /dev/null +++ b/tests/bugs/IfPerThis/Testcase1.java @@ -0,0 +1,27 @@ +public class Testcase1 { + + public static void main(String [] args) { + new Testcase1().sayhi(); + } + + public void sayhi() { + System.out.println("Hello World"); + } + +} + +// Note the use of an if inside a perthis, causes the ajc compiler to +// throw an exception +aspect Aspect perthis(if(4==3)) { + + before () : call(* println(..)) && !within(Aspect*) { + System.out.println("Advice 1"); + } + +} + +aspect Aspect2 pertarget(if(3==4)) {} + +aspect Aspect3 percflow(if(3==4)) {} + +aspect Aspect4 percflowbelow(if(3==4)) {} \ No newline at end of file diff --git a/tests/bugs/IfPerThis/Testcase2.java b/tests/bugs/IfPerThis/Testcase2.java new file mode 100644 index 000000000..42e9dfb04 --- /dev/null +++ b/tests/bugs/IfPerThis/Testcase2.java @@ -0,0 +1,41 @@ + aspect Testcase2 perthis(pc1()) { + + pointcut pc1(): execution(* doCommand(..)) && if(commandInterceptionEnabled); + private static boolean commandInterceptionEnabled = true; + + public Testcase2() { + System.out.println("Created a PerThis aspect : " + this.toString()); + } + + before(ICommand command) : execution(* doCommand(..)) && this(command) { + System.out.println("Invoking command bean: "+ command); + } + + before(): if(4==3) { + + } + + public static void main(String[] args) { + ICommand c1 = new Command("hello"); + ICommand c2 = new Command("hello again"); + c1.doCommand(); + c2.doCommand(); + } + +} + +interface ICommand { + void doCommand(); +} + +class Command implements ICommand { + + private String output = ""; + + public Command(String s) { this.output = s; } + + public void doCommand() { + System.out.println(output + "(" + this + ")"); + } + +} \ No newline at end of file diff --git a/tests/bugs/IfPerThis/Testcase3.java b/tests/bugs/IfPerThis/Testcase3.java new file mode 100644 index 000000000..c29834338 --- /dev/null +++ b/tests/bugs/IfPerThis/Testcase3.java @@ -0,0 +1,37 @@ +// Compiler limitation, can't put if() directly in per clause +aspect Testcase3 perthis(execution(* doCommand(..)) && if(commandInterceptionEnabled)) { + + private static boolean commandInterceptionEnabled = true; + + public Testcase3() { + System.out.println("Created a PerThis aspect : " + this.toString()); + } + + before(ICommand command) : execution(* doCommand(..)) && this(command) { + System.out.println("Invoking command bean: "+ command); + } + + public static void main(String[] args) { + ICommand c1 = new Command("hello"); + ICommand c2 = new Command("hello again"); + c1.doCommand(); + c2.doCommand(); + } + +} + +interface ICommand { + void doCommand(); +} + +class Command implements ICommand { + + private String output = ""; + + public Command(String s) { this.output = s; } + + public void doCommand() { + System.out.println(output + "(" + this + ")"); + } + +} \ No newline at end of file