Using now stackTraceToString() instead of StackTraceHelper
This commit is contained in:
parent
4ec366f7cd
commit
9e161c3658
|
@ -5,8 +5,8 @@ import net.dankito.banking.fints.model.MessageLogEntry
|
||||||
import net.dankito.banking.fints.model.MessageLogEntryType
|
import net.dankito.banking.fints.model.MessageLogEntryType
|
||||||
import net.dankito.utils.multiplatform.log.Logger
|
import net.dankito.utils.multiplatform.log.Logger
|
||||||
import net.dankito.utils.multiplatform.log.LoggerFactory
|
import net.dankito.utils.multiplatform.log.LoggerFactory
|
||||||
import net.dankito.utils.multiplatform.StackTraceHelper
|
|
||||||
import net.dankito.utils.multiplatform.extensions.getInnerException
|
import net.dankito.utils.multiplatform.extensions.getInnerException
|
||||||
|
import net.dankito.utils.multiplatform.extensions.nthIndexOf
|
||||||
import net.dankito.utils.multiplatform.extensions.toStringWithTwoDigits
|
import net.dankito.utils.multiplatform.extensions.toStringWithTwoDigits
|
||||||
import kotlin.reflect.KClass
|
import kotlin.reflect.KClass
|
||||||
|
|
||||||
|
@ -32,9 +32,6 @@ open class MessageLogCollector {
|
||||||
get() = ArrayList(messageLog)
|
get() = ArrayList(messageLog)
|
||||||
|
|
||||||
|
|
||||||
protected open val stackTraceHelper = StackTraceHelper()
|
|
||||||
|
|
||||||
|
|
||||||
open fun addMessageLog(type: MessageLogEntryType, message: String, context: MessageContext) {
|
open fun addMessageLog(type: MessageLogEntryType, message: String, context: MessageContext) {
|
||||||
val messageToLog = createMessage(type, prettyPrintHbciMessage(message), context, true)
|
val messageToLog = createMessage(type, prettyPrintHbciMessage(message), context, true)
|
||||||
|
|
||||||
|
@ -50,7 +47,7 @@ open class MessageLogCollector {
|
||||||
if (e != null) {
|
if (e != null) {
|
||||||
getLogger(loggingClass).error(e) { messageToLog }
|
getLogger(loggingClass).error(e) { messageToLog }
|
||||||
} else {
|
} else {
|
||||||
getLogger(loggingClass).error(messageToLog)
|
getLogger(loggingClass).error { messageToLog }
|
||||||
}
|
}
|
||||||
|
|
||||||
val errorStackTrace = if (e != null) NewLine + getStackTrace(e) else ""
|
val errorStackTrace = if (e != null) NewLine + getStackTrace(e) else ""
|
||||||
|
@ -145,7 +142,10 @@ open class MessageLogCollector {
|
||||||
protected open fun getStackTrace(e: Exception): String {
|
protected open fun getStackTrace(e: Exception): String {
|
||||||
val innerException = e.getInnerException()
|
val innerException = e.getInnerException()
|
||||||
|
|
||||||
return stackTraceHelper.getStackTrace(innerException, MaxCountStackTraceElements)
|
val stackTraceString = innerException.stackTraceToString()
|
||||||
|
val indexOf16thLine = stackTraceString.nthIndexOf("\n", MaxCountStackTraceElements)
|
||||||
|
|
||||||
|
return if (indexOf16thLine < 0) stackTraceString else stackTraceString.substring(0, indexOf16thLine)
|
||||||
}
|
}
|
||||||
|
|
||||||
protected open fun getLogger(loggingClass: KClass<*>): Logger {
|
protected open fun getLogger(loggingClass: KClass<*>): Logger {
|
||||||
|
|
|
@ -1,8 +0,0 @@
|
||||||
package net.dankito.utils.multiplatform
|
|
||||||
|
|
||||||
|
|
||||||
expect class StackTraceHelper actual constructor() {
|
|
||||||
|
|
||||||
fun getStackTrace(e: Throwable, maxCountStackTraceElements: Int? = null): String
|
|
||||||
|
|
||||||
}
|
|
|
@ -0,0 +1,53 @@
|
||||||
|
package net.dankito.utils.multiplatform.extensions
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the n-th occurrence of [string] or -1 if [string] isn't contained n-times.
|
||||||
|
*/
|
||||||
|
fun String.nthIndexOf(string: String, nthOccurrence: Int, startIndex: Int = 0, ignoreCase: Boolean = false): Int {
|
||||||
|
var currentIndex = startIndex
|
||||||
|
var countOccurrence = 0
|
||||||
|
|
||||||
|
while (countOccurrence < nthOccurrence) {
|
||||||
|
val index = this.indexOf(string, currentIndex, ignoreCase)
|
||||||
|
|
||||||
|
if (index < 0) {
|
||||||
|
return -1 // not found
|
||||||
|
}
|
||||||
|
|
||||||
|
if (++countOccurrence == nthOccurrence) {
|
||||||
|
return index
|
||||||
|
}
|
||||||
|
|
||||||
|
currentIndex = index + 1
|
||||||
|
}
|
||||||
|
|
||||||
|
return -1
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Finds all occurrences of [string] in String and returns their indices.
|
||||||
|
*/
|
||||||
|
fun String.indicesOf(string: String, startIndex: Int = 0, ignoreCase: Boolean = false): List<Int> {
|
||||||
|
val indices = mutableListOf<Int>()
|
||||||
|
var currentIndex = startIndex
|
||||||
|
|
||||||
|
while (currentIndex >= 0) {
|
||||||
|
currentIndex = this.indexOf(string, currentIndex, ignoreCase)
|
||||||
|
|
||||||
|
if (currentIndex < 0) {
|
||||||
|
break
|
||||||
|
} else {
|
||||||
|
indices.add(currentIndex++)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return indices
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Finds all occurrences of [string] in String.
|
||||||
|
*/
|
||||||
|
fun String.countOccurrences(string: String, startIndex: Int = 0, ignoreCase: Boolean = false): Int {
|
||||||
|
return this.indicesOf(string, startIndex, ignoreCase).size
|
||||||
|
}
|
|
@ -0,0 +1,42 @@
|
||||||
|
package net.dankito.utils.multiplatform.extensions
|
||||||
|
|
||||||
|
import kotlin.test.Test
|
||||||
|
import kotlin.test.assertEquals
|
||||||
|
|
||||||
|
internal class StringExtensionsTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun nthIndexOf() {
|
||||||
|
val input = "java.lang.Exception: A severe error occurred" + IntRange(1, 30).map { "\r\n\tStack trace element $it" }
|
||||||
|
|
||||||
|
val result = input.nthIndexOf("\n", 15)
|
||||||
|
|
||||||
|
assertEquals(415, result)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun countOccurrences() {
|
||||||
|
val expectedOccurrences = 30
|
||||||
|
val input = "java.lang.Exception: A severe error occurred" + IntRange(1, expectedOccurrences).map { "\r\n\tStack trace element $it" }
|
||||||
|
|
||||||
|
val result = input.countOccurrences("\n")
|
||||||
|
|
||||||
|
assertEquals(expectedOccurrences, result)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun indicesOf() {
|
||||||
|
val expectedOccurrences = 30
|
||||||
|
val stringToFind = "\r\n"
|
||||||
|
val input = "java.lang.Exception: A severe error occurred" + IntRange(1, expectedOccurrences).map { "$stringToFind\tStack trace element $it" }
|
||||||
|
|
||||||
|
val result = input.indicesOf(stringToFind)
|
||||||
|
|
||||||
|
assertEquals(expectedOccurrences, result.size)
|
||||||
|
|
||||||
|
result.forEach { index ->
|
||||||
|
assertEquals(input.substring(index, index + stringToFind.length), stringToFind)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -1,16 +0,0 @@
|
||||||
package net.dankito.utils.multiplatform
|
|
||||||
|
|
||||||
|
|
||||||
actual class StackTraceHelper() {
|
|
||||||
|
|
||||||
actual fun getStackTrace(e: Throwable, maxCountStackTraceElements: Int?): String {
|
|
||||||
var stackTrace = e.getStackTrace()
|
|
||||||
|
|
||||||
maxCountStackTraceElements?.let {
|
|
||||||
stackTrace = stackTrace.take(maxCountStackTraceElements)
|
|
||||||
}
|
|
||||||
|
|
||||||
return stackTrace.joinToString("\r\n")
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,24 +0,0 @@
|
||||||
package net.dankito.utils.multiplatform
|
|
||||||
|
|
||||||
import java.io.PrintWriter
|
|
||||||
import java.io.StringWriter
|
|
||||||
|
|
||||||
|
|
||||||
actual class StackTraceHelper {
|
|
||||||
|
|
||||||
actual fun getStackTrace(e: Throwable, maxCountStackTraceElements: Int?): String {
|
|
||||||
val stringWriter = StringWriter()
|
|
||||||
e.printStackTrace(PrintWriter(stringWriter))
|
|
||||||
|
|
||||||
val stackTrace = stringWriter.toString()
|
|
||||||
|
|
||||||
maxCountStackTraceElements?.let {
|
|
||||||
val elements = stackTrace.split(System.lineSeparator()).take(maxCountStackTraceElements)
|
|
||||||
|
|
||||||
return elements.joinToString(System.lineSeparator())
|
|
||||||
}
|
|
||||||
|
|
||||||
return stackTrace
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,10 +0,0 @@
|
||||||
package net.dankito.utils.multiplatform
|
|
||||||
|
|
||||||
actual class StackTraceHelper {
|
|
||||||
|
|
||||||
actual fun getStackTrace(e: Throwable, maxCountStackTraceElements: Int?): String {
|
|
||||||
// TODO: is this a nice string?
|
|
||||||
return e.getStackTrace().take(maxCountStackTraceElements ?: Int.MAX_VALUE).joinToString("\n")
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
Loading…
Reference in New Issue