我使用的是带有LOG4J的SLF 4J,配置通常在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条答案
按热度按时间2o7dmzc51#
您不需要为JVM提供不同的日志实现。
日志记录代码使用类路径搜索
log4j.properties
文件,因此您所需要做的就是确保您的测试log4j.properties
文件位于发布文件之前的位置。我使用了Maven,它将文件放在目录中,这样做会更容易。我的发布版本
log4j.properties
放在src/main/resources
目录中。我的测试版本放在src/test/resources
目录中。Eclipse构建路径(classpath)被设置为在src/main/resources
之前搜索src/test/resources
,因此您的单元测试使用测试文件。JAR(或WAR)构建指令使用来自src/main/resources
的文件。lymgl2op2#
以下ROOT日志级别更改将对junit起作用,以将日志记录设置为所需级别。
qkf9rpyu3#
您可以使用具有
setAllLevels
方法的org.apache.logging.log4j.core.config.Configurator
。在您的测试中,您可以在
@Before
方法中使用它:注:使用绑定org.slf4j:slf4j-log4j12:1.7.26进行测试
7tofc5zh4#
也许一开始并不完全与这个问题相关,但是,当大多数开发人员在搜索
如何更改某些junit测试方法的日志级别。
方法是使用一个定制的junit MethodRule来访问记录器并重新配置每个包的日志级别。
使用下面的类,你可以做到这一点。它设置包和类的日志级别,如测试方法注解中定义的那样,当测试完成时,将日志程序设置回它们的初始状态。我们假设默认的日志级别当前设置为INFO。
为了实现这一点,你需要在你的测试类中指定测试规则:
所需的类在下面找到:
nx7onnlm5#
通常LEVEL.FINEST应该可以做到...但是看看http://saltnlight5.blogspot.mx/2013/08/how-to-configure-slf4j-with-different.html,看看日志框架的实现是否考虑了创建。