c7435ba760
We are going to deprecate `WITH_RUNTIME` directive. The main reason behind this change is that `WITH_STDLIB` directive better describes its meaning, specifically it will add kotlin stdlib to test's classpath.
42 lines
956 B
Kotlin
Vendored
42 lines
956 B
Kotlin
Vendored
// FULL_JDK
|
|
// WITH_STDLIB
|
|
// TARGET_BACKEND: JVM
|
|
// ASSERTIONS_MODE: jvm
|
|
// FILE: inline.kt
|
|
|
|
package test
|
|
|
|
inline fun inlineMe() {
|
|
assert(false) { "FROM INLINED" }
|
|
}
|
|
|
|
// FILE: inlineSite.kt
|
|
|
|
import test.*
|
|
|
|
class CheckerJvmAssertInlineFunctionAssertionsEnabled {
|
|
fun check() {
|
|
inlineMe()
|
|
throw RuntimeException("FAIL 0")
|
|
}
|
|
}
|
|
|
|
class Dummy
|
|
|
|
fun enableAssertions(): CheckerJvmAssertInlineFunctionAssertionsEnabled {
|
|
val loader = Dummy::class.java.classLoader
|
|
loader.setClassAssertionStatus("CheckerJvmAssertInlineFunctionAssertionsEnabled", true)
|
|
loader.setClassAssertionStatus("InlineKt", false)
|
|
val c = loader.loadClass("CheckerJvmAssertInlineFunctionAssertionsEnabled")
|
|
return c.newInstance() as CheckerJvmAssertInlineFunctionAssertionsEnabled
|
|
}
|
|
|
|
fun box(): String {
|
|
var c = enableAssertions()
|
|
try {
|
|
c.check()
|
|
return "FAIL 2"
|
|
} catch (ignore: AssertionError) {}
|
|
return "OK"
|
|
}
|