文档章节

Junit 单元测试编写注意事项记录

笋干瘦肉栗子粽
 笋干瘦肉栗子粽
发布于 2017/06/04 23:56
字数 1404
阅读 3
收藏 0
点赞 0
评论 0

在公司项目开始的阶段由于准备不完善和个人能力不足,忽略了编写正规的单元测试的好处,所以在长达一年的时间里,项目在上线前的构建过程中其实是没有跑过测试的,在项目上线的最初几个月里,由于项目功能涉及的方面较少,所以可以轻松的确保上线代码不存在严重的问题。

随着项目涉及的方面逐渐扩大,没有正规的测试架构的问题逐渐显现出来,我还记得一次由于spring循环注入导致接口的事务失效的问题,足足浪费了我两天的时间查找错误,如果在上线前经过了严格单元测试,也不会出现如此低级的错误。

现在项目的生产代码已经到了人工无法掌控的地步,在线上频繁出现的小bug严重影响了生产代码的可靠性和我的生产效率。这都是当时项目开发阶段不重视单元测试给自己埋的坑。

我现在也渐渐发现了一个道理:越是项目架构早期的缺陷,发现的越迟,危害越大。 在接下来的时间里我决定消除这个隐患---通过重写结构良好,可靠度高的单元测试。

下面的编写注意事项来自科斯凯拉的《Effective Unit Testing》 在重写单元测试的过程学习到的经验与感悟会慢慢的补充

##衡量测试代码的指标

  • 测试代码的可读性
  • 测试的可靠度
  • 测试的执行速度

##测试反例

###坏味道

  • ####可读性
    1. 断言的表达方式要明确表达验证意图,避免认知负担
    2. 断言的范围要紧密贴合测试目的。不能高于本测试目的,永远成功的断言没有价值。也不能将断言范围覆盖多个测试意图,永远失败的测试缺乏可维护性。断言范围不明确造成理解困难。
    3. 避免测试方法中的过度细节,测试方法应该能快速表达测试内容。注意方法名,分离多余的安装方法,重用共用的测试代码
    4. 避免多重职责,单个测试的测试内容应该只关注目标代码的一个行为,便于快速定位测试问题
    5. 避免将不必要的测试逻辑与数据文件分割,简单的数据应该内联到测试之中,如果不能做到,那么数据文件也应该和测试方法待在一起
    6. 避免测试代码中意义重要但是表达不明的膜法数字,使用有意义的静态变量或者方法名来代替
    7. 避免冗长的安装,抽取细节,整合到命名浅显的方法名中
    8. 避免不必要的断言保护,增加冗余的断言

  • ####可维护性

    阅读代码比编写代码频繁的多

    1. 避免重复 结构重复和语义重复
    2. 避免测试方法中的条件逻辑,他会造成的断言被回避不执行
    3. 避免间歇性成功的测试,同一个测试数据一个测试方法的返回结果应该始终一致
    4. 避免残缺的文件路径,应该使用类路径、项目路径等相对路径
    5. 测试生成的共享文件等资源在测试结束之后就应该删除,避免测试之间相互影响
    6. thiread#sleep 使用countDownLatch来代替
    7. 避免参数化测试模式滥用
    8. 提高测试类的内聚,合理使用公共基类

  • ####可信赖性
    1. 测试项目中不应该存在被注释掉不运行的代码
    2. 代码注释要和测试代码同步 好的代码注释为什么而非做什么
    3. 测试失败时就应当失败
    4. 避免轻率承诺避免空的测试方法,没有任何检查的测试没有用处,测试内容不全,测试的代码比声明的少
    5. 避免降低期望,源于断言过于模糊或者不能描述期望行为,避免虚假安全感
    6. 避免基于所运行的平台而决定断言结果
    7. 用断言替换条件
    8. 分支条件的不同路径应该分解到单独的测试中,所有的测试都应该有失败的机会

