下载此文档

单元测试代码覆盖率浅谈.doc


文档分类:IT计算机 | 页数:约7页 举报非法文档有奖
1/7
下载提示
  • 1.该资料是网友上传的,本站提供全文预览,预览什么样,下载就什么样。
  • 2.下载该文档所得收入归上传者、原创者。
  • 3.下载的文档,不会出现我们的网址水印。
1/7 下载此文档
文档列表 文档介绍
单元测试代码覆盖率浅谈.doc单元测试代码覆盖率浅谈在做单元测试吋,代码覆盖率常常被拿来作为衡虽测试好坏的指标,甚至,用代码覆盖率来考核测试任务完成情况,比如,代码覆盖率必须达到80%或90%。于是乎,测试人员费尽心思设计案例覆盖代码。用代码覆盖率来衡量,冇利也冇冇弊。木文我们就代码覆盖率展开讨论,也欢迎同学们踊跃评论。首先,让我们先來了解一卜•所谓的“代码覆盖率”。我找来了所谓的定义:代码覆盖率=代码的覆盖程度,一种度量方式。上面简如精悍的文字非常准确的描述了代码覆盖率的含义。而代码覆盖程度的度量方式是有很多种的,这里介绍一下最常用的几种:(StatementCoverage)又称行覆盖(LineCoverage),段覆盖(Segmentcoverage),基木块覆盖(BasicBlockCoverage),这是最常用也是最常见的一种覆盖方式,就是度量被测代码中每个可执行语句是否被执行到了。这里说的是“可执行语句”,因此就不会包括像C++的头文件声明,代码注释,空行,等等。非常好理解,只统计能够执行的代码被执行了多少行。需要注意的是,单独一行的花括号{}也常常被统计进去。语句覆盖常常被人指责为“最弱的覆盖”,它只管覆盖代码小的执行语句,却不考虑各种分支的组合等等。假如你的上司只耍求你达到语句覆盖,那么你可以省下很多功夫,但是,换來的确实测试效果的不明显,很难更多地发现代码中的问题。这里举一个不能再简单的例子,我们看下面的被测试代码:intfoo(inta,intb)returna/b;}假如我们的测试人员编写如下测试案例:TeseCase:a=10,b=5测试人员的测试结果会告诉你,他的代码覆盖率达到了100%,并且所有测试案例都通过了。然而遗憾的是,我们的语句覆盖率达到了所谓的100%,但是却没有发现最简单的Bug,比如,当我让b=0时,会抛出一个除零异常。正因如此,假如上而只要求测试人员语句覆盖率达到多少的话,测试人员只要钻钻空子,专门针对如何覆盖代码行编写测试案例,就很容易达到主管的要求。当然了,这同时说明了几个问题:1•主管只使用语句覆盖率來考核测试人员本身就有问题。,钻如此的空子是缺乏职业道德的。3•是否应该采用更好的考核方式来考核测试人员的工作?为了寻求更好的考核标准,我们必须先了解完代码覆盖率到底还有哪些,如果你的主管只知道语句覆盖,行覆盖,那么你应该主动向他介绍还冇更多的覆盖方式。比如:判定覆盖(Decisioncoverage)又称分支覆盖(BranchCoverage),所有边界覆盖(AII-EdgesCoverage),基本路径覆盖(BasicPathCoverage),判定路径覆盖(Decision-Decision-Path)。它度量程序中每一个判定的分支是否都被测试到了。这句话是碍要进一步理解的,应该非常容易和下面说到的条件覆盖混淆。因此我们直接介绍第三种覆盖方式,然后和判定覆盖一起來对比,就明口两者是怎么I叫事了。条件覆盖(Conditioncoverage)它度量判定中的每个子表达式结果true和false是否被测试到了。为了说明判定覆盖和条件覆盖的区别,我们來举一个例子,假如我们的被测代码如下:intfoo(int intb){if(a<10IIb<10)//判定{return0;//分支一}else

单元测试代码覆盖率浅谈 来自淘豆网www.taodocs.com转载请标明出处.

非法内容举报中心
文档信息
  • 页数7
  • 收藏数0 收藏
  • 顶次数0
  • 上传人pppccc8
  • 文件大小84 KB
  • 时间2019-12-08