03_测试覆盖率

测试覆盖率

学习目标

掌握各种测试覆盖率的含义

能计算各种测试覆盖率

理解覆盖率在白盒测试中所起的作用

覆盖率概念

覆盖率是用来度量测试完整性的一个手段。覆盖率是测试技术有效性的一个度量。

覆盖率 = (至少被执行一次的item数)/item的总数

覆盖率按照测试方法大体上可以划分为三大类,即白盒覆盖(White-Box Coverage)、灰盒覆盖(Gray-Box Coverage)和

黑盒覆盖(Black-Box Coverage)。

测试用例设计不能一味追求覆盖率,因为测试成本随覆盖率的增加而增加。

白盒覆盖率

白盒覆盖率中使用的最常见的就是逻辑覆盖率(Logical Coverage),也叫代码覆盖率(Code Coverage)或结构化覆盖率(Structural Coverage)。

逻辑覆盖包括:

语句覆盖

语句覆盖(Statement Coverage)的含义是,在测试时运行被测程序后,程序中被执行到的可执行语句的比率:

语句覆盖率 = (至少被执行一次的语句数量)/(可执行的语句总数)

在测试时,首先设计若干个测试用例,然后运行被测试程序,使程序中的每个可执行语句至少执行一次。

语句覆盖率

即使语句覆盖率达到百分之100%也会有缺陷发现不了,所以覆盖率只是我们度量的手段。

判断覆盖率

判断覆盖(Decision Coverage)也叫分支覆盖(Branch Coverage),它的含义是,在测试时运行被测程序后,

程序中所有判断语句的取真分支和取假分支被执行到的比率:

判定覆盖率= (判定结果被评价的次数)/(判定结果的总数)

在测试时,首先设计若干个测试用例,然后运行被测试程序,使得程序中每个判断的取真分支和取假分支至少经历一次,

即判断的真假值均曾被满足。

即使判定覆盖率达到了100%也会有缺陷发现不了,所以覆盖率只是我们度量的手段。

判断覆盖

条件覆盖

条件覆盖率

条件覆盖(Condition Coverage)的含义是,在测试时运行被测程序后,所有判断语句中每一个

条件的可能取值(真值和假值)出现过的比率:

条件覆盖率 = (条件操作数值至少被评价一次的数量)/(条件操作数值的总数)

判定条件覆盖

判定-条件覆盖率

判定条件覆盖(Decision Condition Coverage),也叫分支条件覆盖(Branch Condition Coverage),也叫分支

条件覆盖(Branch Condition Cverage)。所谓判定一条件覆盖就是设计足够的测试用例,使得判断中每个调价函所有

可能取值至少执行一次,同时每个判断本身的所有可能判断结果至少执行一次。

判定条件覆盖率 = (条件操作数值或判定结果至少被评价一次的数量)/(条件操作数值总数+判定结果总数)

条件组合覆盖

条件组合覆盖率(Multiple Condition Coverage),基本思想是:设计足够的测试用例,使得每一个判定中条件的各种可能组合

都至少出现一次。

条件组合覆盖率 = (条件组合至少被评价一次的数量)/(条件组合总数)

路径覆盖率

路径能否全面覆盖在软件测试中是个重要问题,如果程序中的每一条路径都得到考验,才能说程序受到了全面检验

即使对于路径数很有限的程序已经做到了路径覆盖,仍然不能保证被测程序的正确性

每种覆盖率度量的时候都有其局限性,因此要把各种覆盖率组合起来对测试进行度量。

函数覆盖

有很多测试工具,例如TrueCoverage,PureCoverage等,都提供了函数覆盖(Function Coverage)的概念,函数覆盖是针对系统

或一个子系统的测试的,它表示在该测试中,有哪些函数被测试到了,其被测试到的频率有多大,这些函数在系统所有函数中占

的比例有多大。函数覆盖是一个比较容易自动化的技术。

函数覆盖 = (至少被执行一次的函数数量)/(系统中函数的总数)

接口覆盖

接口覆盖(Interface Coverage),或者称为入口点覆盖(Entry-Point Coverage),要求通过设计一定的用例使得系统的每个接口被测试到。

接口覆盖 = (至少被执行一次的接口数量)/(系统中接口的总数)

灰盒覆盖率

黑盒覆盖率

面向对象的覆盖率


*/

你可能感兴趣的:(03_测试覆盖率)