单元测试—破除依赖

发表于:2015-11-04 11:03  作者:庄君祥   来源:51Testing软件测试网采编

字体: | 上一篇 | 下一篇 |我要投稿 | 推荐标签: 软件测试技术 单元测试

  痛点是什么
  要测试的对象依赖另一个你无法控制(或者还未实现)的对象。这个对象可能是Web服务、系统时间、线程调试、接口或者其他。
  重要的问题是:你的测试代码不能控制这个依赖的对象向你的代码返回什么值,也不能控制它的行为(例如想模拟一个异常)。
  何以解忧,唯有存根或者模拟对象。
  什么是存根
  一个存根是对系统中存在的一个依赖项(或者协作者)的可控制的替代物。通过使用存根,你在测试代码时无需直接处理这个依赖项。
  什么是模拟对象
  模拟对象是系统中的伪对象,它可以验证被测试对象是否按预期的方式调用了这个伪对象,因此通过或者是失败。通常每个测试最多有一个模拟对象
  存根和模拟对象区别
  它们二者其他都是伪对象。二者最根本的区别是存根不会导致测试失败,而模拟对象可以。即存根不参与断言,而模拟对象参与断言。
  怎么实现
  手工
  竟然还想着手工实现。。。。但是还是简单说一下原理,如果有想深入了解,可以参见《单元测试的艺术》
  ·加一个中间层,让测试类实现它,然后编写一个用于单元测试的实现类
  ·继承测试类,编写一个单元测试的实现类,重写方法并赋值返回值。
  ·通过工厂创建存根对象
  ·通过Ioc创建存根对象
  ·通过反射注入属性生成存根对象
  ......
  框架
  目前也在找比较适合的框架。所说EasyMock太过时了,还要使用PowerMock。Jmockito和其他的不受限的mock框架还在学习中。正在觅食一个能降低隔离复杂度的框架。
  下面陈述一下我想找的隔离框架的几个特性
  1、支持AAA原则,即“准备——执行——断言”结果的框架,不大想用“录制——重放”的方法。因为不自然。
  2、框架必须是不受限的。可以支持静态方法,私有构建等。哈哈,因为我比较贪心
  3、框架有比较友好的文档。这样可以降低学习曲线。
  4、框架的语法,看得更自然舒服些。毕竟要用很久,顺眼很重要!!
  5、最好是能支持灵活的参数mock。就像EasyMock.anyString()。因为有些参数确实不想关心。

评 论

论坛新帖



建议使用IE 6.0以上浏览器,800×600以上分辨率,法律顾问:上海信义律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2022, 沪ICP备05003035号
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪公网安备 31010102002173号

51Testing官方微信

51Testing官方微博

扫一扫 测试知识全知道