io.specmatic.core.log.VerboseExceptionLog.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of specmatic-core Show documentation
Show all versions of specmatic-core Show documentation
Turn your contracts into executable specifications. Contract Driven Development - Collaboratively Design & Independently Deploy MicroServices & MicroFrontends.
package io.specmatic.core.log
import io.specmatic.core.utilities.exceptionCauseMessage
import io.specmatic.core.value.JSONObjectValue
import io.specmatic.core.value.StringValue
import io.specmatic.core.value.Value
class VerboseExceptionLog(val e: Throwable, val msg: String?): LogMessage {
override fun toJSONObject(): JSONObjectValue {
val data: Map = mapOf(
"className" to StringValue(e.javaClass.name),
"cause" to StringValue(exceptionCauseMessage(e)),
"stackTrace" to StringValue(e.stackTraceToString())
)
val message: Map = msg?.let {
mapOf("message" to StringValue(msg))
} ?: emptyMap()
return JSONObjectValue(data.plus(message))
}
override fun toLogString(): String {
val message = when(msg) {
null -> exceptionCauseMessage(e)
else -> "${msg}: ${e.localizedMessage ?: e.message ?: e.javaClass.name}"
}
return "$message${System.lineSeparator()}${e.stackTraceToString()}"
}
}