今天早晨一边喝咖啡, 一边看完http://www.connextra.com/aboutUs/mockobjects.pdf, 很有心得.
Mock Object的目的
用来模拟外部复杂的资源, 使UT可以测试那些依赖于外界资源(如数据库, 第三方产品等).
使用Mock Object的方法
- 定义一个Mock Object, 实现外部资源的接口或者定义
- Instantiate一个Mock Object, 并设置state
- 给Mock Object定义内部期望值
- 把这个Mock Object instance传递给需要测试的Unit进行操作
- 操作完毕后将Mock Object内部的状态与期待状态比较(assertion)
注意点
- hard code需要的逻辑, 避免过多实现
- Mock Object之间不应该互相调用, 如果出线这种状态, 多半Mock Object不必要的复杂了.
优点
- 避免过早引入Instructure Dependency, 例如对数据库的选取
- 可以从很多测试代码把assertion refactoring到Mock Object内部
- 把测试的Scope缩小
- 模拟各种情况
- 有利于发现可以通过refactoring创建新的interface
缺点
- Mock Object本身的错误无法避免
- 因为是Unit Test, 所以类似积累误差的问题仍然需要Functional Testing进行