From 0681531dc0ac706de137ad29cfd719ba12d83101 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 26 Nov 2013 15:25:39 -0600 Subject: [PATCH] Test complicated annotation constructs Signed-off-by: Johannes Schindelin --- test/Annotations.java | 32 +++++++++++++++++++ .../testing/annotations/TestComplex.java | 14 ++++++++ 2 files changed, 46 insertions(+) create mode 100644 test/avian/testing/annotations/TestComplex.java diff --git a/test/Annotations.java b/test/Annotations.java index 7674e5d6f4..f09b0251eb 100644 --- a/test/Annotations.java +++ b/test/Annotations.java @@ -4,6 +4,7 @@ import java.lang.reflect.Proxy; import avian.testing.annotations.Color; import avian.testing.annotations.Test; +import avian.testing.annotations.TestComplex; import avian.testing.annotations.TestEnum; import avian.testing.annotations.TestInteger; @@ -30,6 +31,7 @@ public class Annotations { expect(noAnno.getAnnotation(Test.class) == null); expect(noAnno.getAnnotations().length == 0); testProxyDefaultValue(); + testComplexAnnotation(); } @Test("couscous") @@ -54,4 +56,34 @@ public class Annotations { Proxy.newProxyInstance(loader, new Class[] { Test.class }, handler); expect("Hello, world!".equals(test.value())); } + + private interface World { + @TestComplex(arrayValue = { @Test, @Test(value = "7/9") }, + stringValue = "adjunct element", charValue = '7', doubleValue = 0.7778, + classValue = TestInteger.class) + int hello(); + } + + private static void testComplexAnnotation(TestComplex annotation) + throws Exception + { + expect(2 == annotation.arrayValue().length); + expect("Hello, world!".equals(annotation.arrayValue()[0].value())); + expect("7/9".equals(annotation.arrayValue()[1].value())); + expect("adjunct element".equals(annotation.stringValue())); + expect('7' == annotation.charValue()); + expect(0.7778 == annotation.doubleValue()); + expect(TestInteger.class == annotation.classValue()); + } + + public static void testComplexAnnotation() throws Exception { + ClassLoader loader = Annotations.class.getClassLoader(); + TestComplex annotation = (TestComplex) + World.class.getMethod("hello").getAnnotation(TestComplex.class); + testComplexAnnotation(annotation); + Class clazz = Proxy.getProxyClass(loader, new Class[] { World.class }); + annotation = (TestComplex) + clazz.getMethod("hello").getAnnotation(TestComplex.class); + expect(annotation == null); + } } diff --git a/test/avian/testing/annotations/TestComplex.java b/test/avian/testing/annotations/TestComplex.java new file mode 100644 index 0000000000..4e271cc9d9 --- /dev/null +++ b/test/avian/testing/annotations/TestComplex.java @@ -0,0 +1,14 @@ +package avian.testing.annotations; + +import java.lang.annotation.Retention; +import java.lang.annotation.RetentionPolicy; + +@Retention(RetentionPolicy.RUNTIME) +public @interface TestComplex { + public Test[] arrayValue(); + public Class classValue(); + public String stringValue(); + public char charValue(); + public double doubleValue(); +} +