已经发布了几个问题,其中包括有关依赖项注入的特定问题,例如何时使用它以及支持它的框架。然而,
什么是依赖项注入?何时/为什么/不应该使用它?
依赖注入 将依赖传递给其他 对象 或 框架 (依赖注入器)。
依赖注入使测试更加容易。注入可以通过 构造函数 完成。
SomeClass() 其构造函数如下:
SomeClass()
public SomeClass() { myObject = Factory.getObject(); }
问题 :如果myObject涉及复杂的任务,例如磁盘访问或网络访问,则 很难 对其进行单元测试SomeClass()。程序员必须进行模拟,myObject并可能 拦截 工厂调用。
myObject
替代解决方案 :
myObject作为参数传递给构造函数
public SomeClass (MyClass myObject) { this.myObject = myObject; }
myObject 可以直接通过,这使测试更加容易。
如果没有依赖注入,则很难在单元测试中隔离组件。
2013年,当我撰写此答案时,这是Google Testing Blog的一个主要主题。这对我来说仍然是最大的优势,因为程序员在运行时设计中并不总是需要额外的灵活性(例如,对于服务定位器或类似的模式)。程序员在测试过程中经常需要隔离类。