in.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.
Deprecation Notice for group ID "in.specmatic"
******************************************************************************************************
Updates for "specmatic-core" will no longer be available under the deprecated group ID "in.specmatic".
Please update your dependencies to use the new group ID "io.specmatic".
******************************************************************************************************
The newest version!
package `in`.specmatic.core.log
import `in`.specmatic.core.utilities.exceptionCauseMessage
import `in`.specmatic.core.value.JSONObjectValue
import `in`.specmatic.core.value.StringValue
import `in`.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()}"
}
}