From ba4ad2a3ab859f6cf33a2a04f52ce44d94a9d976 Mon Sep 17 00:00:00 2001 From: Marius Lewerenz Date: Mon, 1 Apr 2024 13:13:16 +0200 Subject: [PATCH] Allow supplying org.slf4j.Marker to the logger this fixes #360 --- .../kotlinlogging/slf4j/Slf4jExtensions.kt | 14 ++-- .../slf4j/internal/Slf4jMarker.kt | 6 ++ .../kotlinlogging/slf4j/Slf4jMarkerTest.kt | 75 +++++++++++++++++++ 3 files changed, 90 insertions(+), 5 deletions(-) create mode 100644 src/javaMain/kotlin/io/github/oshai/kotlinlogging/slf4j/internal/Slf4jMarker.kt create mode 100644 src/jvmTest/kotlin/io/github/oshai/kotlinlogging/slf4j/Slf4jMarkerTest.kt diff --git a/src/javaMain/kotlin/io/github/oshai/kotlinlogging/slf4j/Slf4jExtensions.kt b/src/javaMain/kotlin/io/github/oshai/kotlinlogging/slf4j/Slf4jExtensions.kt index 71d2dced..4eed4338 100644 --- a/src/javaMain/kotlin/io/github/oshai/kotlinlogging/slf4j/Slf4jExtensions.kt +++ b/src/javaMain/kotlin/io/github/oshai/kotlinlogging/slf4j/Slf4jExtensions.kt @@ -1,14 +1,18 @@ package io.github.oshai.kotlinlogging.slf4j -import io.github.oshai.kotlinlogging.KLogger -import io.github.oshai.kotlinlogging.KotlinLogging -import io.github.oshai.kotlinlogging.Level -import io.github.oshai.kotlinlogging.Marker +import io.github.oshai.kotlinlogging.* import io.github.oshai.kotlinlogging.slf4j.internal.Slf4jLoggerFactory +import io.github.oshai.kotlinlogging.slf4j.internal.Slf4jMarker import org.slf4j.Logger import org.slf4j.MarkerFactory -public fun Marker.toSlf4j(): org.slf4j.Marker = MarkerFactory.getMarker(this.getName()) +public fun Marker.toSlf4j(): org.slf4j.Marker = + when (this) { + is Slf4jMarker -> marker + else -> MarkerFactory.getMarker(getName()) + } + +public fun org.slf4j.Marker.toKotlinLogging(): Marker = Slf4jMarker(this) public fun Level.toSlf4j(): org.slf4j.event.Level = when (this) { diff --git a/src/javaMain/kotlin/io/github/oshai/kotlinlogging/slf4j/internal/Slf4jMarker.kt b/src/javaMain/kotlin/io/github/oshai/kotlinlogging/slf4j/internal/Slf4jMarker.kt new file mode 100644 index 00000000..a767427e --- /dev/null +++ b/src/javaMain/kotlin/io/github/oshai/kotlinlogging/slf4j/internal/Slf4jMarker.kt @@ -0,0 +1,6 @@ +package io.github.oshai.kotlinlogging.slf4j.internal + +import io.github.oshai.kotlinlogging.Marker + +@JvmInline +internal value class Slf4jMarker(val marker: org.slf4j.Marker) : Marker, org.slf4j.Marker by marker diff --git a/src/jvmTest/kotlin/io/github/oshai/kotlinlogging/slf4j/Slf4jMarkerTest.kt b/src/jvmTest/kotlin/io/github/oshai/kotlinlogging/slf4j/Slf4jMarkerTest.kt new file mode 100644 index 00000000..34f7deb5 --- /dev/null +++ b/src/jvmTest/kotlin/io/github/oshai/kotlinlogging/slf4j/Slf4jMarkerTest.kt @@ -0,0 +1,75 @@ +package io.github.oshai.kotlinlogging.slf4j + +import io.github.oshai.kotlinlogging.KotlinLogging +import io.github.oshai.kotlinlogging.addAppender +import io.github.oshai.kotlinlogging.removeAppender +import kotlin.test.assertEquals +import org.apache.logging.log4j.core.Appender +import org.apache.logging.log4j.core.LogEvent +import org.apache.logging.log4j.core.appender.NullAppender +import org.apache.logging.slf4j.Log4jMarker +import org.junit.jupiter.api.AfterEach +import org.junit.jupiter.api.BeforeEach +import org.junit.jupiter.api.Test + +private val logger = KotlinLogging.logger {} + +private class TestAppender( + val appender: Appender = NullAppender.createAppender("testAppender"), + var lastEvent: LogEvent? = null, +) : Appender by appender { + override fun append(event: LogEvent) { + lastEvent = event.toImmutable() + appender.append(event) + } +} + +class Slf4jMarkerTest { + + private val testAppender = TestAppender() + + @BeforeEach + fun setupAppender() { + addAppender(testAppender) + } + + @AfterEach + fun removeAppender() { + removeAppender(testAppender) + } + + @Test + fun `a slf4j Marker can be supplied to the logger`() { + + val log4jMarker = + object : org.apache.logging.log4j.Marker { + override fun addParents( + vararg markers: org.apache.logging.log4j.Marker? + ): org.apache.logging.log4j.Marker = TODO("Not yet implemented") + + override fun getName(): String = "foo" + + override fun getParents(): Array = + TODO("Not yet implemented") + + override fun hasParents(): Boolean = false + + override fun isInstanceOf(m: org.apache.logging.log4j.Marker?): Boolean = false + + override fun isInstanceOf(name: String?): Boolean = false + + override fun remove(marker: org.apache.logging.log4j.Marker?): Boolean = + TODO("Not yet implemented") + + override fun setParents( + vararg markers: org.apache.logging.log4j.Marker? + ): org.apache.logging.log4j.Marker = TODO("Not yet implemented") + } + + val slf4jMarker = Log4jMarker(null, log4jMarker) + + logger.atError(slf4jMarker.toKotlinLogging()) { message = "bar" } + + assertEquals(testAppender.lastEvent?.marker, log4jMarker) + } +}