代码改变世界

TDD: 解除依赖

2013-10-16 16:57  Spring.Guo  阅读(395)  评论(0编辑  收藏  举报

1  A类依赖B 类,可以把B类提取成IB接口,解除AB 之间的依赖关系。

 

   通过创建实现了IB接口的BStub 装代码,可以模拟B类进行测试。

   这是针对接口编程的典型。适合构造代价大,变化多的情况。应用示例如下:

   a.上层与下层之间的设计,比如业务层依赖数据访问层。

   b. B类是一个复杂对象。 比如 发送邮件,连接网络,调用物理硬件接口等。

 

2 A 类依赖B 类,把B类作为参数传递到A类中,适合B类的构造代价不是很大的情况。

   a 通过构造函数参数传递

   b 通过方法参数传递

例如:我们经常不经意间就这样写了:

  public class A {

public A()

{

     B  b = new B()  .    //实例化,产生依赖 

}

public void Do()

{

     B  b = new B()  .    //实例化,产生依赖 

   //..   do someting

}

    }

   以上写发,我们在测试代码中,将无法隔离B ,去测试A。降低依赖的写法:

  public class A {

         private B _b ;

public A(B b)

{

     this._b = b.    //实例化,依赖B,但在外部 

}

public void Do(B b)

{

      this._b = b.    //实例化,依赖B,但在外部 

   //..   do someting

}

    }

   通过这个方式写,在单元测试代码中,我可以构造B ,去测试A。