在Junit测试期间如何将日志级别设置为DEBUG?
我正在使用SLF4J和LOG4J,配置通常在log4j.properties
,它将日志级别设置为INFO。
但是在测试期间,我想将日志设置为DEBUG。
我看不到自动化这种方法的方法,也没有像log4j.tests.properties
这样只能在测试期间加载的东西。
所以我尝试在测试设置(@BeforeClass)中以编程方式执行此操作:
LogManager.getRootLogger().setLevel(Level.ALL);
没有成功……
我正在使用这些版本:
org.slf4j slf4j-api 1.7.5 org.slf4j slf4j-log4j12 1.7.5
我怎样才能达到这个效果?
编辑:我想我不够清楚。 这个问题不是关于设置正确的日志级别…它是关于在运行Junit测试时设置DEBUG日志级别,以及在任何其他情况下设置INFO日志级别。 我想自动化这个。
您不需要为JVM提供不同的日志实现。
日志记录代码使用类路径搜索log4j.properties
文件。 因此,您需要做的就是确保您的测试log4j.properties
文件位于它将在发布文件之前找到的位置。
我使用Maven,它在目录中放置文件以使其变得容易。 我的发布log4j.properties
位于目录src/main/resources
。 我的测试版本在src/test/resources
。 Eclipse构建路径(类路径)设置为在src/main/resources
之前搜索src/test/resources
src/main/resources
,因此您的unit testing使用测试文件。 JAR(或WAR)构建指令使用src/main/resources
的文件。
通常LEVEL.FINEST应该这样做……但是看一看http://saltnlight5.blogspot.mx/2013/08/how-to-configure-slf4j-with-different.html来查看日志框架实现的考虑。