写点什么

需要 100% 的测试覆盖率吗?

  • 2007-05-31
  • 本文字数:937 字

    阅读完需:约 3 分钟

多少测试才算够用呢?答案因人而异。有人会告诉你要做到 100%的测试覆盖率。另一些人却不这么想,他们认为这个问题的答案因测试代码质量的不同而不同,而衡量测试覆盖率并不能说明这些测试及被测试代码的质量。

来自 ObjectMentor 的 Tim Ottinger 写道:“如果你正在进行真正的 TDD,那么你的测试覆盖率应该很高,因为你只有编写出产品级代码才能满足测试的部分。”这很巧妙地表明,TDD 对已有代码的测试覆盖率几乎没有什么影响。

我并不是说代码覆盖率应该很低,只是说随着我们的进展,我们写的每个独立的测试应该对我们的代码覆盖率影响非常小……这是一个很令我感兴趣的想法。

通过示例,Andy Glover 向我们说明了代码覆盖的度量可能会给我们带来了错误的安全感。对于代码覆盖的度量可能会告诉你哪些代码没有被测试,但不能准确地告诉你哪些代码 _ 被 _ 测试过了。同样地,Tobias Schlitt 认为:对代码覆盖的度量是很重要的,因为它会告诉我们哪部分是我们没有覆盖到的。

诚然,一个测试套件的高代码覆盖率根本不能说明代码经过了很好的测试(假如你自己不写代码和测试的话)。但是反过来说是成立的:一个较低的代码覆盖率毫无疑问还是意味着这个测试套件并不充分。就让我来深入分析一下代码覆盖率问题,看看它会给你带来什么吧。

测试大师 Testivus 认为“结果因情况而异”是最好的解释。对于那些刚开始写测试的人来说:

现在他写了很多代码,但还没有测试代码,那他还有很长的路要走。此时把重点放在代码覆盖率上的话将会很郁闷,而且毫无用处。他现在最好开始写一些测试并运行这些测试,覆盖率问题是他之后才需要考虑的事情。

对于那些有经验的开发者来说:

……所需的测试数量依赖于很多因素,而且在“需要考虑哪些因素”这个问题上,她比我更清楚,毕竟代码是她写的。虽然没有那种简单明了的答案,但她还是足以应付这个事实。

最后,对于那些只想得到答案的人来说:

第三个程序员想得到仅仅是简简单单的答案——即便事实上简简单单的答案并不存在……而且(即便有)他在稍后并不会遵循这些答案。

就象在这些 Blog 中说的那样,测试的关注点在于测试给质量检验带来的益处。从这个角度出发,我们应该意识到,对测试覆盖率的度量可以告诉我们遗漏了什么,而不是告诉我们哪些做的很好。

查看英文原文: 100% Test Coverage?

2007-05-31 02:301792
用户头像

发布了 100 篇内容, 共 25.0 次阅读, 收获喜欢 5 次。

关注

评论

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

如何为政企移动办公加上一道“安全锁”?

BeeWorks

删除视图——基于函数的视图 Django

海拥(haiyong.site)

Python django 6月月更

知识管理在业务中的价值如何体现

小炮

知识管理

Java不支持协程?那是你不知道Quasar!

码农参上

协程 Java后端

什么是RESTful,REST api设计时应该遵守什么样的规则?

wljslmz

RESTful 6月月更

新版负载均衡WebClient CRUD

Damon

微服务架构 微服务框架 6月月更

Development status of full color LED display

Dylan

LED display full-color LED display Outdoor LED display

【Meetup 预告】RocketMQ OpenMLDB Connector,实时数据到特征工程的高速传输

第四范式开发者社区

机器学习 数据库 开源 云原生 特征平台

"不敢去怀疑代码,又不得不怀疑代码"记一次网络请求超时分析

华为云开发者联盟

前端 开发 HTTP 华为云

R 和 Python用于统计学分析,哪个更好?

Jackpop

安全信得过!天翼云数据安全管理平台通过评测

天翼云开发者社区

加密市场进入寒冬,是“天灾”还是“人祸”?

鳄鱼视界

多年亿级流量下的高并发经验总结,都毫无保留地写在了这本书中

博文视点Broadview

ironSource Luna 推出苹果搜索广告限时优惠,注册即享3个月免费服务

科技热闻

wallys/WiFi6 MiniPCIe Module 2T2R 2×2.4GHz 2x5GHz

wallys-wifi6

wifi6 mtk7915 mtk7975

2022年中国重卡智能化升级专题研究

易观分析

智能汽车

加密市场进入寒冬,是“天灾”还是“人祸”?

股市老人

口令安全是什么意思?等保2.0政策中口令安全标准条款有哪些?

行云管家

网络安全 口令安全 等保 等保2.0 口令

Vue-17-组件

Python研究所

6月月更

MongoDB在腾讯零售优码中的应用

杨亚洲(专注MongoDB及高性能中间件)

mongodb 分布式数据库mongodb 构架 NoSQL 数据库 数据库·

入驻快讯|欢迎极狐GitLab 正式入驻 InfoQ 写作社区!

极狐GitLab

gitlab git 学习 #GitLab DevOps工具

uni-app进阶之https请求方式/状态管理【day11】

恒山其若陋兮

6月月更

VHEDT业务发展框架

凌晞

框架 构架

网络安全的五大特点有哪些?五大属性是什么?

行云管家

网络安全 数据安全 网络安全法

TDengine 连接器上线 Google Data Studio 应用商店

TDengine

tdengine 时序数据库 Google Data Studio

IntelliJ IDEA中有什么让你相见恨晚的好用插件?

Jackpop

畅享高性能计算!天翼云HPC解决方案来了

天翼云开发者社区

10款超牛Vim插件,爱不释手了

Jackpop

洞见科技牵头的全球「首个」IEEE隐私计算「互联互通」国际标准正式启动

洞见科技

隐私计算 IEEE 互联互通

直播出海 | 国内直播间再出爆品,「外卷」全球如何致胜

融云 RongCloud

天翼云乘风新基建,构建数字化转型“4+2”能力体系

天翼云开发者社区

需要100%的测试覆盖率吗?_研发效能_Amr Elssamadisy_InfoQ精选文章