Files
kotlin-fork/compiler/testData/ir/irText/declarations/annotations/javaAnnotationWithSingleArrayArgument.kt
T
Sergej Jaskiewicz 6e8283a6fe [IR] Dump IdSignatures and mangled names in irText tests
The reason #1 for this feature is that we want to test IdSignatures
generated for declarations. Currently, there is no (easy) way to ensure
that a change in the signature building logic doesn't cause any breaking
changes wrt klibs.

Now, most IdSignatures include hashed mangled names in them, so even if
we catch a regression where the included hash changes, there would be no
way of knowing immediately what caused it, unless we'd also have mangled
names in the expectations.

The reason #2 is to test the manglers themselves. Currently, there are
no tests for them. They heavily duplicate each other, this is already
causing issues (see KT-57427) that would be very hard to catch without
these tests.

^KT-58238 Fixed
2023-05-15 18:20:45 +00:00

32 lines
696 B
Kotlin
Vendored

// SKIP_KT_DUMP
// TARGET_BACKEND: JVM
// SKIP_SIGNATURE_DUMP
// ^ Different types in annotations generated by K1 and K2
// FILE: A.java
public class A {
@Annos(value = @Anno(token = "OK"))
@Strings(value = "OK")
@Ints(value = 42)
@Enums(value = E.EA)
@Classes(value = double.class)
public void test() {}
}
// FILE: C.kt
import kotlin.reflect.KClass
annotation class Anno(val token: String)
enum class E { EA }
annotation class Annos(val value: Array<Anno>)
annotation class Strings(val value: Array<String>)
annotation class Ints(val value: IntArray)
annotation class Enums(val value: Array<E>)
annotation class Classes(val value: Array<KClass<*>>)
class C : A()