在单元测试中如何测试私有方法

上一篇 / 下一篇  2012-10-16 09:46:14 / 个人分类:单元测试

51Testing软件测试网g*tg"Cu\4j9_([

  在单元测试用例的开发过程中遇到需要测试私有方法的地方往往会给开发人员带来很大的困扰。

v~$qDW:q0

N3q E%c$CB d2tM0  在http://blog.developers.ba/post/2009/04/12/Unit-testing-private-methods-yes-or-no.aspx 这篇blog中,博主也提到了类似的问题。

dr+~`4G(o|i \%O051Testing软件测试网3RT2x uC

  1、需要对私有方法进行测试吗?

'j;SHM2q051Testing软件测试网\ ps/F2U ^ [

  2、如何测试?是调整私有方法的访问权限或是通过public来测试。

8X-y,k#Mp:^-ZZ0

m$]8xLu+cu#zU0  3、对私有方法进行测试是不是意味着代码中有了bad smell。51Testing软件测试网r1U1B7tr JF

;w9N v.c5bU:Tbr0  4....51Testing软件测试网0kb.f @9T-a mb'`

51Testing软件测试网q zi:g(EV^~G v

  接下来谈谈我的感受吧

h~ b&t!?3pSxF%?051Testing软件测试网Yh#g;Vp'V6v

   1、是不是需要对一个方法(无论是public或是private)取决于这个函数的复杂度和价值,并不是所有的function都要测试的,除非需要 追求很高的测试覆盖率。这样的话是否需要对一个private方法进行测试就看这个private方法是不是比较重要、复杂、容易出错,其实这个原则也适 用于Public的方法,你总不会去测试java的setter和getter吧。51Testing软件测试网^ ?#X*z!WI+X'[o

51Testing软件测试网5Y ^,Y,_nq%TX$l

  2、很多时候private的方法的测试时可以通过对public方法的测试间接来达到的。一个设计良好的、充分运用TDD的工程完全可以通过对public方法提供完整的用例就可以覆盖private方法。

$R_ Uq v Wt051Testing软件测试网\'T+g\h

  3、仅仅为了能够进行单元测试,而采用将private方法改成public方法通常是不合适的,这样会暴露出不该暴露的实现细节,另外接口过多也破坏了SRP(单一职责原则)。51Testing软件测试网,J;xZ3el fU

0U_Ov{H ^0  4、当你非常渴望测试一个private方法的时候,可以仔细评估这个private方法和目前所在类的关系,这样的private方法是不是应该迁移到另一个类中,在另一个类中作为public提供接口给调用方(我通常这么干)。51Testing软件测试网)j pQ!am:d0t

{j `0v5cOu0  5、最后一个测试private的途径就是利用语言提供的反射功能,在testcase中将private方法修改成public的,以此来实现对private方法的测试。

H p;GZ*zI0

TAG:

 

评分:0

我来说两句

Open Toolbar