我将 SLF4J 与 LOG4J 一起使用,配置通常位于log4j.properties
,并将日志级别设置为 INFO。
但是在测试期间我想将日志设置为“调试”。
我看不出有什么方法可以实现自动化,也没有类似的东西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>
我怎样才能达到这个结果?
EDIT:我想我说得还不够清楚。这个问题不是关于设置正确的日志级别...而是关于在运行 Junit 测试时设置 DEBUG 日志级别,以及在任何其他情况下设置 INFO 日志级别。我想自动化这个。
您不需要为 JVM 提供不同的日志实现。
日志记录代码搜索log4j.properties
使用类路径的文件。所以你需要做的就是确保你的测试log4j.properties
文件位于发布文件之前可以找到的位置。
我使用 Maven,它将文件放置在目录中以使其变得简单。我的释放log4j.properties
进入目录src/main/resources
。我的测试版进入src/test/resources
。 Eclipse构建路径(classpath)设置为搜索src/test/resources
before src/main/resources
,因此您的单元测试使用测试文件。 JAR(或 WAR)构建指令使用来自src/main/resources
.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)