###设计原则 模块化编程有理由提高代码可测性

模块化设计原则

####SOLID

  1. s---单一职责原则 类小而专注,具有高内聚。发生变化的原因只有一个
  2. o---开闭原则 对扩展开放,对修改关闭 --可在不修改代码的情况下扩展功能
  3. l---里是替换原则 子类是父类的扩展,子类能替换父类进行工作
  4. i---接口隔离原则 接口小而专注,提高可测试性
  5. d---依赖翻转原则,类不用自己实例化协作者,而是选择依赖接口

####可测性的设计指南

避免使用private修饰符 避免使用final修饰符 避免工具类之外的static方法 避免被测方法中使用new的硬编码 避免在构造函数中包含逻辑 避免使用单例 使用继承达到重用会抑制可测性

© 著作权归作者所有

共有 人打赏支持
笋干瘦肉栗子粽
粉丝 1
博文 2
码字总数 5562
作品 0
杭州
程序员
JUnit 5.2.0 发布,Java 单元测试框架

JUnit 5.2.0 发布,JUnit 5.2.0 = Platform 1.2.0 + Jupiter 5.2.0 + Vintage 5.2.0,此次更新包括构建工具的增强、参数化测试的改进等。 更新信息如下: 构建工具功能增强以支持新的模块化体...

雨田桑 ⋅ 05/04 ⋅ 0

Gradle学习(二十一)——用TestKit测试构建逻辑

用法 想使用TestKit,需要在构建脚本中引入: gradleTestKit()方法包含TestKit的class文件,还有Gradle Api的客户端工具类,但是并不包含JUnit,TestNG等测试工具的类, 用GradleRunner进行功...

lastsweetop ⋅ 03/10 ⋅ 0

spring-boot2.0 单元测试JUnit4

spring-boot2.0 单元测试JUnit4 简单在spring-boot2.0版本中使用junit 源码如下: @SpringBootTest(classes = DemoT002Application.class) 只要加上这个就能使用DemoT002Application.class是......

btmaxyyq ⋅ 06/04 ⋅ 0

springboot在jetty+websocket的环境下的junit测试失败

这个问题描述起来可能还比较长。 首先我在springboot中选择了jetty作为服务器,然后现在我希望使用jetty的websocket功能,因此边加了jetty的websocket包。按照网上的教程,只要注意把tomcat的...

kuma_ller ⋅ 05/27 ⋅ 0

Android程序测试(1)——新建一个简单的测试工程来测试已有的工程

因为程序测试方面是程序开发中非常重要的一方面,这里结合官方教程,来了解下Android程序是怎样进行测试的。 Android开发环境集成了一个容易使用但同时很强大的程序测试框架,通过这个框架,...

一路漫漫 ⋅ 2012/03/16 ⋅ 0

ContiPerf接口性能测试

ContiPerf ContiPerf是一个轻量级的测试工具,基于JUnit 4 开发,可用于接口级的性能测试 可以指定在线程数量和执行次数,通过限制最大时间和平均执行时间来进行效率测试 具体使用方法 添加依...

kipeng300 ⋅ 05/11 ⋅ 0

【Android stuido】【Monkey】【Jenkins】自动化测试初探

自动化测试初探-201709032226 Junit 部分注解说明 一个JUnit4 的单元测试用例执行顺序为:@BeforeClass –> @Before –> @Test –> @After –> @AfterClass 每一个测试方法的调用顺序为:@Be...

lichong951 ⋅ 05/24 ⋅ 0

Junit测试Controller(MockMVC使用),传输@RequestBody数据解决办法

一、单元测试的目的   简单来说就是在我们增加或者改动一些代码以后对所有逻辑的一个检测,尤其是在我们后期修改后(不论是增加新功能,修改bug),都可以做到重新测试的工作。以减少我们在...

文文1 ⋅ 06/01 ⋅ 0

在eclipse中配置maven

