Mock Object: 把单元测试进行到底

今天早晨一边喝咖啡, 一边看完http://www.connextra.com/aboutUs/mockobjects.pdf, 很有心得.

Mock Object的目的
用来模拟外部复杂的资源, 使UT可以测试那些依赖于外界资源(如数据库, 第三方产品等).

使用Mock Object的方法

  1. 定义一个Mock Object, 实现外部资源的接口或者定义
  2. Instantiate一个Mock Object, 并设置state
  3. 给Mock Object定义内部期望值
  4. 把这个Mock Object instance传递给需要测试的Unit进行操作
  5. 操作完毕后将Mock Object内部的状态与期待状态比较(assertion)

注意点

  • hard code需要的逻辑, 避免过多实现
  • Mock Object之间不应该互相调用, 如果出线这种状态, 多半Mock Object不必要的复杂了.

优点

  • 避免过早引入Instructure Dependency, 例如对数据库的选取
  • 可以从很多测试代码把assertion refactoring到Mock Object内部
  • 把测试的Scope缩小
  • 模拟各种情况
  • 有利于发现可以通过refactoring创建新的interface

缺点

  • Mock Object本身的错误无法避免
  • 因为是Unit Test, 所以类似积累误差的问题仍然需要Functional Testing进行

你可能感兴趣的:(数据库,object,单元测试,测试,interface,Refactoring)