高效测试设计全解析
1. 测试私有方法的探讨
在软件测试中,测试私有方法是一个值得深入探讨的话题。有时候,被测试对象会向自身发送消息,这些消息会调用定义在接收者私有接口中的方法。从理想设计的角度看,由于这些私有方法在对象外部不可见,似乎不需要对其进行测试。然而,现实情况并非如此简单,处理私有方法需要一定的判断力和灵活性。
1.1 测试时忽略私有方法
有几个重要原因让我们在测试时忽略私有方法:
- 冗余性 :私有方法隐藏在被测试对象内部,其结果对外部不可见。而且,这些私有方法会被已经有测试的公共方法调用。即使私有方法存在 bug 导致应用程序出现问题,现有的测试也会暴露这个问题,所以测试私有方法是不必要的。
- 不稳定性 :私有方法通常不稳定,对其进行测试会使测试与可能经常变化的应用代码耦合。当应用程序发生变化时,测试也需要相应修改,这会浪费大量时间在不必要的测试维护上。
- 误导性 :测试可以为被测试对象提供文档说明,展示其与外部的交互方式。如果在测试中包含私有方法,会分散读者对主要目的的注意力,还可能鼓励他们破坏封装,依赖这些私有方法。因此,测试应该隐藏私有方法,而不是暴露它们。
1.2 从被测试类中移除私有方法
避免私有方法是解决测试私有方法问题的一种途径。如果对象有大量私有方法,这可能表明该对象承担了过多的责任。此时,可以考虑将这些私有方法提取到新的对象中,使其成为新对象的公共接口。理论上,新的公共接口应该是稳定的,可以安全依赖。但实际上,新接口的稳定性可能和原来的私有接口一样,方法不