写点什么

单元测试 vs. 私有方法

  • 2009-02-04
  • 本文字数:841 字

    阅读完需:约 3 分钟

前几天,Naresh Jain 在 Managed Chaos 上发了篇博客,总结了一些测试中的 bad smell 。例如:

一个方法中有太多 test case——被测试的方法做了太多事情。
太多的 setup/teardown——表示被测试类的耦合性太高。
改变一个地方,多处测试受影响——也许是测试的设计问题,也许是实现代码中有过多依赖。
测试上下文中有太多依赖——设计中的耦合性太高。
测试运行速度缓慢——表示你的单元测试也许在使用外部系统,例如网络、数据库、文件系统等等。通常也意味着被测试类有过多的职责。
……

里面还有一条:

为了测试的目的,把成员变量或者方法的访问权限变成 protected 或者 public——可能是因为测试代码跟被测试的代码耦合太高,也可能是本来私有的东西有太多行为,这种情况下应该考虑把它抽出来作为独立的对象。

怎么为私有方法写单元测试?这个难题由来已久了。

有人会选择跳过私有方法,有人会选择去掉 private 限定符;跳过私有方法自然不是良策,但提升访问权限也会破坏封装,在 Naresh Jain 看来也算得上是 bad smell,那怎么解决才好?

Naresh Jain 对此语焉不详,不过还好, Agile Tips 在 08 年 11 月有一篇文章介绍了怎么测试私有方法。文末作者说道:

应该为私有方法添加测试么?我的答案是,在成功的用了 TDD 或者测试驱动重构(Test-Driven Refactoring)以后,你的代码中就不会出现针对私有方法的测试。

如果你用 TDD 编写全新的代码,在没有测试之前是没有功能的。私有方法是到了重构那一步的最后才会出现。把代码转移到私有方法中的这个过程,已经被先前写过的测试覆盖到了。所以,如果你成功了用了 TDD,代码中就不会出现针对私有方法的测试。

如果你在改善遗留代码,你就该使用测试驱动重构。这样的话,可能会临时针对私有方法写一些测试。但是,随着测试覆盖率的增加,那些 public 方法的测试会覆盖到所有的路径,也包括了私有方法的调用。所以,你也不再需要测试私有方法。

在文中,作者也举了一些简单例子说明了用 TDD 的方式重构出私有方法,以及用测试驱动重构处理遗留代码的方式,更多细节请阅读原文

2009-02-04 19:367921
用户头像

发布了 197 篇内容, 共 52.4 次阅读, 收获喜欢 20 次。

关注

评论

发布
暂无评论
发现更多内容

架构师训练营第1周作业

无名氏

【总结】架构师要做什么

孙野

食堂就餐卡系统设计

史慧君

架构师学习第一周作业

云峰

【架构训练营】第一期

云064

第一周总结

王志祥

极客大学架构师训练营

食堂就餐卡系统设计

小遵

食堂就餐卡系统设计

chinsun1

架构文档

架构师训练营-Week 01 学习总结

华乐彬

学习 架构 架构师 极客大学架构师训练营

第一周作业

Jeremy

食堂就餐卡系统设计

食堂就餐系统架构设计(训练营第一课)

看山是山

极客大学架构师训练营 UML 食堂就餐系统

架构师训练营第一周心得

努力努力再努力m

极客大学架构师训练营

学习总结-架构师训练营-第一周

走过路过飞过

架构师-第一课总结

free[啤酒]

食堂就餐卡系统设计

olderwei

week1-食堂就餐卡系统

张健

食堂就餐卡

食堂就餐卡系统设计

呱呱

极客大学架构师训练营 作业

架构师0期 | 食堂就餐卡系统架构设计文档

刁架构

极客大学架构师训练营

架构师第一周总结

suke

极客大学架构师训练营

关于架构设计的学习记录

imicode

Homework-食堂就餐卡系统设计

River Tree

架构设计 Homework

第二课 以图服人

Geek_bobo

week1作业

数字

week1《作业二:根据当周学习情况,完成一篇学习总结》

任鑫

架构师训练营-Week 01 命题作业

华乐彬

极客大学架构师训练营 架构文档 作业

食堂就餐卡系统设计

泛岁月的涟漪

架构师训练营 - 学习总结 - 第一周

桔子

week1-学习总结

张健

架构师训练营第一周学习总结

a晖

如何开始成为一名架构师

Ph0rse

极客大学架构师训练营

单元测试 vs. 私有方法_研发效能_李剑_InfoQ精选文章