aboutsummaryrefslogtreecommitdiffstats
path: root/tests/knownLimitations
diff options
context:
space:
mode:
Diffstat (limited to 'tests/knownLimitations')
-rw-r--r--tests/knownLimitations/test117/Driver.java126
-rw-r--r--tests/knownLimitations/test117/Readme.txt12
2 files changed, 138 insertions, 0 deletions
diff --git a/tests/knownLimitations/test117/Driver.java b/tests/knownLimitations/test117/Driver.java
new file mode 100644
index 000000000..c8cf1a2b3
--- /dev/null
+++ b/tests/knownLimitations/test117/Driver.java
@@ -0,0 +1,126 @@
+import org.aspectj.testing.Tester;
+
+public class Driver {
+ public static void main(String[] args) { test(); }
+
+ public static void test() {
+ C1 c1 = new C1();
+ C11 c11 = new C11();
+ C111 c111 = new C111();
+ C12 c12 = new C12();
+ Cleaf1 cleaf1 = new Cleaf1();
+ Cleaf11 cleaf11 = new Cleaf11();
+ Cleaf111 cleaf111 = new Cleaf111();
+ Cleaf12 cleaf12 = new Cleaf12();
+
+ Tester.checkEqual(c1.a, 0, "c1.a");
+ Tester.checkEqual(c11.a, 0, "c11.a");
+ Tester.checkEqual(c111.a, 0, "c111.a");
+ Tester.checkEqual(c12.a, 0, "c12.a");
+
+ Tester.checkEqual(cleaf1.a, 0, "cleaf1.a");
+ Tester.checkEqual(cleaf11.a, 0, "cleaf11.a");
+ Tester.checkEqual(cleaf111.a, 0, "cleaf111.a");
+ Tester.checkEqual(cleaf12.a, 0, "cleaf12.a");
+
+ Tester.checkEqual(c1.b, 0, "c1.b");
+ Tester.checkEqual(cleaf1.b, 0, "cleaf1.b");
+
+ Tester.checkEqual(I1.c, 5, "I1.c");
+
+ Tester.checkEqual(c1.d, 1, "c1.d");
+ Tester.checkEqual(c11.d, 1, "c11.d");
+ Tester.checkEqual(c111.d, 1, "c111.d");
+ Tester.checkEqual(c12.d, 1, "c12.d");
+
+ Tester.checkEqual(c1.e, 2, "c1.e");
+ Tester.checkEqual(cleaf1.e, 2, "cleaf1.e");
+
+ Tester.checkEqual(C1.f, 4, "C1.f");
+ Tester.checkEqual(cleaf1.f, 4, "cleaf1.f");
+ Tester.checkEqual(c1.f, 4, "c1.f");
+
+ Tester.checkEqual(c1.getF(), 4, "c1.getF()");
+ }
+}
+
+interface I1 { }
+interface I11 extends I1 { }
+interface I111 extends I11 { }
+interface I12 extends I1 { }
+
+class C1 implements I1 { }
+class C11 implements I11 { }
+class C111 implements I111 { }
+class C12 implements I12 { }
+
+class Cleaf1 extends C1 { }
+class Cleaf11 extends C11 { }
+class Cleaf111 extends C111 { }
+class Cleaf12 extends C12 { }
+
+// For this class structure: here is the "directly implements" relation
+// C1 directly implements I1
+// C11 directly implements I11
+// C11 directly implements I1
+// C111 directly implements I111
+// C111 directly implements I11
+// C111 directly implements I1
+// C12 directly implements I12
+// C12 directly implements I1
+
+
+
+// introducing a bunch of variables (almost all non-static).
+aspect A1 {
+
+ // Variable Introductions:
+ // without initializer X designator is interface
+ // with initializer X designator is class
+
+ // with initializer, interface also has the two cases of presence or
+ // absence of the modifiers.
+
+ // introduce on initializer without initializer
+ // should introduce into:
+ // C1, C11, C111, C12
+ int I1.a;
+
+ // introduce on interface with initializer but no Mods
+ // should introduce into:
+ // C1, C11, C111, C12
+ int I1.d = 1;
+
+ // introduce on interface with initializer and Mods
+ // should introduce into:
+ // I1
+ public static final int I1.c = 5;
+
+ // introduce on class
+ // should introduce into
+ // C1
+ int C1.b;
+ int C1.e = 2;
+
+ // introduce on class with static modifier
+ // should introduce into
+ // C1
+ static int C1.f = 2;
+
+ int C1.getF() { return 2; }
+}
+
+aspect A2 {
+ declare precedence: A2, A1;
+
+ int around() : set(int C1.f) && within(A1) {
+ return C1.f = 3;
+ }
+
+ after (): staticinitialization(C1) {
+ C1.f = 4;
+ }
+
+ // this should override the introduction from A1
+ int C1.getF() { return 4; }
+}
diff --git a/tests/knownLimitations/test117/Readme.txt b/tests/knownLimitations/test117/Readme.txt
new file mode 100644
index 000000000..51d75a7c3
--- /dev/null
+++ b/tests/knownLimitations/test117/Readme.txt
@@ -0,0 +1,12 @@
+Mode: vm run
+Title: introduce of variables
+
+This tests if variable introductions happen at all the places that
+they are supposed to happen in the presence of interfaces,
+subinterfaces, classes and inheritance. It tests rule 2 partly, (the
+non-error causing cases only).
+
+It DOES NOT test if variable introductions do not happen at all the
+places they should not happen. (That will be a separate test.)
+
+