官网下载maven插件(http://maven.apache.org/download.cgi) 现在完解压如图所示: 文件目录介绍: Bin:二进制文件 Boot:引导,启动 Conf:配置文件 Lib:jar包 README.txt:读我 2.修改配置文件...

懿宁19931210 ⋅ 05/15 ⋅ 0

MyBatis使用,MyBatis单独使用笔记

MyBatis使用,MyBatis单独使用笔记 1. 创建一张表 2. 引入jar包 3. 创建数据库属性文件db.properties [plain] view plain copy jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://l......

优惠券活动 ⋅ 04/25 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

解决CentOS6、7,/etc/sysconfig/下没有iptables的问题

一、Centos 6版本解决办法: 1.任意运行一条iptables防火墙规则配置命令: iptables -P OUTPUT ACCEPT 2.对iptables服务进行保存: service iptables save 3.重启iptables服务: service ...

寰宇01 ⋅ 18分钟前 ⋅ 2

数据库备份和恢复

备份:mysqldump -u root -p 数据库>磁盘路径 恢复:mysql -u root -p 数据库<sql脚本的磁盘路径

anlve ⋅ 今天 ⋅ 0

发生了什么?Linus 又发怒了?

在一个 Linux 内核 4.18-rc1 的 Pull Request 中,开发者 Andy Shevchenko 表示其在对设备属性框架进行更新时,移除了 union 别名,这引发了 Linus 的暴怒。 这一次 Linus Torvalds 发怒的原...

问题终结者 ⋅ 今天 ⋅ 0

在树莓派上搭建一个maven仓库

在树莓派上搭建一个maven仓库 20180618 lambo init 项目说明 家里有台树莓派性能太慢。想搭建一个maven私服, 使用nexus或者 jfrog-artifactory 运行的够呛。怎么办呢,手写一个吧.所在这个...

林小宝 ⋅ 今天 ⋅ 0

Spring发展历程总结

转自与 https://www.cnblogs.com/RunForLove/p/4641672.html 目前很多公司的架构,从Struts2迁移到了SpringMVC。你有想过为什么不使用Servlet+JSP来构建Java web项目,而是采用SpringMVC呢?...

onedotdot ⋅ 今天 ⋅ 0

Python模块/包/库安装(6种方法)

Python模块/包/库安装(6种方法) 冰颖机器人 2016-11-29 21:33:26 一、方法1: 单文件模块 直接把文件拷贝到 $python_dir/Lib 二、方法2: 多文件模块,带setup.py 下载模块包(压缩文件zip...

cswangyx ⋅ 今天 ⋅ 0

零基础学习大数据人工智能,学习路线篇!系统规划大数据之路?

大数据处理技术怎么学习呢?首先我们要学习Python语言和Linux操作系统,这两个是学习大数据的基础,学习的顺序不分前后。 Python:Python 的排名从去年开始就借助人工智能持续上升,现在它已经...

董黎明 ⋅ 今天 ⋅ 0

openJdk和sun jdk的区别

使用过LINUX的人都应该知道,在大多数LINUX发行版本里,内置或者通过软件源安装JDK的话,都是安装的OpenJDK, 那么到底什么是OpenJDK,它与SUN JDK有什么关系和区别呢? 历史上的原因是,Ope...

jason_kiss ⋅ 今天 ⋅ 0

梳理

Redux 是 JavaScript 状态容器,提供可预测化的状态管理。 它是JS的状态容器,是一种解决问题的方式,所以即可以用于 react 也可以用于 vue。 需要理解其思想及实现方式。 应用中所有的 stat...

分秒 ⋅ 今天 ⋅ 0

Java 后台判断是否为ajax请求

/** * 是否是Ajax请求 * @param request * @return */public static boolean isAjax(ServletRequest request){return "XMLHttpRequest".equalsIgnoreCase(((HttpServletReques......

JavaSon712 ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部