《Unit Testing》1.3 使用覆盖率指标来度量测试套件的好坏

使用覆盖率来度量测试套件(Test Suite)的质量

有两种比较流行的测试覆盖率的度量方法:

  • 代码覆盖率

  • 分支覆盖率

覆盖率度量会显示一个测试套件(Test Suite)会执行多少代码,范围从 0 100%

除了上述两种方法之外,还有很多其它的度量方法。它们都是被用来评估一个测试套件的质量的。

 

通常人们会认为,这个覆盖率越高越好。不幸的是,这没那么简单,覆盖率度量确实能提供非常有价值的反馈,但是它们无法有效的评估出测试套件的质量。这一点与代码可进行单元测试的能力一样:覆盖率度量是一个非常好的负向指示(能评估出测试套件是否较差),但它无法评估出测试套件是否很好。

 

代码覆盖率度量

第一种,也是使用最多的度量方式就是代码覆盖率(code coverage,也叫测试覆盖率 test coverage)。它的公式如下:

 

 

例如:

 

 

该测试对上面的有效代码(共 5 行,89101213)的覆盖率达到了 80%891213)。

 

如果我重构一下代码,如下图所示呢:

可以看到有效代码行数变成了 3 行(8910),它们都是绿色,说明都被覆盖了。从工具也可以看到覆盖率变成了 100%

 

所以,代码覆盖率确实变化了,达到了 100%。但是测试套件的质量提高了吗?当然没有,我只是在方法内部重新罗列了一下代码,而测试仍然只验证了相同数量的可能结果。

 

分支覆盖率度量

另一种覆盖率度量方法是分支覆盖率。其公式如下:

 

 

想要使用复制覆盖率,你得想办法把代码里所有可能的分支求和,然后再检测测试走了多少分支。

 

例子:

还是之前的例子,IsStringLong 方法里面一共有两种情况,也就是两个分支。而测试只会运行小于等于 5 这种情况,所以分支覆盖率为 50%

 

注意:分支覆盖率里面只考虑分支数量,并不考虑所执行的代码行数。

 

覆盖率度量的问题

尽管分支覆盖率的结果比代码覆盖率更有用一些,但是仍然无法依赖它们中的任何一个来决定测试套件的质量:

  • 无法保证测试会验证被测试系统SUT,System Under Test)所有可能的结果

  • 没有一种覆盖率度量法可以测试外部库的代码路径

 

为了让代码路径真正被测试,而不仅仅是路过执行,单元测试必须有适当的断言。

 

例子:

这段代码其实产生了两个结果,分别是 13 15 行,只有第 15 行的结果被测试了,而第 13 行的结果(第 7 行的属性)并没有被验证。

而两种测试覆盖率的结果仍然没有变化,还是 100% 50%

所以说,覆盖率度量无法保证代码会被测试,只能保证代码会被执行而已。

 

但是,如果你确实考虑了每种可能,同时结合分支覆盖率,那么是否能够提供一个可靠的机制,来判断测试套件的质量呢?很不幸,不能。

因为没有任何覆盖率度量方法能考虑外部库中的代码路径。

 

例如:

这个测试里,分支覆盖率达到了 100%,但是它没考虑 .NET 提供的 int.Parse 这个方法的可能结果。对于 int.Parse 至少有以下几种可能:

而我们只考虑了其中一种。所以您可能会遇到许多极端情况,并且无法查看测试是否将所有情况都考虑在内。

 

这并不是说覆盖率度量应该考虑外部库的代码路径(它们不应该),而是说明你不能指望这些度量来评估单元测试的质量好坏。覆盖率度量无法判断您的测试是否详尽无遗; 也不能说明是否有足够的测试。

 

特定的覆盖率数字

要把覆盖率度量当成一个指标,而不是一个目标。

就如同生病住院的病人,体温高可能表示发烧,它是一个有用的观察。但是医院不能把不择手段降低病人的体温当成治病的目标。

 

