[tests] Add test data for KT-63840
This commit is contained in:
committed by
Space Team
parent
2bcaa3eb8f
commit
4f38d77fae
@@ -0,0 +1,36 @@
|
||||
// ISSUE: KT-63840
|
||||
// WITH_STDLIB
|
||||
|
||||
// IGNORE_LIGHT_ANALYSIS
|
||||
// IGNORE_BACKEND_K1: ANY
|
||||
// REASON: red code (see corresponding diagnostic test)
|
||||
|
||||
// IGNORE_BACKEND_K2: JVM_IR, WASM
|
||||
// REASON: run-time failure (java.lang.ArrayStoreException: TargetType @ Kt63840aKt$box$1.invoke)
|
||||
|
||||
fun box(): String {
|
||||
build {
|
||||
select(
|
||||
replaceTypeVariable(TargetType()),
|
||||
DifferentType()
|
||||
)
|
||||
}
|
||||
return "OK"
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
fun <T> select(vararg values: T): T = values.first()
|
||||
|
||||
class TargetType
|
||||
class DifferentType
|
||||
|
||||
class Buildee<TV> {
|
||||
fun replaceTypeVariable(value: TV): TV { val temp = storage; storage = value; return temp }
|
||||
private var storage: TV = TargetType() as TV
|
||||
}
|
||||
|
||||
fun <PTV> build(instructions: Buildee<PTV>.() -> Unit): Buildee<PTV> {
|
||||
return Buildee<PTV>().apply(instructions)
|
||||
}
|
||||
@@ -0,0 +1,33 @@
|
||||
// ISSUE: KT-63840
|
||||
|
||||
// IGNORE_LIGHT_ANALYSIS
|
||||
// IGNORE_BACKEND_K1: ANY
|
||||
// REASON: red code (see corresponding diagnostic test)
|
||||
|
||||
// IGNORE_BACKEND_K2: JVM_IR
|
||||
// REASON: run-time failure (java.lang.ClassCastException: TargetType cannot be cast to DifferentType @ Kt63840bKt$box$1.invoke)
|
||||
|
||||
fun box(): String {
|
||||
build {
|
||||
if (true)
|
||||
replaceTypeVariable(TargetType())
|
||||
else
|
||||
DifferentType()
|
||||
}
|
||||
return "OK"
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
class TargetType
|
||||
class DifferentType
|
||||
|
||||
class Buildee<TV> {
|
||||
fun replaceTypeVariable(value: TV): TV { val temp = storage; storage = value; return temp }
|
||||
private var storage: TV = TargetType() as TV
|
||||
}
|
||||
|
||||
fun <PTV> build(instructions: Buildee<PTV>.() -> Unit): Buildee<PTV> {
|
||||
return Buildee<PTV>().apply(instructions)
|
||||
}
|
||||
@@ -0,0 +1,33 @@
|
||||
// ISSUE: KT-63840
|
||||
|
||||
// IGNORE_LIGHT_ANALYSIS
|
||||
// IGNORE_BACKEND_K1: ANY
|
||||
// REASON: red code (see corresponding diagnostic test)
|
||||
|
||||
// IGNORE_BACKEND_K2: JVM_IR
|
||||
// REASON: run-time failure (java.lang.ClassCastException: TargetType cannot be cast to DifferentType @ Kt63840cKt$box$1.invoke)
|
||||
|
||||
fun box(): String {
|
||||
build {
|
||||
when {
|
||||
true -> replaceTypeVariable(TargetType())
|
||||
else -> DifferentType()
|
||||
}
|
||||
}
|
||||
return "OK"
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
class TargetType
|
||||
class DifferentType
|
||||
|
||||
class Buildee<TV> {
|
||||
fun replaceTypeVariable(value: TV): TV { val temp = storage; storage = value; return temp }
|
||||
private var storage: TV = TargetType() as TV
|
||||
}
|
||||
|
||||
fun <PTV> build(instructions: Buildee<PTV>.() -> Unit): Buildee<PTV> {
|
||||
return Buildee<PTV>().apply(instructions)
|
||||
}
|
||||
@@ -0,0 +1,32 @@
|
||||
// ISSUE: KT-63840
|
||||
// CHECK_TYPE_WITH_EXACT
|
||||
// WITH_STDLIB
|
||||
|
||||
fun test() {
|
||||
val buildee = build {
|
||||
select(
|
||||
replaceTypeVariable(TargetType()),
|
||||
DifferentType()
|
||||
)
|
||||
}
|
||||
// exact type equality check — turns unexpected compile-time behavior into red code
|
||||
// considered to be non-user-reproducible code for the purposes of these tests
|
||||
checkExactType<Buildee<TargetType>>(buildee)
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
fun <T> select(vararg values: T): T = values.first()
|
||||
|
||||
class TargetType
|
||||
class DifferentType
|
||||
|
||||
class Buildee<TV> {
|
||||
fun replaceTypeVariable(value: TV): TV { val temp = storage; storage = value; return temp }
|
||||
private var storage: TV = null!!
|
||||
}
|
||||
|
||||
fun <PTV> build(instructions: Buildee<PTV>.() -> Unit): Buildee<PTV> {
|
||||
return Buildee<PTV>().apply(instructions)
|
||||
}
|
||||
@@ -0,0 +1,32 @@
|
||||
// ISSUE: KT-63840
|
||||
// CHECK_TYPE_WITH_EXACT
|
||||
// WITH_STDLIB
|
||||
|
||||
fun test() {
|
||||
val buildee = build {
|
||||
select(
|
||||
<!TYPE_MISMATCH("DifferentType; TargetType"), TYPE_MISMATCH("DifferentType; TargetType")!>replaceTypeVariable(TargetType())<!>,
|
||||
DifferentType()
|
||||
)
|
||||
}
|
||||
// exact type equality check — turns unexpected compile-time behavior into red code
|
||||
// considered to be non-user-reproducible code for the purposes of these tests
|
||||
checkExactType<Buildee<TargetType>>(buildee)
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
fun <T> select(vararg values: T): T = values.first()
|
||||
|
||||
class TargetType
|
||||
class DifferentType
|
||||
|
||||
class Buildee<TV> {
|
||||
fun replaceTypeVariable(value: TV): TV { val temp = storage; storage = value; return temp }
|
||||
private var storage: TV = null!!
|
||||
}
|
||||
|
||||
fun <PTV> build(instructions: Buildee<PTV>.() -> Unit): Buildee<PTV> {
|
||||
return Buildee<PTV>().apply(instructions)
|
||||
}
|
||||
@@ -0,0 +1,29 @@
|
||||
// ISSUE: KT-63840
|
||||
// CHECK_TYPE_WITH_EXACT
|
||||
|
||||
fun test() {
|
||||
val buildee = build {
|
||||
if (true)
|
||||
replaceTypeVariable(TargetType())
|
||||
else
|
||||
DifferentType()
|
||||
}
|
||||
// exact type equality check — turns unexpected compile-time behavior into red code
|
||||
// considered to be non-user-reproducible code for the purposes of these tests
|
||||
checkExactType<Buildee<TargetType>>(buildee)
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
class TargetType
|
||||
class DifferentType
|
||||
|
||||
class Buildee<TV> {
|
||||
fun replaceTypeVariable(value: TV): TV { val temp = storage; storage = value; return temp }
|
||||
private var storage: TV = null!!
|
||||
}
|
||||
|
||||
fun <PTV> build(instructions: Buildee<PTV>.() -> Unit): Buildee<PTV> {
|
||||
return Buildee<PTV>().apply(instructions)
|
||||
}
|
||||
@@ -0,0 +1,29 @@
|
||||
// ISSUE: KT-63840
|
||||
// CHECK_TYPE_WITH_EXACT
|
||||
|
||||
fun test() {
|
||||
val buildee = build {
|
||||
if (true)
|
||||
<!TYPE_MISMATCH("DifferentType; TargetType"), TYPE_MISMATCH("DifferentType; TargetType")!>replaceTypeVariable(TargetType())<!>
|
||||
else
|
||||
DifferentType()
|
||||
}
|
||||
// exact type equality check — turns unexpected compile-time behavior into red code
|
||||
// considered to be non-user-reproducible code for the purposes of these tests
|
||||
checkExactType<Buildee<TargetType>>(buildee)
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
class TargetType
|
||||
class DifferentType
|
||||
|
||||
class Buildee<TV> {
|
||||
fun replaceTypeVariable(value: TV): TV { val temp = storage; storage = value; return temp }
|
||||
private var storage: TV = null!!
|
||||
}
|
||||
|
||||
fun <PTV> build(instructions: Buildee<PTV>.() -> Unit): Buildee<PTV> {
|
||||
return Buildee<PTV>().apply(instructions)
|
||||
}
|
||||
@@ -0,0 +1,29 @@
|
||||
// ISSUE: KT-63840
|
||||
// CHECK_TYPE_WITH_EXACT
|
||||
|
||||
fun test() {
|
||||
val buildee = build {
|
||||
when {
|
||||
true -> replaceTypeVariable(TargetType())
|
||||
else -> DifferentType()
|
||||
}
|
||||
}
|
||||
// exact type equality check — turns unexpected compile-time behavior into red code
|
||||
// considered to be non-user-reproducible code for the purposes of these tests
|
||||
checkExactType<Buildee<TargetType>>(buildee)
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
class TargetType
|
||||
class DifferentType
|
||||
|
||||
class Buildee<TV> {
|
||||
fun replaceTypeVariable(value: TV): TV { val temp = storage; storage = value; return temp }
|
||||
private var storage: TV = null!!
|
||||
}
|
||||
|
||||
fun <PTV> build(instructions: Buildee<PTV>.() -> Unit): Buildee<PTV> {
|
||||
return Buildee<PTV>().apply(instructions)
|
||||
}
|
||||
@@ -0,0 +1,29 @@
|
||||
// ISSUE: KT-63840
|
||||
// CHECK_TYPE_WITH_EXACT
|
||||
|
||||
fun test() {
|
||||
val buildee = build {
|
||||
when {
|
||||
true -> <!TYPE_MISMATCH("DifferentType; TargetType"), TYPE_MISMATCH("DifferentType; TargetType")!>replaceTypeVariable(TargetType())<!>
|
||||
else -> DifferentType()
|
||||
}
|
||||
}
|
||||
// exact type equality check — turns unexpected compile-time behavior into red code
|
||||
// considered to be non-user-reproducible code for the purposes of these tests
|
||||
checkExactType<Buildee<TargetType>>(buildee)
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
class TargetType
|
||||
class DifferentType
|
||||
|
||||
class Buildee<TV> {
|
||||
fun replaceTypeVariable(value: TV): TV { val temp = storage; storage = value; return temp }
|
||||
private var storage: TV = null!!
|
||||
}
|
||||
|
||||
fun <PTV> build(instructions: Buildee<PTV>.() -> Unit): Buildee<PTV> {
|
||||
return Buildee<PTV>().apply(instructions)
|
||||
}
|
||||
Reference in New Issue
Block a user