为测试,保护独立性——用stub来打破对象之间的依赖关系

现在来看The Art of Unit Testing With Examples in .NET的第三章“Using Stubs to Break Dependencies”

  • 作者使用了三种定义来指向测试中的伪造关系:fakes,stubs 和 mocks。
  • “除了间接层次过多这样的问题之外,没有哪种面向对象的问题是不能通过添加间接层次解决的。”然而,单元测试的诸多精妙之处就在于:如何找到正确的地方添加或使用间接层次,以测试目标代码
  • 加入间接层次的三个步骤:
    1. 找到待测试方法依赖的“接口”。这里的接口不单单是指面向对象中的接口,还包括与其他类协作需要调用方法或类。
    2. 如果“接口”与待测方法有“直接关系”(比如直接调用等等),就可以通过向接口加入间接层次,使得待测方法可以被测试。
    3. 将交互接口的“潜在实现”用可以控制的东西替换。
  • 对于Seam(接缝)的定义:

Seams are places in your code where you can plug in different functionality,such as stub classes. (可参考Michael Feathers的《修改代码的艺术》)

  • 打破依赖的5种方法
    1. 抽离出接口,以替换潜在实现。
    2. 向待测类中注入stub实现。
    3. 在构造器中接收接口作为函数
    4. 将接口作为属性,进行设置或读取。
    5. 调用方法前得到stub。

相关文章

迭代器模式(Iterator)迭代器模式(Iterator)[Cursor]意图...
高性能IO模型浅析服务器端编程经常需要构造高性能的IO模型,...
策略模式(Strategy)策略模式(Strategy)[Policy]意图:定...
访问者模式(Visitor)访问者模式(Visitor)意图:表示一个...
命令模式(Command)命令模式(Command)[Action/Transactio...
生成器模式(Builder)生成器模式(Builder)意图:将一个对...