summaryrefslogtreecommitdiffstats
path: root/tests/java5/ataspectj/annotationGen/DeclareAnnotationTest.aj
diff options
context:
space:
mode:
authoracolyer <acolyer>2005-10-03 16:17:15 +0000
committeracolyer <acolyer>2005-10-03 16:17:15 +0000
commit0fae66242efd3fd91dc7ace349cdcf7e5ebc2ade (patch)
tree85dda17da70b10b31b422853d1323421a82b3a21 /tests/java5/ataspectj/annotationGen/DeclareAnnotationTest.aj
parentc86fa6de889e521ebe8224d1a7579269c53ac357 (diff)
downloadaspectj-0fae66242efd3fd91dc7ace349cdcf7e5ebc2ade.tar.gz
aspectj-0fae66242efd3fd91dc7ace349cdcf7e5ebc2ade.zip
completes all of the MAP bar ITDs
Diffstat (limited to 'tests/java5/ataspectj/annotationGen/DeclareAnnotationTest.aj')
-rw-r--r--tests/java5/ataspectj/annotationGen/DeclareAnnotationTest.aj77
1 files changed, 77 insertions, 0 deletions
diff --git a/tests/java5/ataspectj/annotationGen/DeclareAnnotationTest.aj b/tests/java5/ataspectj/annotationGen/DeclareAnnotationTest.aj
new file mode 100644
index 000000000..0c3e4608d
--- /dev/null
+++ b/tests/java5/ataspectj/annotationGen/DeclareAnnotationTest.aj
@@ -0,0 +1,77 @@
+import org.aspectj.lang.reflect.*;
+import java.lang.reflect.*;
+import java.lang.annotation.*;
+
+public aspect DeclareAnnotationTest {
+
+ declare @type : a.b.c..* : @MyAnnotation("ady 1");
+
+ declare @method : * *(String) : @MyAnnotation("ady 2");
+
+ declare @field : java.io.Serializable+ * : @MyClassRetentionAnnotation("ady 3");
+
+ declare @constructor : new(String,..) : @MyAnnotation;
+
+ public static void main(String[] args) throws ClassNotFoundException {
+ AjType<DeclareAnnotationTest> myType = AjTypeSystem.getAjType(DeclareAnnotationTest.class);
+ DeclareAnnotation[] decAs = myType.getDeclareAnnotations();
+ if (decAs.length != 4) throw new RuntimeException("Expecting 4 members, got " + decAs.length);
+ // should be in declaration order...
+ checkAtType(decAs[0]);
+ checkAtMethod(decAs[1]);
+ checkAtField(decAs[2]);
+ checkAtConstructor(decAs[3]);
+ }
+
+
+ private static void checkAtType(DeclareAnnotation da) {
+ if (da.getKind() != DeclareAnnotation.Kind.Type) throw new RuntimeException("expecting @type");
+ if (da.getSignaturePattern() != null) throw new RuntimeException("not expecting a signature pattern");
+ if (!da.getTypePattern().asString().equals("a.b.c..*")) throw new RuntimeException("expecting 'a.b.c..*' but got '" + da.getTypePattern().asString() + "'");
+ if (da.getDeclaringType().getJavaClass() != DeclareAnnotationTest.class) throw new RuntimeException("bad declaring type: " + da.getDeclaringType());
+ MyAnnotation ma = (MyAnnotation) da.getAnnotation();
+ if (!ma.value().equals("ady 1")) throw new RuntimeException("bad value: " + ma.value());
+ if (!da.getAnnotationAsText().equals("@MyAnnotation(\"ady 1\")")) throw new RuntimeException("bad annotation text: " + da.getAnnotationAsText());
+ }
+
+ private static void checkAtMethod(DeclareAnnotation da) {
+ if (da.getKind() != DeclareAnnotation.Kind.Method) throw new RuntimeException("expecting @method");
+ if (da.getTypePattern() != null) throw new RuntimeException("not expecting a type pattern");
+ if (!da.getSignaturePattern().asString().equals("* *(java.lang.String)")) throw new RuntimeException("expecting '* *(java.lang.String)' but got '" + da.getSignaturePattern().asString() + "'");
+ if (da.getDeclaringType().getJavaClass() != DeclareAnnotationTest.class) throw new RuntimeException("bad declaring type: " + da.getDeclaringType());
+ MyAnnotation ma = (MyAnnotation) da.getAnnotation();
+ if (!ma.value().equals("ady 2")) throw new RuntimeException("bad value: " + ma.value());
+ if (!da.getAnnotationAsText().equals("@MyAnnotation(\"ady 2\")")) throw new RuntimeException("bad annotation text: " + da.getAnnotationAsText());
+ }
+
+ private static void checkAtField(DeclareAnnotation da) {
+ if (da.getKind() != DeclareAnnotation.Kind.Field) throw new RuntimeException("expecting @field");
+ if (da.getTypePattern() != null) throw new RuntimeException("not expecting a type pattern");
+ if (!da.getSignaturePattern().asString().equals("java.io.Serializable+ *")) throw new RuntimeException("expecting 'java.io.Serializable+ *' but got '" + da.getSignaturePattern().asString() + "'");
+ if (da.getDeclaringType().getJavaClass() != DeclareAnnotationTest.class) throw new RuntimeException("bad declaring type: " + da.getDeclaringType());
+ if (da.getAnnotation() != null) throw new RuntimeException("expecting null annotation, but got " + da.getAnnotation());
+ if (!da.getAnnotationAsText().equals("@MyClassRetentionAnnotation(\"ady 3\")")) throw new RuntimeException("bad annotation text: " + da.getAnnotationAsText());
+ }
+
+ private static void checkAtConstructor(DeclareAnnotation da) {
+ if (da.getKind() != DeclareAnnotation.Kind.Constructor) throw new RuntimeException("expecting @constructor");
+ if (da.getTypePattern() != null) throw new RuntimeException("not expecting a type pattern");
+ if (!da.getSignaturePattern().asString().equals("new(java.lang.String, ..)")) throw new RuntimeException("expecting 'new(java.lang.String,..)' but got '" + da.getSignaturePattern().asString() + "'");
+ if (da.getDeclaringType().getJavaClass() != DeclareAnnotationTest.class) throw new RuntimeException("bad declaring type: " + da.getDeclaringType());
+ MyAnnotation ma = (MyAnnotation) da.getAnnotation();
+ if (!ma.value().equals("some value")) throw new RuntimeException("bad value: " + ma.value());
+ if (!da.getAnnotationAsText().equals("@MyAnnotation")) throw new RuntimeException("bad annotation text: " + da.getAnnotationAsText());
+ }
+
+}
+
+@Retention(RetentionPolicy.RUNTIME)
+@interface MyAnnotation {
+
+ String value() default "some value";
+
+}
+
+@interface MyClassRetentionAnnotation {
+ String value();
+}