mirror of
https://github.com/jlengrand/kotlin.git
synced 2026-05-08 08:31:26 +00:00
Use properties of Java annotations in codegen tests
Retain obsolete versions until support for methods in Java annotations is dropped
This commit is contained in:
@@ -5,21 +5,21 @@ JavaAnn(*array()) class MyClass4
|
||||
|
||||
|
||||
fun box(): String {
|
||||
val value1 = javaClass<MyClass1>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
val value1 = javaClass<MyClass1>().getAnnotation(javaClass<JavaAnn>()).value
|
||||
if (value1.size() != 2) return "fail1: ${value1.size()}"
|
||||
if (value1[0] != "d1") return "fail2: ${value1[0]}"
|
||||
if (value1[1] != "d2") return "fail3: ${value1[1]}"
|
||||
|
||||
val value2 = javaClass<MyClass2>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
val value2 = javaClass<MyClass2>().getAnnotation(javaClass<JavaAnn>()).value
|
||||
if (value2.size() != 2) return "fail4: ${value2.size()}"
|
||||
if (value2[0] != "d1") return "fail5: ${value2[0]}"
|
||||
if (value2[1] != "d2") return "fail6: ${value2[1]}"
|
||||
|
||||
val value3 = javaClass<MyClass3>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
val value3 = javaClass<MyClass3>().getAnnotation(javaClass<JavaAnn>()).value
|
||||
if (value3.size() != 1) return "fail7: ${value3.size()}"
|
||||
if (value3[0] != "asd") return "fail8: ${value3[0]}"
|
||||
|
||||
val value4 = javaClass<MyClass4>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
val value4 = javaClass<MyClass4>().getAnnotation(javaClass<JavaAnn>()).value
|
||||
if (value4.size() != 0) return "fail 9: ${value4.size()}"
|
||||
|
||||
return "OK"
|
||||
|
||||
@@ -5,17 +5,17 @@ JavaAnn(*array()) class MyClass4
|
||||
|
||||
|
||||
fun box(): String {
|
||||
val value1 = javaClass<MyClass1>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
val value1 = javaClass<MyClass1>().getAnnotation(javaClass<JavaAnn>()).value
|
||||
if (value1.size() != 0) return "fail1: ${value1.size()}"
|
||||
|
||||
val value2 = javaClass<MyClass2>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
val value2 = javaClass<MyClass2>().getAnnotation(javaClass<JavaAnn>()).value
|
||||
if (value2.size() != 0) return "fail2: ${value2.size()}"
|
||||
|
||||
val value3 = javaClass<MyClass3>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
val value3 = javaClass<MyClass3>().getAnnotation(javaClass<JavaAnn>()).value
|
||||
if (value3.size() != 1) return "fail3: ${value3.size()}"
|
||||
if (value3[0] != "asd") return "fail4: ${value3[0]}"
|
||||
|
||||
val value4 = javaClass<MyClass4>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
val value4 = javaClass<MyClass4>().getAnnotation(javaClass<JavaAnn>()).value
|
||||
if (value4.size() != 0) return "fail 5: ${value4.size()}"
|
||||
|
||||
return "OK"
|
||||
|
||||
@@ -3,6 +3,6 @@ JavaAnn("value") class MyClass
|
||||
fun box(): String {
|
||||
val ann = javaClass<MyClass>().getAnnotation(javaClass<JavaAnn>())
|
||||
if (ann == null) return "fail: cannot find Ann on MyClass}"
|
||||
if (ann.value() != "value") return "fail: annotation parameter i should be 'value', but was ${ann.value()}"
|
||||
if (ann.value != "value") return "fail: annotation parameter i should be 'value', but was ${ann.value}"
|
||||
return "OK"
|
||||
}
|
||||
|
||||
@@ -4,17 +4,17 @@ JavaAnn2 class MyClass2
|
||||
fun box(): String {
|
||||
val ann = javaClass<MyClass>().getAnnotation(javaClass<JavaAnn>())
|
||||
if (ann == null) return "fail: cannot find Ann on MyClass}"
|
||||
if (ann.value() != "default") return "fail: annotation parameter i should be 'default', but was ${ann.value()}"
|
||||
if (ann.value != "default") return "fail: annotation parameter i should be 'default', but was ${ann.value}"
|
||||
|
||||
val ann2 = javaClass<MyClass2>().getAnnotation(javaClass<JavaAnn2>())
|
||||
if (ann2 == null) return "fail: cannot find Ann on MyClass}"
|
||||
if (ann2.a() != 1) return "fail for a: expected = 1, but was ${ann2.a()}"
|
||||
if (ann2.b() != 1.toByte()) return "fail for b: expected = 1, but was ${ann2.b()}"
|
||||
if (ann2.c() != 1.toShort()) return "fail for c: expected = 1, but was ${ann2.c()}"
|
||||
if (ann2.d() != 1.0) return "fail for d: expected = 1, but was ${ann2.d()}"
|
||||
if (ann2.e() != 1F) return "fail for e: expected = 1, but was ${ann2.e()}"
|
||||
if (ann2.j() != 1L) return "fail for j: expected = 1, but was ${ann2.j()}"
|
||||
if (ann2.f() != "default") return "fail for f: expected = default, but was ${ann2.f()}"
|
||||
if (ann2.a != 1) return "fail for a: expected = 1, but was ${ann2.a}"
|
||||
if (ann2.b != 1.toByte()) return "fail for b: expected = 1, but was ${ann2.b}"
|
||||
if (ann2.c != 1.toShort()) return "fail for c: expected = 1, but was ${ann2.c}"
|
||||
if (ann2.d != 1.0) return "fail for d: expected = 1, but was ${ann2.d}"
|
||||
if (ann2.e != 1F) return "fail for e: expected = 1, but was ${ann2.e}"
|
||||
if (ann2.j != 1L) return "fail for j: expected = 1, but was ${ann2.j}"
|
||||
if (ann2.f != "default") return "fail for f: expected = default, but was ${ann2.f}"
|
||||
|
||||
return "OK"
|
||||
}
|
||||
|
||||
@@ -6,5 +6,5 @@ JavaAnn(OK::class) class MyClass
|
||||
fun box(): String {
|
||||
val ann = javaClass<MyClass>().getAnnotation(javaClass<JavaAnn>())
|
||||
if (ann == null) return "fail: cannot find JavaAnn on MyClass"
|
||||
return ann.value().simpleName!!
|
||||
return ann.value.simpleName!!
|
||||
}
|
||||
|
||||
@@ -2,5 +2,5 @@
|
||||
fun box(): String {
|
||||
val ann = javaClass<MyJavaClass>().getAnnotation(javaClass<JavaAnn>())
|
||||
if (ann == null) return "fail: cannot find JavaAnn on MyClass"
|
||||
return ann.value().simpleName!!
|
||||
return ann.value.simpleName!!
|
||||
}
|
||||
|
||||
@@ -4,7 +4,7 @@ class K
|
||||
JavaAnn(O::class, K::class) class MyClass
|
||||
|
||||
fun box(): String {
|
||||
val args = javaClass<MyClass>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
val args = javaClass<MyClass>().getAnnotation(javaClass<JavaAnn>()).value
|
||||
val argName1 = args[0].simpleName ?: "fail 1"
|
||||
val argName2 = args[1].simpleName ?: "fail 2"
|
||||
return argName1 + argName2
|
||||
|
||||
@@ -2,7 +2,7 @@ class O
|
||||
class K
|
||||
|
||||
fun box(): String {
|
||||
val args = javaClass<MyJavaClass>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
val args = javaClass<MyJavaClass>().getAnnotation(javaClass<JavaAnn>()).value
|
||||
val argName1 = args[0].simpleName ?: "fail 1"
|
||||
val argName2 = args[1].simpleName ?: "fail 2"
|
||||
return argName1 + argName2
|
||||
|
||||
@@ -0,0 +1,7 @@
|
||||
import java.lang.annotation.Retention;
|
||||
import java.lang.annotation.RetentionPolicy;
|
||||
|
||||
@Retention(RetentionPolicy.RUNTIME)
|
||||
@interface JavaAnn {
|
||||
String[] value() default {"d1", "d2"};
|
||||
}
|
||||
@@ -0,0 +1,26 @@
|
||||
JavaAnn class MyClass1
|
||||
JavaAnn() class MyClass2
|
||||
JavaAnn("asd") class MyClass3
|
||||
JavaAnn(*array()) class MyClass4
|
||||
|
||||
|
||||
fun box(): String {
|
||||
val value1 = javaClass<MyClass1>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
if (value1.size() != 2) return "fail1: ${value1.size()}"
|
||||
if (value1[0] != "d1") return "fail2: ${value1[0]}"
|
||||
if (value1[1] != "d2") return "fail3: ${value1[1]}"
|
||||
|
||||
val value2 = javaClass<MyClass2>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
if (value2.size() != 2) return "fail4: ${value2.size()}"
|
||||
if (value2[0] != "d1") return "fail5: ${value2[0]}"
|
||||
if (value2[1] != "d2") return "fail6: ${value2[1]}"
|
||||
|
||||
val value3 = javaClass<MyClass3>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
if (value3.size() != 1) return "fail7: ${value3.size()}"
|
||||
if (value3[0] != "asd") return "fail8: ${value3[0]}"
|
||||
|
||||
val value4 = javaClass<MyClass4>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
if (value4.size() != 0) return "fail 9: ${value4.size()}"
|
||||
|
||||
return "OK"
|
||||
}
|
||||
@@ -0,0 +1,7 @@
|
||||
import java.lang.annotation.Retention;
|
||||
import java.lang.annotation.RetentionPolicy;
|
||||
|
||||
@Retention(RetentionPolicy.RUNTIME)
|
||||
@interface JavaAnn {
|
||||
String[] value();
|
||||
}
|
||||
@@ -0,0 +1,22 @@
|
||||
JavaAnn class MyClass1
|
||||
JavaAnn() class MyClass2
|
||||
JavaAnn("asd") class MyClass3
|
||||
JavaAnn(*array()) class MyClass4
|
||||
|
||||
|
||||
fun box(): String {
|
||||
val value1 = javaClass<MyClass1>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
if (value1.size() != 0) return "fail1: ${value1.size()}"
|
||||
|
||||
val value2 = javaClass<MyClass2>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
if (value2.size() != 0) return "fail2: ${value2.size()}"
|
||||
|
||||
val value3 = javaClass<MyClass3>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
if (value3.size() != 1) return "fail3: ${value3.size()}"
|
||||
if (value3[0] != "asd") return "fail4: ${value3[0]}"
|
||||
|
||||
val value4 = javaClass<MyClass4>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
if (value4.size() != 0) return "fail 5: ${value4.size()}"
|
||||
|
||||
return "OK"
|
||||
}
|
||||
@@ -0,0 +1,7 @@
|
||||
import java.lang.annotation.Retention;
|
||||
import java.lang.annotation.RetentionPolicy;
|
||||
|
||||
@Retention(RetentionPolicy.RUNTIME)
|
||||
@interface JavaAnn {
|
||||
String value();
|
||||
}
|
||||
@@ -0,0 +1,8 @@
|
||||
JavaAnn("value") class MyClass
|
||||
|
||||
fun box(): String {
|
||||
val ann = javaClass<MyClass>().getAnnotation(javaClass<JavaAnn>())
|
||||
if (ann == null) return "fail: cannot find Ann on MyClass}"
|
||||
if (ann.value() != "value") return "fail: annotation parameter i should be 'value', but was ${ann.value()}"
|
||||
return "OK"
|
||||
}
|
||||
@@ -0,0 +1,18 @@
|
||||
import java.lang.annotation.Retention;
|
||||
import java.lang.annotation.RetentionPolicy;
|
||||
|
||||
@Retention(RetentionPolicy.RUNTIME)
|
||||
@interface JavaAnn {
|
||||
String value() default "default";
|
||||
}
|
||||
|
||||
@Retention(RetentionPolicy.RUNTIME)
|
||||
@interface JavaAnn2 {
|
||||
int a() default 1;
|
||||
byte b() default 1;
|
||||
short c() default 1;
|
||||
double d() default 1;
|
||||
float e() default 1;
|
||||
long j() default 1;
|
||||
String f() default "default";
|
||||
}
|
||||
@@ -0,0 +1,20 @@
|
||||
JavaAnn class MyClass
|
||||
JavaAnn2 class MyClass2
|
||||
|
||||
fun box(): String {
|
||||
val ann = javaClass<MyClass>().getAnnotation(javaClass<JavaAnn>())
|
||||
if (ann == null) return "fail: cannot find Ann on MyClass}"
|
||||
if (ann.value() != "default") return "fail: annotation parameter i should be 'default', but was ${ann.value()}"
|
||||
|
||||
val ann2 = javaClass<MyClass2>().getAnnotation(javaClass<JavaAnn2>())
|
||||
if (ann2 == null) return "fail: cannot find Ann on MyClass}"
|
||||
if (ann2.a() != 1) return "fail for a: expected = 1, but was ${ann2.a()}"
|
||||
if (ann2.b() != 1.toByte()) return "fail for b: expected = 1, but was ${ann2.b()}"
|
||||
if (ann2.c() != 1.toShort()) return "fail for c: expected = 1, but was ${ann2.c()}"
|
||||
if (ann2.d() != 1.0) return "fail for d: expected = 1, but was ${ann2.d()}"
|
||||
if (ann2.e() != 1F) return "fail for e: expected = 1, but was ${ann2.e()}"
|
||||
if (ann2.j() != 1L) return "fail for j: expected = 1, but was ${ann2.j()}"
|
||||
if (ann2.f() != "default") return "fail for f: expected = default, but was ${ann2.f()}"
|
||||
|
||||
return "OK"
|
||||
}
|
||||
@@ -0,0 +1,7 @@
|
||||
import java.lang.annotation.Retention;
|
||||
import java.lang.annotation.RetentionPolicy;
|
||||
|
||||
@Retention(RetentionPolicy.RUNTIME)
|
||||
@interface JavaAnn {
|
||||
Class<?>[] args();
|
||||
}
|
||||
@@ -0,0 +1,11 @@
|
||||
class O
|
||||
class K
|
||||
|
||||
JavaAnn(args = array(O::class, K::class)) class MyClass
|
||||
|
||||
fun box(): String {
|
||||
val args = javaClass<MyClass>().getAnnotation(javaClass<JavaAnn>()).args()
|
||||
val argName1 = args[0].simpleName ?: "fail 1"
|
||||
val argName2 = args[1].simpleName ?: "fail 2"
|
||||
return argName1 + argName2
|
||||
}
|
||||
@@ -0,0 +1,13 @@
|
||||
import java.lang.annotation.Retention;
|
||||
import java.lang.annotation.RetentionPolicy;
|
||||
|
||||
@Retention(RetentionPolicy.RUNTIME)
|
||||
@interface JavaAnn {
|
||||
Class<?>[] args();
|
||||
}
|
||||
|
||||
class O {}
|
||||
class K {}
|
||||
|
||||
@JavaAnn(args = {O.class, K.class})
|
||||
class MyJavaClass {}
|
||||
@@ -0,0 +1,6 @@
|
||||
fun box(): String {
|
||||
val args = javaClass<MyJavaClass>().getAnnotation(javaClass<JavaAnn>()).args()
|
||||
val argName1 = args[0].simpleName ?: "fail 1"
|
||||
val argName2 = args[1].simpleName ?: "fail 2"
|
||||
return argName1 + argName2
|
||||
}
|
||||
@@ -0,0 +1,7 @@
|
||||
import java.lang.annotation.Retention;
|
||||
import java.lang.annotation.RetentionPolicy;
|
||||
|
||||
@Retention(RetentionPolicy.RUNTIME)
|
||||
@interface JavaAnn {
|
||||
Class<?> value();
|
||||
}
|
||||
@@ -0,0 +1,10 @@
|
||||
|
||||
class OK
|
||||
|
||||
JavaAnn(OK::class) class MyClass
|
||||
|
||||
fun box(): String {
|
||||
val ann = javaClass<MyClass>().getAnnotation(javaClass<JavaAnn>())
|
||||
if (ann == null) return "fail: cannot find JavaAnn on MyClass"
|
||||
return ann.value().simpleName!!
|
||||
}
|
||||
@@ -0,0 +1,12 @@
|
||||
import java.lang.annotation.Retention;
|
||||
import java.lang.annotation.RetentionPolicy;
|
||||
|
||||
@Retention(RetentionPolicy.RUNTIME)
|
||||
@interface JavaAnn {
|
||||
Class<?> value();
|
||||
}
|
||||
|
||||
class OK {}
|
||||
|
||||
@JavaAnn(OK.class)
|
||||
class MyJavaClass {}
|
||||
@@ -0,0 +1,6 @@
|
||||
|
||||
fun box(): String {
|
||||
val ann = javaClass<MyJavaClass>().getAnnotation(javaClass<JavaAnn>())
|
||||
if (ann == null) return "fail: cannot find JavaAnn on MyClass"
|
||||
return ann.value().simpleName!!
|
||||
}
|
||||
@@ -0,0 +1,7 @@
|
||||
import java.lang.annotation.Retention;
|
||||
import java.lang.annotation.RetentionPolicy;
|
||||
|
||||
@Retention(RetentionPolicy.RUNTIME)
|
||||
@interface JavaAnn {
|
||||
Class<?>[] value();
|
||||
}
|
||||
@@ -0,0 +1,11 @@
|
||||
class O
|
||||
class K
|
||||
|
||||
JavaAnn(O::class, K::class) class MyClass
|
||||
|
||||
fun box(): String {
|
||||
val args = javaClass<MyClass>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
val argName1 = args[0].simpleName ?: "fail 1"
|
||||
val argName2 = args[1].simpleName ?: "fail 2"
|
||||
return argName1 + argName2
|
||||
}
|
||||
@@ -0,0 +1,13 @@
|
||||
import java.lang.annotation.Retention;
|
||||
import java.lang.annotation.RetentionPolicy;
|
||||
|
||||
@Retention(RetentionPolicy.RUNTIME)
|
||||
@interface JavaAnn {
|
||||
Class<?>[] value();
|
||||
}
|
||||
|
||||
class O {}
|
||||
class K {}
|
||||
|
||||
@JavaAnn({O.class, K.class})
|
||||
class MyJavaClass {}
|
||||
@@ -0,0 +1,9 @@
|
||||
class O
|
||||
class K
|
||||
|
||||
fun box(): String {
|
||||
val args = javaClass<MyJavaClass>().getAnnotation(javaClass<JavaAnn>()).value()
|
||||
val argName1 = args[0].simpleName ?: "fail 1"
|
||||
val argName2 = args[1].simpleName ?: "fail 2"
|
||||
return argName1 + argName2
|
||||
}
|
||||
Reference in New Issue
Block a user