测试覆盖率
学习目标
掌握各种测试覆盖率的含义
能计算各种测试覆盖率
理解覆盖率在白盒测试中所起的作用
覆盖率概念
覆盖率是用来度量测试完整性的一个手段。覆盖率是测试技术有效性的一个度量。
覆盖率 = (至少被执行一次的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),要求通过设计一定的用例使得系统的每个接口被测试到。
接口覆盖 = (至少被执行一次的接口数量)/(系统中接口的总数)
灰盒覆盖率
黑盒覆盖率
面向对象的覆盖率
*/