单元测试之道-学习笔记

使用Junit进行java代码单元测试。

 

Junit断言

assertEqual([String message],expected,actual,[tolerance])

assertNull([String message],object)

assertSame([String message],expected,actual) 验证是否引用同一对象

assertNotSame([String message],expected,actual)

assertTrue([String message],boolean condition)

assertFalse([String message],boolean condition)

fail([String message]) 使测试立即失败,可用来测试异常

 

如果测试失败,先修复失败的测试,再进行原代码新特性的编写

 

哪些内容需要被测试:

  1.Right——结果是否正确?

  2.B——是否所有的边界条件都是正确的?

  3.I——能查一下反向关联吗?

  4.C——能用其他手段交叉检查一下结果吗?

  5.E——你是否可以强制错误条件发生?(使用mock,模拟内存耗光,磁盘用满等)

  6.P——是否满足性能要求?

 

如何测试边界条件:

  1.一致性——值是否符合预期的格式

  2.有序性——一组值是该有序的,还是无序的

  3.区间性——值是否在一个合理的最大值和最小值范围之内

  4.引用,耦合性——代码是否引用了一些不受代码本身直接控制的外部因素

  5.存在性——值是否存在

  6.基数性——是否恰好有足够的值

  7.时间性——所有的事情是否都是按顺序发生,是否在正确的时间,是否及时

 

好的单元测试遵循以下准则:

 

1.自动的

      测试可以自动运行,并且自动分析测试结果

 

2.全面的

      测试代码覆盖到每个可能出错的地方。可以使用nounit等工具分析测试覆盖率

 

3.可重复的

      测试代码可以以任意顺序重复运行,不影响测试结果。这意味着每个测试必须独立,而且和环境无关

 

4.独立的

      测试代码必须整洁、专注重点。每一个测试专门测试一件事情。测试必须彼此独立,和环境无关

 

5.专业的

      测试代码必须和产品代码一样专业,包括该有的封装、继承、DRY原则等良好设计。但是不需要测试不太可能存在bug的方法,比如单纯的get/set方法。一般来说,测试代码和产品代码等量或者更多。

 

测试一个工程

      经常测试,确保check in的代码都是测试通过。加强代码review,交流团队经验。

 

代码设计

      1.面向测试的设计。如果一段代码不好进行测试,那么变更代码,使测试变得容易。

      2.为测试而重构代码。作为回报,我们获得了一个简洁的设计。

      3.测试类的不变性

      4.测试驱动的设计

      5.测试无效的参数。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值