46 lines
1.4 KiB
Kotlin
46 lines
1.4 KiB
Kotlin
@file:OptIn(kotlin.experimental.ExperimentalNativeApi::class)
|
|
|
|
import kotlin.text.Regex
|
|
import kotlin.test.*
|
|
|
|
var expectedInlinesCount = 0
|
|
var expectedExceptionContrFrames = 0
|
|
|
|
fun exception() {
|
|
error("FAIL!")
|
|
}
|
|
|
|
fun main(args: Array<String>) {
|
|
val sourceInfoType = args.first()
|
|
val (e, i) = when (sourceInfoType) {
|
|
"libbacktrace" -> Pair(0, 1)
|
|
"coresymbolication" -> Pair(4, 0)
|
|
else -> throw AssertionError("Unknown source info type " + sourceInfoType)
|
|
}
|
|
expectedExceptionContrFrames = e
|
|
expectedInlinesCount = i
|
|
|
|
var actualInlinesCount = 0
|
|
try {
|
|
exception()
|
|
}
|
|
catch (e:Exception) {
|
|
val stackTrace = e.getStackTrace()
|
|
actualInlinesCount = stackTrace.count { it.contains("[inlined]")}
|
|
stackTrace.take(expectedExceptionContrFrames + 2).forEach(::checkFrame)
|
|
}
|
|
assertEquals(expectedInlinesCount, actualInlinesCount)
|
|
}
|
|
internal val regex = Regex("^(\\d+)\\ +.*/(.*):(\\d+):.*$")
|
|
internal fun checkFrame(value:String) {
|
|
val goldValues = arrayOf<Pair<String, Int>?>(
|
|
*arrayOfNulls(expectedExceptionContrFrames),
|
|
*arrayOfNulls(expectedInlinesCount),
|
|
"stack_trace_inline.kt" to 10,
|
|
"stack_trace_inline.kt" to 25)
|
|
val (pos, file, line) = regex.find(value)!!.destructured
|
|
goldValues[pos.toInt()]?.let {
|
|
assertEquals(it.first, file)
|
|
assertEquals(it.second, line.toInt())
|
|
}
|
|
} |