Files
kotlin-fork/compiler/testData/codegen/box/ranges/javaInterop/withIndex/javaCollectionOfMaybeNullableWithIndexWithNotNullLoopVariableFailFast.kt
T
2021-11-20 03:37:31 +03:00

37 lines
980 B
Kotlin
Vendored

// !LANGUAGE: +StrictJavaNullabilityAssertions
// TARGET_BACKEND: JVM
// IGNORE_BACKEND: JVM, JVM_IR
// IGNORE_BACKEND_FIR: JVM_IR
// FIR status: not supported in JVM
// WITH_STDLIB
// Note: This fails because explicit types are ignored in destructuring declarations (KT-22392).
// FILE: box.kt
import kotlin.test.*
fun box(): String {
// Sanity check to make sure there IS an exception even when not in a for-loop
try {
val (index, i: Int) = J.listOfMaybeNullable().withIndex().first()
return "Fail: should throw on get()"
} catch (e: IllegalStateException) {}
try {
for ((index, i: Int) in J.listOfMaybeNullable().withIndex()) {
return "Fail: should throw on get() in loop header"
}
}
catch (e: IllegalStateException) {}
return "OK"
}
// FILE: J.java
import java.util.*;
public class J {
public static List<Integer> listOfMaybeNullable() {
return Collections.singletonList(null);
}
}