Junit测试时如何设置日志级别为DEBUG?

新手上路,请多包涵

我将 SLF4J 与 LOG4J 一起使用,配置通常在 log4j.properties 中,并将日志级别设置为 INFO。

但是在测试期间,我想将日志设置为 DEBUG。

我看不到自动执行此操作的方法,也没有类似 log4j.tests.properties 类的东西,只能在测试期间加载。

所以我尝试在测试设置(@BeforeClass)中以编程方式执行此操作:

 LogManager.getRootLogger().setLevel(Level.ALL);

没有成功…

我正在使用这些版本:

     <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
        <version>1.7.5</version>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-log4j12</artifactId>
        <version>1.7.5</version>
    </dependency>

我怎样才能达到这个结果?

编辑: 我想我还不够清楚。这个问题不是关于设置正确的日志级别……它是关于在运行 Junit 测试时设置 DEBUG 日志级别,以及在任何其他情况下设置 INFO 日志级别。我想自动化这个。

原文由 PedroD 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 2.8k
2 个回答

您不需要为 JVM 提供不同的日志实现。

日志记录代码使用类路径搜索 log4j.properties 文件。因此,您需要做的就是确保您的测试 log4j.properties 文件位于它会在发布文件之前找到的位置。

我使用 Maven,它将文件布置在目录中以简化操作。我的版本 log4j.properties 进入目录 src/main/resources 。我的测试版本进入 src/test/resources 。 Eclipse 构建路径(类路径)设置为搜索 src/test/resources 之前 src/main/resources ,因此您的单元测试使用测试文件。 JAR(或 WAR)构建说明使用来自 src/main/resources 的文件。

原文由 PedroD 发布,翻译遵循 CC BY-SA 3.0 许可协议

低于 ROOT 的日志级别更改将使 junit 将日志记录设置为所需的级别。

 import org.slf4j.LoggerFactory;
import ch.qos.logback.classic.Level;
import ch.qos.logback.classic.Logger;

@Before
public void setUp() {
    final Logger logger = (Logger)LoggerFactory.getLogger(Logger.ROOT_LOGGER_NAME);
    logger.setLevel(Level.ALL);
}

原文由 Achu22 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题