Files
kotlin-fork/compiler/testData/codegen/box/assert/jvm/localObject.kt
T
Ivan Kylchik c7435ba760 Replace all occurrences of WITH_RUNTIME with WITH_STDLIB
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.
2021-11-17 15:26:38 +03:00

159 lines
3.3 KiB
Kotlin
Vendored

// TARGET_BACKEND: JVM
// ASSERTIONS_MODE: jvm
// WITH_STDLIB
package localObject
interface Checker {
fun checkTrue(): Boolean
fun checkFalse(): Boolean
fun checkTrueWithMessage(): Boolean
fun checkFalseWithMessage(): Boolean
}
class ShouldBeDisabled : Checker {
override fun checkTrue(): Boolean {
var hit = false
val l = { hit = true; true }
val local = object {
fun run() {
assert(l())
}
}
local.run()
return hit
}
override fun checkFalse(): Boolean {
var hit = false
val l = { hit = true; false }
val local = object {
fun run() {
assert(l())
}
}
local.run()
return hit
}
override fun checkTrueWithMessage(): Boolean {
var hit = false
val l = { hit = true; true }
val local = object {
fun run() {
assert(l()) { "BOOYA" }
}
}
local.run()
return hit
}
override fun checkFalseWithMessage(): Boolean {
var hit = false
val l = { hit = true; false }
val local = object {
fun run() {
assert(l()) { "BOOYA" }
}
}
local.run()
return hit
}
}
class ShouldBeEnabled : Checker {
override fun checkTrue(): Boolean {
var hit = false
val l = { hit = true; true }
val local = object {
fun run() {
assert(l())
}
}
local.run()
return hit
}
override fun checkFalse(): Boolean {
var hit = false
val l = { hit = true; false }
val local = object {
fun run() {
assert(l())
}
}
local.run()
return hit
}
override fun checkTrueWithMessage(): Boolean {
var hit = false
val l = { hit = true; true }
val local = object {
fun run() {
assert(l()) { "BOOYA" }
}
}
local.run()
return hit
}
override fun checkFalseWithMessage(): Boolean {
var hit = false
val l = { hit = true; false }
val local = object {
fun run() {
assert(l()) { "BOOYA" }
}
}
local.run()
return hit
}
}
fun setDesiredAssertionStatus(v: Boolean): Checker {
val loader = Checker::class.java.classLoader
loader.setPackageAssertionStatus("localObject", v)
val c = loader.loadClass(if (v) "localObject.ShouldBeEnabled" else "localObject.ShouldBeDisabled")
return c.newInstance() as Checker
}
fun box(): String {
var c = setDesiredAssertionStatus(false)
if (c.checkTrue()) return "FAIL 0"
if (c.checkTrueWithMessage()) return "FAIL 1"
if (c.checkFalse()) return "FAIL 2"
if (c.checkFalseWithMessage()) return "FAIL 3"
c = setDesiredAssertionStatus(true)
if (!c.checkTrue()) return "FAIL 4"
if (!c.checkTrueWithMessage()) return "FAIL 5"
try {
c.checkFalse()
return "FAIL 6"
} catch (ignore: AssertionError) {
}
try {
c.checkFalseWithMessage()
return "FAIL 7"
} catch (ignore: AssertionError) {
}
return "OK"
}