• 软件测试系列白盒测试覆盖率的问题


    覆盖率##

    一、覆盖率的概念###

    覆盖率是用来度量测试完整性的一个手段,现在有越来越多的测试工具能够支持覆盖率测试,但是它们本身并不包含测试技术,只是测试技术有效性的一个度量。白盒测试中经常用到的覆盖率是逻辑覆盖率。
    

    二、覆盖率的目的###

    覆盖率对于软件测试有着非常重要的作用,通过覆盖率我们可以知道我们的测试是否充分,我们测试的弱点在哪些方面,进而指导我们设计能够增加覆盖率的测试用例,有效的提高测试质量。
    
    一方面覆盖率技术可以指导测试用例的设计;另一方面,可以通过覆盖率来衡量白盒测试的力度。
    

    三、逻辑覆盖率主要有以下六种:###

    (1)语句覆盖;
    
    (2)判定覆盖;
    
    (3)条件覆盖;
    
    (4)判定条件覆盖;
    
    (5)条件组合覆盖;
    
    (6)路径覆盖。
    

    1、语句覆盖(Statement Coverage)

    语句覆盖的含义是,在测试时,运行被测程序后,程序中被执行到的可执行语句的比率。
    
    语句覆盖=(至少被执行一次的语句数量)/可执行的语句总数。
    
    *语句覆盖是最弱的一种覆盖方式。
    

    2、判定覆盖(Decision Coverage)

    判定覆盖也叫分支覆盖(Branch Coverage),含义是:在测试时,运行被测程序后,程序中所有判断语句的取真分支和取假分支被执行到的比率。
    
    判定覆盖=(判定结果被评价的次数)/判定结果的总数。
    

    3、条件覆盖(Condition Coverage)

    条件覆盖的含义是:在测试时,运行被测程序后,所有判断语句中每个条件的可能取值(真值和假值)出现过的比率。
    
    条件覆盖=(条件操作数值至少被评价一次的数量)/(条件操作数值得总数)
    

    4、判定条件覆盖(Decision Condition Coverage)

    判定条件覆盖也叫分支条件覆盖(Branch Condition Coverage)它的含义是:在测试时,运行被测程序后,所有判断语句中每个条件的所有可能值(为真为假)和每个判断本身的判定结果(为真为假)出现的比率。
    
    判定条件覆盖=(条件操作数值或判定结果至少被评价一次的数量)/(条件操作数值总数+判定结果总数)
    
    *判定条件覆盖率实际上就是判定覆盖率和条件覆盖率的组合。
    

    5、条件组合覆盖(Condition combination coverage)

    条件组合覆盖的含义是,在测试时,运行被测程序后,所有语句中子条件所有可能的取值结果组合出现过的比率。
    
    条件组合覆盖=(至少被执行到一次的条件组合)/总的可能的条件组合数。
    
    *条件组合覆盖是除路径覆盖以外,最强的一种覆盖方式。
    

    6、路径覆盖(Path Coverage)

    路径覆盖的含义是:在测试时,运行被测程序后,程序中所有可能的路径被执行过的比率。
    
    路径覆盖=(至少被执行到一次的路径数)/总的路径数。
    

    四、总结五种逻辑覆盖率。###

    1、语句覆盖是最弱的一种覆盖方式。

    2、条件组合覆盖是除路径覆盖以外,最强的一种覆盖方式。

    3、百分百的条件组合覆盖一定包含:百分百的语句覆盖、百分百的判定覆盖、百分百的条件覆盖以及百分百的判定条件覆盖;但不一定包含百分百的路径覆盖。

    4、百分百的判定覆盖(分支覆盖)一定包含:百分百的语句覆盖。

    5、百分百的条件覆盖不一定包含:百分百的语句覆盖。

    五、举例说明。###

    图1

    <img src="//images0.cnblogs.com/blog2015/706704/201504/291739062409387.jpg" width="400" height=400" align=center/>

    范例一

    1、分析图1(被测程序流程图)

    (1)语句:有两条语句,分别为,X=X/A 和 X=X+1。

    (2)判定:有两个判定,分别为(A>1)AND(B=0) 和 (A=2)OR(X>1);这两个判定,分别都有两种可能,true或者false,图中我们用F或者T来表示,所以说这个流程中判定结果的总数为四。

    (3)条件:每个判定里面都包含了两个子条件,每个子条件都有两种可能性,true或者false,图中我们分别用T1 F1;T2 F2...来表示,每个判定里面就有四种可能,这样,这个流程图中的条件操作数值的总数为八。

    (4)判定条件:判定条件覆盖率实际上就是判定覆盖率和条件覆盖率的组合。

    (5)条件组合:上面我们在条件里面提到过的,每个判定里面都包含了两个子条件,每个子条件都有两种可能性,true或者false,图中我们分别用T1、F1、T2、F2...来表示,但是和条件覆盖不一样的是,每个子条件里面的两种可能性(T或者F)都要进行两两组合,即进行排列组合,那么,条件组合的总数为八种组合。分别为:T1T2,F1F2,T1F2,F1T2;T3T4,F3F4,T3F4,F3T4.

    **【 这个时候大家不能混淆这两个概念,只是因为2个判定比较特殊而已,因为2乘以2和2的2次方是相等的,条件里面是八种条件,而条件组合里面是八种组合。如果一个判定里面有三个子条件的话,这一个判定里面的条件总值就成为2乘以3;而条件组合就是2的3次方。】

    (6)路径:图1中路径共有四条,即:abd,ace,abe,acd。

    2、给出用例,计算以上六种覆盖率的值

    执行CASE:A=2;B=1;X=3。
    

    在计算覆盖率之前,我们首先要看判定中的子条件在做什么运算,第一个判定中,这两个子条件在做与运算,(一个假即为假)。第二个判定中,这两个子条件在做或预算,(一个真即为真)。

    (1)语句覆盖率:1/2 (50%)

    分析:第一个判定中子条件的值为T1、F2(一真一假),所以我们走F这条分支,此时X=X/A这条语句没有被执行到;接下来,我们看第二个判定,它的子条件的值为T3、T4(都为真),所以我们走T这条分支,这时,语句X=X+1这条语句被执行到了。也就是说,我们只执行到一条语句,所以语句覆盖率位1/2。
    

    (2)判定覆盖率:2/4 (50%)

    分析:我们刚才在分析语句覆盖的时候,我们提到第一个判定语句走的是F分支,第二个判定语句也的是T分支,所以我们共走了两条分支,分支总数为4,所以判定覆盖率为:2/4。
    

    (3)条件覆盖率:4/8 (50%)

    第一个判定中子条件的值为T1、F2;第二个判定的子条件的值为T3、T4。也就是说我们执行到的条件总数为4;总共的条件操作总值为8,所以条件覆盖率为:4/8。
    

    (4)判定条件覆盖率:6/12 (50%)

    前面我们已经分析过了,判定条件覆盖率实际上就是判定覆盖率和条件覆盖率的组合,所以判定条件覆盖率就等与,2/4 (判定覆盖率)+ 4/8(条件覆盖率)=6/12(注意,这里的“+”代表的是组合,而不是算数相加,所以是分子分母分别相加即可)。
    

    (5)条件组合覆盖率:2/8 (25%)

    同样的,在条件覆盖率分析中我们已经提到过了,第一个判定中子条件的组合为T1F2;第二个判定的子条件的组合为T3T4,也就是说我们执行到了两种组合;我们在分析流程图的时候已经提到过,总的可能的条件总数为八种组合,所以说条件组合覆盖率为:2/8。
    

    (6)路径覆盖率:1/4 (25%)

    在流程图分析中我们已经提到,路径共有四条,而我们走到的路径为只有abe一条,所以路径覆盖率为:1/4。
    

    范例二:

    被测程序流程图还是上面范例一的图1

    执行case1:A=2,B=0,X=3;
    
    执行case2:A=1,B=0,X=1。
    

    计算这两种情况下的6种覆盖率。

    (1)语句覆盖率:2/2 (100%)

    case1:第一个判定中子条件的值为T1、T2(都为真),所以我们走T这条分支,执行到X=X/A这条语句;接下来,第二个判定,它的子条件的值为T3、T4(都为真),所以我们走T这条分支,这时,语句X=X+1这条语句被执行到了。也就是说,我们把两条语句都执行到了,所以语句覆盖率位2/2。
    
    所以说case1这一条用例就可以到达100%的语句覆盖,我们就不用再去执行case2了。
    

    (2)判定覆盖率:4/4 (100%)

    case1:我们刚才在分析语句覆盖的时候,我们提到第一个判定语句走的是T分支,第二个判定语句走的也是T分支;
    
    case2:第一个判定语句中子条件的值为F1、T2,所以我们走F分支;第二个判定语句中子条件的值为F3、F4,所以我们依然走F分支;
    
    上面两个用例把我们两个判定中的4个分支都执行到了,所以判定覆盖率为4/4(100%)。
    

    (3)条件覆盖率:7/8(100%)

    case1:第一个判定语句中子条件的值为T1、T2,第二个判定条件中子条件的值为T3、T4;
    
    case2:第一个判定语句中子条件的值为F1、T2,第二个判定条件中子条件的值为F3、F4;
    
    这两个用例执行了七种条件,F2没有执行到,所以条件覆盖率为:7/8(100%)。
    

    (4)判定条件覆盖率:11/12。

    判定条件覆盖率=判定覆盖率和条件覆盖率的组合 = 4/4 + 7/8 = 11/12。
    

    (5)条件组合覆盖率:4/8 (50%)

    case1:第一个判定语句中子条件的组合为T1T2,第二个判定条件中子条件的组合为T3T4;
    	
    case2:第一个判定语句中子条件的组合为F1T2,第二个判定条件中子条件的组合为F3F4;
    
    我们可以看出:这两个用例只执行到八种组合中的四种组合,所以条件组合覆盖率为4/8(50%)。
    

    (6)路径覆盖率:2/4(50%)

    case1:在这条用例中我们所执行到的路径为:ace。
    
    case2:在这条用例中我们所执行到的路径为:abd。
    
    这两条用例执行到两条路径(ace和abd),还有两条路径(abe和acd)没有执行到,所以路径覆盖率为2/4(50%)。
  • 相关阅读:
    C# 多线程和异步 (转发)
    WCF —— Endpoint & Binding & netTcpBinding Overview(转发)
    http 请求 —— 连接数问题 & httpclient 重用
    WCF ChannelFactory and channels caching, reusing, closing and recovery
    WCF ——从绑定元素认识系统预定义绑定 转载 & NetTcpBinding & 信道工厂(Channel Factory)(转发)
    在C#中利用KeepAlive处理Socket网络异常断开的方法
    WCF _ example
    What happens when I close/abort a WCF channel/proxy?
    WCF —— Consuming WCF Services in .NET Core – Best Practices(转发)
    Python shapely
  • 原文地址:https://www.cnblogs.com/shijiayi/p/4466619.html
Copyright © 2020-2023  润新知