gradle junit 使用 slf4j 测试日志记录

gradle junit tests logging with slf4j

我正在尝试使用 Gradle 4.2.1 和 JUnit 4 启用测试日志记录。

https://discuss.gradle.org/t/allow-slf4j-logging-during-junit-tests/24449

出于某种原因,我只能看到 INFO 日志级别而不是更高级别(警告、错误)。有人设法将其设置为在单元测试期间显示所有日志级别吗?

提前致谢。

dependencies {
    compile group: 'org.slf4j', name:'slf4j-api', version: '1.7.21'
    compile group: 'org.slf4j', name:'slf4j-simple', version: '1.7.21'
    compile group: 'ch.qos.logback', name: 'logback-classic', version:  '1.1.7'
    testCompile group: 'junit', name: 'junit', version: '4.12'
}

...

test {
    testLogging {    
        showStandardStreams true
        exceptionFormat 'full'

logback-test.xml

<?xml version="1.0" encoding="UTF-8"?>
<configuration>

    <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{5} - %msg%n</pattern>
        </encoder>
    </appender>

    <logger name="io.effectus.cqrs" level="INFO" additivity="false">
        <appender-ref ref="CONSOLE" />
    </logger>

    <root level="WARN">
        <appender-ref ref="CONSOLE" />
    </root>

</configuration>

类路径上有两个 SLF4J 实现:

compile group: 'org.slf4j', name:'slf4j-simple', version: '1.7.21'
compile group: 'ch.qos.logback', name: 'logback-classic', version:  '1.1.7'

slf4j-simple 的默认值仅为 INFO 及以上,这可以通过配置 simplelogger.properties 来更改,您可能没有。

所以你的问题,只看到 INFO 及以上,可能是因为 slf4j-simple 优先于 logback-classic。

您在评论中提到升级到 logback 1.2.3 后它可以工作。可能出于某种原因,这现在优先于 slf4j-simple,但最好确保您在类路径上只有一个绑定。