aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoraclement <aclement>2009-03-04 00:54:16 +0000
committeraclement <aclement>2009-03-04 00:54:16 +0000
commit87a2be9fe71662caef27147fdae5177e37243438 (patch)
tree2d8d02578d011f41d99c527fd539cf76d2ee3f99
parent957181a21c6606399b00b5f2b86b15e8e7cbaaae (diff)
downloadaspectj-87a2be9fe71662caef27147fdae5177e37243438.tar.gz
aspectj-87a2be9fe71662caef27147fdae5177e37243438.zip
declaremixin: testcode
-rw-r--r--tests/features164/declareMixin/CaseA.java6
-rw-r--r--tests/features164/declareMixin/CaseB.java28
-rw-r--r--tests/features164/declareMixin/CaseC.java31
-rw-r--r--tests/features164/declareMixin/CaseD.java31
-rw-r--r--tests/features164/declareMixin/CaseE.java51
-rw-r--r--tests/features164/declareMixin/CaseF.java32
-rw-r--r--tests/features164/declareMixin/CaseG.java39
-rw-r--r--tests/features164/declareMixin/CaseH.java16
-rw-r--r--tests/features164/declareMixin/CaseI.java16
9 files changed, 248 insertions, 2 deletions
diff --git a/tests/features164/declareMixin/CaseA.java b/tests/features164/declareMixin/CaseA.java
index ac4933437..b82c67618 100644
--- a/tests/features164/declareMixin/CaseA.java
+++ b/tests/features164/declareMixin/CaseA.java
@@ -1,15 +1,17 @@
+// TESTING: Very basics with a simple static factory method
import org.aspectj.lang.annotation.*;
public class CaseA {
public static void main(String[]argv) {
CaseA ca = new CaseA();
- ((I)ca).methodOne();
+ ((I)ca).methodOne(); // will only succeed if mixin applied
}
}
aspect X {
@DeclareMixin("CaseA")
- public I createImplementation() {
+ public static I createImplementation() {
+ System.out.println("Delegate factory invoked");
return new Implementation();
}
}
diff --git a/tests/features164/declareMixin/CaseB.java b/tests/features164/declareMixin/CaseB.java
new file mode 100644
index 000000000..160220f59
--- /dev/null
+++ b/tests/features164/declareMixin/CaseB.java
@@ -0,0 +1,28 @@
+import org.aspectj.lang.annotation.*;
+
+public class CaseB {
+ public static void main(String[]argv) {
+ CaseB cb = new CaseB();
+ ((I)cb).methodOne(); // will only succeed if mixin applied
+ }
+}
+
+aspect X {
+ // TESTING: non static factory method, will need aspectOf() calling on
+ // the aspect before the factory is called
+ @DeclareMixin("CaseB")
+ public I createImplementation() {
+ System.out.println("Delegate factory invoked");
+ return new Implementation();
+ }
+}
+
+interface I {
+ void methodOne();
+}
+
+class Implementation implements I {
+ public void methodOne() {
+ System.out.println("methodOne running");
+ }
+}
diff --git a/tests/features164/declareMixin/CaseC.java b/tests/features164/declareMixin/CaseC.java
new file mode 100644
index 000000000..ee11f3959
--- /dev/null
+++ b/tests/features164/declareMixin/CaseC.java
@@ -0,0 +1,31 @@
+// TESTING: factory method takes the object for which the delegate exists
+import org.aspectj.lang.annotation.*;
+
+public class CaseC {
+ public static void main(String[]argv) {
+ CaseC cc = new CaseC();
+ ((I)cc).methodOne(); // will only succeed if mixin applied
+ }
+
+ public String toString() {
+ return "CaseC instance";
+ }
+}
+
+aspect X {
+ @DeclareMixin("CaseC")
+ public static I createImplementation(Object o) {
+ System.out.println("Delegate factory invoked for "+o.toString());
+ return new Implementation();
+ }
+}
+
+interface I {
+ void methodOne();
+}
+
+class Implementation implements I {
+ public void methodOne() {
+ System.out.println("methodOne running");
+ }
+}
diff --git a/tests/features164/declareMixin/CaseD.java b/tests/features164/declareMixin/CaseD.java
new file mode 100644
index 000000000..d5dcbda15
--- /dev/null
+++ b/tests/features164/declareMixin/CaseD.java
@@ -0,0 +1,31 @@
+// TESTING: factory method is non static and takes the object for which the delegate is being created
+import org.aspectj.lang.annotation.*;
+
+public class CaseD {
+ public static void main(String[]argv) {
+ CaseD cd = new CaseD();
+ ((I)cd).methodOne(); // will only succeed if mixin applied
+ }
+
+ public String toString() {
+ return "CaseD instance";
+ }
+}
+
+aspect X {
+ @DeclareMixin("CaseD")
+ public I createImplementation(Object o) {
+ System.out.println("Delegate factory invoked for "+o.toString());
+ return new Implementation();
+ }
+}
+
+interface I {
+ void methodOne();
+}
+
+class Implementation implements I {
+ public void methodOne() {
+ System.out.println("methodOne running");
+ }
+}
diff --git a/tests/features164/declareMixin/CaseE.java b/tests/features164/declareMixin/CaseE.java
new file mode 100644
index 000000000..62d079b92
--- /dev/null
+++ b/tests/features164/declareMixin/CaseE.java
@@ -0,0 +1,51 @@
+// TESTING: multiple instances causing factory invocation multiple times (but is cached)
+import org.aspectj.lang.annotation.*;
+
+public class CaseE {
+ private String id;
+
+ public static void main(String[]argv) {
+ CaseE cea = new CaseE("a");
+ CaseE ceb = new CaseE("b");
+ ((I)cea).methodOne();
+ ((I)ceb).methodTwo();
+ ((I)cea).methodOne();
+ ((I)ceb).methodTwo();
+ }
+
+ public CaseE(String id) {
+ this.id=id;
+ }
+
+ public String toString() {
+ return "CaseE instance: "+id;
+ }
+}
+
+aspect X {
+ @DeclareMixin("CaseE")
+ public I createImplementation(Object o) {
+ System.out.println("Delegate factory invoked for "+o.toString());
+ return new Implementation(o);
+ }
+}
+
+interface I {
+ void methodOne();
+ void methodTwo();
+}
+
+class Implementation implements I {
+ Object o;
+
+ public Implementation(Object o) {
+ this.o = o;
+ }
+
+ public void methodOne() {
+ System.out.println("methodOne running on "+o);
+ }
+ public void methodTwo() {
+ System.out.println("methodTwo running on "+o);
+ }
+}
diff --git a/tests/features164/declareMixin/CaseF.java b/tests/features164/declareMixin/CaseF.java
new file mode 100644
index 000000000..8e4fd5025
--- /dev/null
+++ b/tests/features164/declareMixin/CaseF.java
@@ -0,0 +1,32 @@
+// TESTING: Factory method directly takes the type specified in the Mixin target (strongly typed)
+import org.aspectj.lang.annotation.*;
+
+public class CaseF {
+ public static void main(String[]argv) {
+ CaseF cc = new CaseF();
+ ((I)cc).methodOne(); // will only succeed if mixin applied
+ }
+
+ public String toString() {
+ return "CaseF instance";
+ }
+}
+
+aspect X {
+ @DeclareMixin("CaseF")
+ public static I createImplementation(CaseF cf) {
+ System.out.println("Delegate factory invoked for "+cf.toString());
+ return new Implementation(cf);
+ }
+}
+
+interface I {
+ void methodOne();
+}
+
+class Implementation implements I {
+ public Implementation(CaseF cf) {}
+ public void methodOne() {
+ System.out.println("methodOne running");
+ }
+}
diff --git a/tests/features164/declareMixin/CaseG.java b/tests/features164/declareMixin/CaseG.java
new file mode 100644
index 000000000..fceb7cb7e
--- /dev/null
+++ b/tests/features164/declareMixin/CaseG.java
@@ -0,0 +1,39 @@
+// TESTING: targeting multiple types from the Mixin
+import org.aspectj.lang.annotation.*;
+
+public class CaseG {
+ public static void main(String[]argv) {
+ ((I)new A()).run();
+ ((I)new B()).run();
+ }
+
+}
+
+class A {
+}
+class B {
+}
+
+aspect X {
+ @DeclareMixin("A || B")
+ public I createImplementation(Object o) {
+ System.out.println("Delegate factory invoked for instance of "+o.getClass().getSimpleName());
+ return new Implementation(o);
+ }
+}
+
+interface I {
+ void run();
+}
+
+class Implementation implements I {
+ Object o;
+
+ public Implementation(Object o) {
+ this.o = o;
+ }
+
+ public void run() {
+ System.out.println("run() executing on behalf of "+o.getClass().getSimpleName());
+ }
+}
diff --git a/tests/features164/declareMixin/CaseH.java b/tests/features164/declareMixin/CaseH.java
new file mode 100644
index 000000000..11a840da1
--- /dev/null
+++ b/tests/features164/declareMixin/CaseH.java
@@ -0,0 +1,16 @@
+// TESTING: null target for mixin
+import org.aspectj.lang.annotation.*;
+
+public class CaseH {
+ public static void main(String[]argv) { }
+}
+
+aspect X {
+ @DeclareMixin(null)
+ public static I createImplementation() {
+ return null;
+ }
+}
+
+interface I {}
+
diff --git a/tests/features164/declareMixin/CaseI.java b/tests/features164/declareMixin/CaseI.java
new file mode 100644
index 000000000..e87040250
--- /dev/null
+++ b/tests/features164/declareMixin/CaseI.java
@@ -0,0 +1,16 @@
+// TESTING: invalid entry in interfaces
+import org.aspectj.lang.annotation.*;
+
+public class CaseI {
+ public static void main(String[]argv) { }
+}
+
+aspect X {
+ @DeclareMixin(value="X",interfaces={String.class})
+ public static I createImplementation() {
+ return null;
+ }
+}
+
+interface I {}
+