单元测试反模式,完整列表

我前段时间写过有关OOP中的反模式的文章 。 现在该写单元测试反模式了,因为它们也存在,并且有很多。 我将尝试在列表中包括我知道的每个示例。 如果您认识其他任何人,请通过请求请求将其添加,或在下面发表评论。 对于每个反模式,如果不是我的,我将尝试提及它的发现位置。 请记住,如果我在某处找到它,并不一定意味着它是在那发明的。 如果发现错误,请发表评论。

测试反模式

杜鹃 1 (又称陌生人3 )。 这是一种测试方法,它位于同一单元测试中,但实际上并不属于该单元测试。

按方法测试 1 。 尽管测试和生产类之间的一对一关系是一个合理的起点,但是测试和生产方法之间的一对一关系几乎总是一个坏主意。

肛门探针 2 。 必须使用不健康的方式执行其测试的测试,例如使用反射读取私有字段。

连体双胞胎 2 。 测试称为单元测试,但实际上是集成测试,因为被测系统和测试之间没有隔离。

幸福的道路 (又名对所有赔率3 ,骗子3的成功)。 这些测试始终走在快乐的道路上(即预期的结果),而无需测试边界和异常。

慢戳 3 。 运行非常慢的单元测试。 开发人员启动测试时,他们有时间去洗手间,抽烟,或者更糟糕的是,在一天结束之前回家进行测试。

巨人 3 。 尽管可以有效地测试被测对象,但它可以跨越数千行并且包含许多测试用例的单元测试。 这可以表明被测系统是上帝对象。

嘲讽 3 。 有时嘲笑会很好并且很方便。 但是有时,开发人员可能会迷失自己去模仿未经测试的内容。 在这种情况下,单元测试包含太多的模拟,存根和/或伪造品,以至于根本没有对被测系统进行测试,而是从模拟返回的数据正在被测试。

检查员 3 。 为了达到100%的代码覆盖率而违反封装的单元测试,但是对对象中发生的事情了解得非常多,以至于任何重构的尝试都会破坏现有的测试,并要求任何更改都应反映在单元测试中。

慷慨的剩菜 3 (又名链帮湿地板 )。 一个实例,其中一个单元测试创​​建了保留在某处的数据,而另一个测试出于自己的vious回目的重用了数据。 如果“生成器”是随后运行的,或者根本不运行,则使用该数据的测试将完全失败。

本地英雄 3 (又名“隐藏依赖项”,“操作系统推广者”,“ 观望者” ,“ 环境破坏者” )。 为了运行,该测试用例依赖于特定于其编写的开发环境的东西。 结果是测试通过了开发箱,但在有人尝试在其他地方运行它时失败。

Nitpicker 3 。 单元测试仅在只对其中的一小部分感兴趣时才比较完整的输出,因此测试必须与其他不重要的细节保持一致。

秘密守望者 3 。 乍一看,由于没有断言,因此似乎没有进行任何测试,但是正如他们所说,“细节决定成败”。 该测试实际上是在发生事故时依赖于引发异常,并且期望测试框架捕获该异常并将其作为故障报告给用户。

道奇 3 。 单元测试具有许多针对次要(并且可能易于测试)副作用的测试,但从未测试核心所需的行为。 有时,您可能会在与数据库访问相关的测试中找到该方法,该测试中调用了一个方法,然后该测试从数据库中选择并针对结果运行断言。

劳德茅斯 3 。 单元测试(或测试套件),即使通过测试,也会通过诊断消息,日志记录和其他杂项使控制台混乱。

贪婪的守望者 3 。 捕获异常并吞没堆栈跟踪的单元测试,有时将其替换为信息较少的失败消息,但有时甚至只是记录日志(请参阅Loudmouth)并通过测试。

音序器 3 。 单元测试取决于断言期间以相同顺序出现的无序列表中的项目。

枚举器 3 (又名无名测试 )。 单元测试,其中每个测试用例方法名称仅是一个枚举,例如test1test2test3 。 结果,测试用例的意图不明确,唯一可以确定的方法是阅读测试用例代码并祈求清晰。

Free Ride 3 (又名Piggyback )。 而不是编写新的测试案例方法来测试另一个功能,而是在现有测试案例中使用新的断言。

设置 3 过多 (又名Hen母亲 )。 为了进行测试,需要进行大量工作才能进行的测试。 有时,使用数百行代码来设置一个测试的环境,其中涉及多个对象,由于所有设置的“噪音”,因此很难真正确定要测试的内容。

线打手 。 乍一看,这些测试涵盖了所有内容,并且代码覆盖率工具可以100%确认它,但是实际上,这些测试只是对代码进行了编码,而没有进行任何输出分析。

四十英尺杆测试请参阅 )。 由于这些测试过于接近他们要测试的类,因此它们之间的距离很远,被无数的抽象层和他们正在检查的逻辑中的数千行代码分隔开。

有用的链接:

  1. Spock:由Rob Fletcher 主持并运行
  2. Boni Garcia的JUnit 5掌握软件测试
  3. TDD反模式 (James Carr)

翻译自: https://www.javacodegeeks.com/2018/12/unit-testing-anti-patterns-full-list.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值