[tests] Add test data for KT-63840

This commit is contained in:
Stanislav Ruban
2023-12-02 15:29:31 +01:00
committed by Space Team
parent 2bcaa3eb8f
commit 4f38d77fae
9 changed files with 282 additions and 0 deletions
@@ -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)
}