mirror of
https://github.com/jlengrand/kotlin.git
synced 2026-05-09 00:21:47 +00:00
Merge boxWithStdlib testData into box, delete BoxWithStdlib test
This commit is contained in:
committed by
Alexander Udalov
parent
22bfc9786a
commit
06a67e6602
45
compiler/testData/codegen/box/reflection/lambdaClasses/parameterNamesAndNullability.kt
vendored
Normal file
45
compiler/testData/codegen/box/reflection/lambdaClasses/parameterNamesAndNullability.kt
vendored
Normal file
@@ -0,0 +1,45 @@
|
||||
// WITH_REFLECT
|
||||
|
||||
import kotlin.reflect.*
|
||||
import kotlin.reflect.jvm.*
|
||||
import kotlin.test.assertEquals
|
||||
import kotlin.test.assertNull
|
||||
|
||||
fun lambda() {
|
||||
val f = { x: Int, y: String? -> }
|
||||
|
||||
val g = f.reflect()!!
|
||||
|
||||
// TODO: maybe change this name
|
||||
assertEquals("<anonymous>", g.name)
|
||||
assertEquals(listOf("x", "y"), g.parameters.map { it.name })
|
||||
assertEquals(listOf(false, true), g.parameters.map { it.type.isMarkedNullable })
|
||||
}
|
||||
|
||||
fun funExpr() {
|
||||
val f = fun(x: Int, y: String?) {}
|
||||
|
||||
val g = f.reflect()!!
|
||||
|
||||
// TODO: maybe change this name
|
||||
assertEquals("<no name provided>", g.name)
|
||||
assertEquals(listOf("x", "y"), g.parameters.map { it.name })
|
||||
assertEquals(listOf(false, true), g.parameters.map { it.type.isMarkedNullable })
|
||||
}
|
||||
|
||||
fun extensionFunExpr() {
|
||||
val f = fun String.(): String = this
|
||||
|
||||
val g = f.reflect()!!
|
||||
|
||||
assertEquals(KParameter.Kind.EXTENSION_RECEIVER, g.parameters.single().kind)
|
||||
assertEquals(null, g.parameters.single().name)
|
||||
}
|
||||
|
||||
fun box(): String {
|
||||
lambda()
|
||||
funExpr()
|
||||
extensionFunExpr()
|
||||
|
||||
return "OK"
|
||||
}
|
||||
Reference in New Issue
Block a user