6e8283a6fe
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
32 lines
696 B
Kotlin
Vendored
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()
|