java – 我可以在启用所有日志记录的情况下自动执行一次JUnit测试用例,并在禁用所有日志记录后自动执行

我找到了解决方案,请参阅下面的答案.有人有更优雅的吗?

我想这样做是为了增加代码覆盖率并找到微妙的错误.

假设要测试以下类:

public class Foo {
    private final Logger logger = LoggerFactory.getLogger(Foo.class);
    public void bar() {
        String param=[..];
        if(logger.isInfoEnabled()) logger.info("A message with parameter {}",param);

        if(logger.isDebugEnabled()) {
            // some complicated preparation for the debug message
            logger.debug([the debug message]);
        }
    }
}

和以下测试类:

public class FooTest {
    @Test
    public void bar() {
        Foo foo=new Foo();
        foo.bar();
    }
}

代码覆盖率工具,例如Cobertura将正确报告只检查了一些条件分支.

对记录器激活或取消激活信息和调试.

除了在你的报道得分上看起来不好之外,这也构成了真正的风险

如果(logger.isDebugEnabled())内部的代码导致了一些副作用怎么办?如果您的代码仅在启用DEBUG时才起作用,并且如果日志级别设置为INFO则会失败,该怎么办? (这实际上发生在我们的一个项目中:p)

所以我的结论是,包含记录器语句的代码应始终在启用所有日志记录时进行一次测试,并在禁用所有日志记录时进行

有没有办法用JUnit做这样的事情?我知道如何全局启用或禁用Logback中的所有日志记录,因此问题是:如何在启用日志记录的情况下执行两次测试,一次禁用日志记录.

附:我知道this question,但我不认为这是重复的.我不太关心绝对覆盖值,而是关注可能包含在if(logger.isDebugEnabled())中的微妙,难以发现的错误.

解决方法

我通过实现一个基类来解决这个问题,如果需要这样的功能,测试类应该扩展.

Writing a parameterized JUnit test条包含解决方案.

有关日志记录基类的信息,请参阅LoggingTestBase;有关使用它的简单示例,请参见LoggingTestBaseExampleTest.

每个包含的测试方法都执行三次:

1.像往常一样使用logback-test.xml中定义的日志执行.这应该有助于编写/调试测试.

2.在启用所有日志记录并将其写入文件的情况下执行.测试后删除文件.

3.在禁用所有日志记录的情况下执行.

是的,LoggingTestBase需要文档;)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


应用场景 C端用户提交工单、工单创建完成之后、会发布一条工单创建完成的消息事件(异步消息)、MQ消费者收到消息之后、会通知各处理器处理该消息、各处理器处理完后都会发布一条将该工单写入搜索引擎的消息、最终该工单出现在搜索引擎、被工单处理人检索和处理。 事故异常体现 1、异常体现 从工单的流转记录发现、
线程类,设置有一个公共资源 package cn.org.chris.concurrent; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; /** * @Descrip
Java中的数字(带有0前缀和字符串)
在Java 9中使用JLink的目的是什么?
Java Stream API Filter(过滤器)
在Java中找到正数和负数数组元素的数量
Java 9中JShell中的不同启动脚本是什么?
使用Java的位填充错误检测技术
java中string是什么
如何使用Java中的JSON-lib API将Map转换为JSON对象?
Java菜单驱动程序以检查数字类型
使用Junit的Maven项目 - 检查银行账号
JAVA编程基础
在Java中使用throw、catch和instanceof来处理异常
在Java中,将数组分割为基于给定查询的子数组后,找到子数组的最大子数组和
如何在Java中从给定的字符串中删除HTML标签?
在PHP中,IntlChar getBlockCode()函数的翻译如下:
如何在Android中实现按下返回键再次退出的功能?
如何使用Java中的流式API解析JSON字符串?
Java中的模式类