mirai/logging/mirai-logging-log4j2/test/MiraiLog4JAdapterTest.kt

64 lines
2.4 KiB
Kotlin
Raw Normal View History

/*
* Copyright 2019-2021 Mamoe Technologies and contributors.
*
* 此源代码的使用受 GNU AFFERO GENERAL PUBLIC LICENSE version 3 许可证的约束, 可以在以下链接找到该许可证.
* Use of this source code is governed by the GNU AGPLv3 license that can be found through the following link.
*
* https://github.com/mamoe/mirai/blob/dev/LICENSE
*/
package net.mamoe.mirai.utils.logging
import io.ktor.client.*
import io.ktor.client.engine.okhttp.*
import net.mamoe.mirai.utils.MiraiLogger
import net.mamoe.mirai.utils.loadService
import java.io.ByteArrayOutputStream
import java.io.PrintStream
import kotlin.test.Test
import kotlin.test.assertFalse
import kotlin.test.assertIs
internal class MiraiLog4JAdapterTest {
@Suppress("DEPRECATION_ERROR")
@Test
fun `services prevail than legacy overrides`() {
MiraiLogger.setDefaultLoggerCreator {
net.mamoe.mirai.utils.SimpleLogger("my logger") { _: String?, _: Throwable? -> }
}
@Suppress("INVISIBLE_MEMBER", "INVISIBLE_REFERENCE")
assertIs<net.mamoe.mirai.internal.utils.Log4jLoggerAdapter>(MiraiLogger.Factory.create(this::class))
}
@Test
fun `using log4j`() {
assertIs<MiraiLog4JFactory>(loadService(MiraiLogger.Factory::class))
val logger = MiraiLogger.Factory.create(this::class)
@Suppress("INVISIBLE_MEMBER", "INVISIBLE_REFERENCE")
assertIs<net.mamoe.mirai.internal.utils.Log4jLoggerAdapter>(logger)
}
@Test
fun `print test`() {
val out = ByteArrayOutputStream()
System.setOut(PrintStream(out, true))
System.setErr(PrintStream(out, true))
HttpClient(OkHttp)
val logger = MiraiLogger.Factory.create(this::class)
logger.error("Hi")
/*
SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.
ERROR StatusLogger Log4j2 could not find a logging implementation. Please add log4j-core to the classpath. Using SimpleLogger to log to the console...
*/
out.flush()
println(out.toString())
assertFalse { out.toString().contains("slf4j", ignoreCase = true) }
assertFalse { out.toString().contains("Log4j2 could not find a logging implementation", ignoreCase = true) }
}
}