AICon 上海站|日程100%上线,解锁Al未来! 了解详情
写点什么

单元测试 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:368233
用户头像

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

关注

评论

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

ELK性能优化实战总结:我强任我强,你“跪”标准好好学

Java 程序员 后端

gRPC学习之五:gRPC-Gateway实战

Java 程序员 后端

Elasticsearch聚合学习之四:结果排序(1)

Java 程序员 后端

elasticsearch实战三部曲之二:文档操作

Java 程序员 后端

Elasticsearch查询速度为什么这么快?看啥?问你呢!

Java 程序员 后端

Eureka(F版本)教程三 服务消费者(Feign)

Java 程序员 后端

Flink数据源拆解分析(WikipediaEditsSource)

Java 程序员 后端

GitHub 上 1

Java 程序员 后端

Dubbo overrideDirectoryUrl的作用?

Java 程序员 后端

Docker镜像超详细介绍

Java 程序员 后端

Elasticsearch Document Index API详解、原理与示例

Java 程序员 后端

Filter 过滤器和 Listener 监听器

Java 程序员 后端

Flutter中的widget

Java 程序员 后端

GitHub上标星75k+超牛的《Java面试突击版》,分享PDF离线版

Java 程序员 后端

Gitlab Runner的分布式缓存实战

Java 程序员 后端

HttpClient工具类

Java 程序员 后端

Docker系列(2)--容器和镜像的使用

Java 程序员 后端

elasticsearch的字符串动态映射

Java 程序员 后端

Hadoop之MapReduce04【客户端源码分析】

Java 程序员 后端

Elasticsearch文档读写模型实现原理

Java 程序员 后端

Elasticsearch聚合学习之四:结果排序

Java 程序员 后端

Flink on Yarn三部曲之三:提交Flink任务

Java 程序员 后端

Flink的sink实战之一:初探

Java 程序员 后端

Go实战(三)-数组array、切片slice语法详解

Java 程序员 后端

Eureka(F版本)教程五 路由网关(zuul)

Java 程序员 后端

Git Flow 的正确使用姿势

Java 程序员 后端

Elasticsearch Mapping parameters(主要参数一览)

Java 程序员 后端

Elasticsearch中的Term查询和全文查询

Java 程序员 后端

ELK太重?试试KFC日志采集

Java 程序员 后端

HarmonyOS(鸿蒙)——全面入门

Java 程序员 后端

dubbo实战之三:使用Zookeeper注册中心

Java 程序员 后端

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