2021-08-09 23:45:32 +08:00
|
|
|
/*
|
|
|
|
* 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 {
|
|
|
|
|
2021-08-10 04:53:40 +08:00
|
|
|
@Suppress("DEPRECATION")
|
|
|
|
@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))
|
|
|
|
}
|
|
|
|
|
2021-08-09 23:45:32 +08:00
|
|
|
@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) }
|
|
|
|
}
|
|
|
|
}
|