通常,如果系统核心某块的测试的覆盖率较高的话是很好的,但是如果把高覆盖率当成目标就不好了。

 

就个人而言:我认为覆盖率低于 60% 肯定不好,这说明有大量的代码未测试。但是更高的覆盖率数字并不能代表什么。所以度量覆盖率只是验证测试套件质量的第一步而已。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/309108.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

对区间的模糊排序

对区间的模糊排序 算法导论第三版第二部分7-6题 Interval find_intersection(vector<Interval> &array,int start,int end) {int random random_include_left_right(start,end);Interval key array[end];array[end] array[random];array[random] key;key arra…

Linux创始人:v5.8是有史以来最大的发行版之一

导语Linux v5.8已经修改了所有文件的20&#xff05;&#xff0c;是迄今为止变化最大的一次发行版。正文Linux创始人Linus Torvalds表示&#xff1a;Linux内核5.8版是“我们有史以来最大的发行版之一”。如果一切顺利&#xff0c;Linux v5.8稳定版应该在2020年8月的某个时候出现…

算法-排序-计数排序(包含对非负数和整数的排序)

计数排序 时间复杂度O&#xff08;n&#xff09; 特点&#xff1a;稳定 限制&#xff1a;对0到maximum中的数进行排序 maximum要求&#xff0c;比数组中最大值大或者相等 有拓展版本的计数排序&#xff08;在文章基数排序内&#xff09; 基数排序链接 void counting_sort(int…

[高等数学]这你不背?

求导及求微分的基本公式: 泰勒中值定理: 麦克劳林公式: 不定积分公式: 凑微分: 第二类换元积分法常用的三种情况: 求高阶导数的几个公式: 二阶常系数非齐次线性微分方程的特解: 排列组合公式: C的计算&#xff1a; 下标的数字乘以上标的数字的个数,且每个数字都要-1.再除以上标…

怎么开会才不浪费时间?

这里是Z哥的个人公众号每周五11&#xff1a;45 按时送达当然了&#xff0c;也会时不时加个餐&#xff5e;我的第「148」篇原创敬上大家好&#xff0c;我是Z哥&#xff0c;先祝大家端午节日快乐。节日期间就发篇比较短的文章吧。人在职场混&#xff0c;开会应该是本职工作之外花…

在O(1)的时间内计算n个整数落在区间[a,b]的个数(预处理时间为O(n+k))

在O&#xff08;1&#xff09;的时间内计算n个整数落在区间[a,b]的个数 预处理时间为O&#xff08;nk) 算法导论第三版8.2-4题 int find_inverter_count(int *array,int length,int maximum,int inverter_left,int inverter_right) {if(inverter_left<0 || inverter_right…

汇编语言中常见的标志位: CF, PF, AF, ZF, SF,TF,IF,DF, OF

一、运算结构标志位 1.CF(进位标志位)&#xff1a;主要用来反映运算是否产生进位或借位&#xff0c;产生进位或借位则CF1&#xff0c;否则CF0。 2.PF(奇偶标志位)&#xff1a;用于反映运算结果中“1”的个数的奇偶性&#xff0c;如果“1”的个数为偶数&#xff0c;则PF1&…

算法-排序-基数排序(对任意整数排序)

基数排序 时间复杂度&#xff1a;Θ(d(nk)) d&#xff1a;元素的位数&#xff0c;k元素中每位数的取值区间大小 非原址排序 1⃣️特点该排序只能每次为基数为1位数进行排序 void radix_sort(int *array,int length,int digits){vector<KeyValuePair> temp_array(length…

.NET 5.0预览版6发布:支持Windows ARM64设备

2020年6月25日&#xff0c;微软dotnet团队在博客宣布了第六个 .NET 5.0 的预览版&#xff1a;https://devblogs.microsoft.com/dotnet/announcing-net-5-0-preview-6/&#xff0c;在改进性能的同时增加了一些新的功能。ASP.NET Core和 EF Core也将于今日发布了。注意&#xff1…

利用真值表法求取主析取范式以及主合取范式的实现(C++)

代码如下: #include <iostream> #include <stack> #include <string> #include <vector> using namespace std; const int N 300; stack<char> s; stack<char> v; int seq; bool vis[N]; bool flag[N]; void dfs(int n); vector<int&…

基于 Blazor 开发五子棋小游戏

今天是农历五月初五&#xff0c;端午节。在此&#xff0c;祝大家端午安康&#xff01;端午节是中华民族古老的传统节日之一。端午也称端五&#xff0c;端阳。此外&#xff0c;端午节还有许多别称&#xff0c;如&#xff1a;午日节、重五节、五月节、浴兰节、女儿节、天中节、地…

工具类—KeyValuePair

工具类KeyValuePair .h文件 #ifndef C11LEARN_KEYVALUEPAIR_H #define C11LEARN_KEYVALUEPAIR_Hclass KeyValuePair { public:int key;int value; public:KeyValuePair();KeyValuePair(int key,int value); };#endif //C11LEARN_KEYVALUEPAIR_H.cpp文件 #include "KeyV…

汇编cmp比较指令详解

刚刚看到了cmp指令&#xff0c;一开始有点晕。后来上网找了些资料&#xff0c;终于看明白了&#xff0c;为了方便初学者&#xff0c;我就简单写下我的思路吧。高手绕过&#xff0c;谢谢&#xff01; cmp(compare)指令进行比较两个操作数的大小例:cmp oprd1,oprd2为第一个操作减…

如何在ASP.NET Core中使用SignalR构建与Angular通信的实时通信应用程序

图片假设我们要创建一个监视Web应用程序&#xff0c;该应用程序为用户提供了一个能够显示一系列信息的仪表板&#xff0c;这些信息会随着时间的推移而更新。第一种方法是在定义的时间间隔&#xff08;轮询&#xff09;定期调用API 以更新仪表板上的数据。无论如何&#xff0c;还…

算法-排序-桶排序

桶排序 桶排序期望的运行时间是Θ(n) 局限&#xff1a;输入数组要在[0,1)之间&#xff08;下面有更通用的版本3⃣️&#xff09; 1⃣️内置排序没有用插入排序而是c自带的sort&#xff0c;要用插入排序可保证算法稳定性。 void bucket_sort(float *array,int length){vector&…

LED计数电路,5输入按键编码器,7段数码管显示驱动集成为LED计数测试电路

LED计数电路: 5输入按键编码器: 7段数码管显示驱动真值表: 集成:

越卖越涨?腾讯股票3月后大涨45%,超越“阿里”成中国第一,市值相当于14.3个百度!...

01 腾讯股价大涨据股市最新消息&#xff1a;腾讯股价已连续3个交易日上涨, 其中6月22日腾讯股价重返470港元关口&#xff0c;公司市值突破4.5万亿港元&#xff0c;折合4.0万亿人民币&#xff1b;而6月23日上午腾讯股价再度大涨4.05%&#xff0c;刷出493.8港元的新高&#xf…

4位无符号比较器设计

4位比较器原理&#xff1a; 4位比较 a3a2a1a0 : b3b2b1b0&#xff0c;比较顺序从高位到低位&#xff0c;当高位大、小关系确定时则无需看低位&#xff0c;当高位相等时再看相邻低位的关系。 注意&#xff1a;对于三个比较结果&#xff0c;已知其中任意两个&#xff0c;可以用…

算法导论水壶问题(第三版第八章思考题8-4)

算法导论水壶问题 &#xff08;第三版第八章思考题8-4&#xff09; 本算法只适用于解题&#xff0c;不通用。 期望的时间复杂度O&#xff08;nlgn&#xff09; Kettle.h文件 #ifndef C11LEARN_KETTLE_H #define C11LEARN_KETTLE_H#include <iostream> #include <vec…