如何在Junit测试期间将日志级别设置为DEBUG?

时间:2016-08-04 21:53:50

标签: java junit log4j slf4j

我正在使用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日志级别。我想自动化这个。

5 个答案:

答案 0 :(得分:17)

您不需要为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中的文件。

答案 1 :(得分:2)

通常LEVEL.FINEST应该这样做......但请看http://saltnlight5.blogspot.mx/2013/08/how-to-configure-slf4j-with-different.html以查看日志框架实现的考虑。

答案 2 :(得分:2)

也许并非一开始就与问题完全相关,但是当大多数开发人员在

上搜索方法时,谷歌查询将使大多数开发人员转向该主题。

如何更改某些junit测试方法的日志级别。

方法是使用自定义的junit MethodRule,该方法访问记录器并重新配置每个程序包的日志级别。

通过下面的类,您可以实现此目标。它按照测试方法的注释中的定义设置程序包和类的日志级别,并在测试完成时将记录器设置回其初始状态。 我们假设默认日志级别当前设置为INFO。

library(dplyr)
df %>%
  select(matches("^A"))

df %>%
  select(matches("2$"))

要实现此目的,您需要在测试类中指定测试规则:

@Test
@LogLevel(packageToLevel = { "my.java.package=DEBUG", "my.other.java.package.ClassNeedsTracing=TRACE" })
public void allLogsOfThatPackageAreInDebugNow() {
   ...
}

@Test
@LogLevel(packageToLevel = { "my.java.package=TRACE", "my.java.package.ClassNoTracing=TRACE" })
public void allLogsOfThatPackageAreInTraceNowExceptOneClass() {
   ...
}

需要的类如下:

@Rule
LogLevelRule logLevelRule = new LogLevelRule();

答案 3 :(得分:1)

您可以使用具有org.apache.logging.log4j.core.config.Configurator方法的setAllLevels

在测试中,您可以通过@Before方法使用它:

  @Before
  public void changeLogLevel() {
    Configurator.setAllLevels("", Level.ALL);
  }

注意:已通过绑定org.slf4j:slf4j-log4j12:1.7.26

进行了测试

答案 4 :(得分: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);
}