首页 > 其他分享 >条件覆盖,路径覆盖,语句覆盖,分支覆盖

条件覆盖,路径覆盖,语句覆盖,分支覆盖

时间:2023-04-12 17:55:37浏览次数:39  
标签:语句 false 覆盖 路径 测试用例 判定 条件 true

条件覆盖,路径覆盖,语句覆盖,分支覆盖

 

转自http://hi.baidu.com/%D2%D7%B1%D8%BA%C6/blog/item/f016729f4fbeaebbc9eaf4df.html

语句覆盖是指选择足够的测试用例,使得运行这些测试用例时,被测程序的每一个语句至少执行一次,其覆盖标准无法发现判定中逻辑运算的错误;判定覆盖是指选择足够的测试用例,使得运行这些测试用例时,每个判定的所有可能结果至少出现一次,但若程序中的判定是有几个条件联合构成时,它未必能发现每个条件的错误; 条件覆盖是指选择足够的测试用例,使得运行这些测试用例时,判定中每个条件的所有可能结果至少出现一次,但未必能覆盖全部分支;判定/条件覆盖是使判定中每个条件的所有可能结果至少出现一次,并且每个判定本身的所有可能结果也至少出现一次;条件组合覆盖是使每个判定中条件结果的所有可能组合至少出现一次,因此判定本身的所有可能解说也至少出现一次,同时也是每个条件的所有可能结果至少出现一次;路径覆盖是每条可能执行到的路径至少执行一次;其中语句覆盖是一种最弱的覆盖,判定覆盖和条件覆盖比语句覆盖强,满足判定/条件覆盖标准的测试用例一定也满足判定覆盖、条件覆盖和语句覆盖,条件组合覆盖是除路径覆盖外最强的,路径覆盖也是一种比较强的覆盖,但未必考虑判定条件结果的组合,并不能代替条件覆盖和条件组合覆盖。 

举个例子吧 
if A and B then Action1 
if C or D then Action2 

语句覆盖最弱,只需要让程序中的语句都执行一遍即可 。上例中只需设计测试用例使得A=true B=true C=true 即可。 

分支覆盖又称判定覆盖:使得程序中每个判断的取真分支和取假分支至少经历一次,即判断的真假均曾被满足。上例需要设计测试用例使其分别满足下列条件即可(1)A=true,B=true,C=true,D=false(2)A=true,B=false,C=false,D=false。 

条件覆盖:要使得每个判断中的每个条件的可能取值至少满足一次。上例中第一个判断应考虑到A=true,A=false,B=true,B=false第二个判断应考虑到C=true,C=false,D=true,D=false,所以上例中可以设计测试用例满足下列条件(1)A=true,B=true,C=true,D=true(2)A=false,B=false,C=false,D=false。 

路径覆盖:要求覆盖程序中所有可能的路径。所以可以设计测试用例满足下列条件(1)A=true,B=true,C=true,D=true(2)A=false,B=false,C=false,D=false(3)A=true,B=true,C=false,D=false(4)A=false,B=false,C=true,D=true。 

不论那种覆盖方法,都不能保证程序的正确性。 
一般测试书中讲白盒测试的逻辑覆盖部分时都会对这几种覆盖作比较,而且都给出了例子。

标签:语句,false,覆盖,路径,测试用例,判定,条件,true
From: https://www.cnblogs.com/bonelee/p/17310641.html

相关文章

  • yaml文件获取key的全路径
    importyamlwithopen('aa.yaml',"r")asfile:data=yaml.load(file,Loader=yaml.FullLoader)defyaml_flat(x):forkey,valueinx.items():ifisinstance(value,dict):fork,vinyaml_flat(value):......
  • 富文本转路径
    +(UIBezierPath*)attributedString2BezierPath:(NSAttributedString*)attributedStringinBounds:(CGSize)bounds{NSString*clearText=attributedString.string;NSCharacterSet*ignoredCharsSet=[NSCharacterSetwhitespaceAndNewlineCharacterSet];......
  • R语言中实现sem进行结构方程建模和路径图可视化|附代码数据
    原文链接:http://tecdat.cn/?p=23312最近我们被客户要求撰写关于结构方程建模的研究报告,包括一些图形和统计输出。结构方程模型是一个线性模型框架,它对潜变量同时进行回归方程建模引言 诸如线性回归、多元回归、路径分析、确认性因子分析和结构回归等模型都可以被认为是SEM的......
  • SpringBoot实现文件图片上传并转换为虚拟路径
    页面代码<!DOCTYPEhtml><htmllang="en"xmlns:th="http://www.thymeleaf.org"><head><metacharset="UTF-8"><title>Title</title></head><body><formaction="/putpic......
  • dowhile,while,for语句
    循环语句//使用三种语句求0~10的总和for循环语句varsum=0;for(vari=0;i<10;i++){sum+=i;}console.log(sum);while语句vari=0;varsum=0;while(i<10){sum+=i;i++;}console.log(sum);dowhile语句vari=0;varsum=0;do{......
  • if,switch语句
    if语句vara=1;varb=2;if(a>b){console.log(a);}else{console.log(b);}//if/elseifif(a>b){}elseif(){}elseif(){}//嵌套ifif(){if(){}}elseif(){}else{}switch语句varname="sss";switch(......
  • plsql控制语句(循环)
    --4.利用三种循环和goto手动循环语句求1到100的偶数和1.loop循环:declare--声明一个变量v_n和一个v_n和的变量v_sum并赋值为0v_nnumber(10):=0;v_sumnumber(10):=0;beginloop......
  • 利用强化学习Q-Learning实现最短路径算法
    如果你是一名计算机专业的学生,有对图论有基本的了解,那么你一定知道一些著名的最优路径解,如Dijkstra算法、Bellman-Ford算法和a*算法(A-Star)等。这些算法都是大佬们经过无数小时的努力才发现的,但是现在已经是人工智能的时代,强化学习算法能够为我们提出和前辈一样好的解决方案吗?......
  • Go笔记(二):条件控制语句
    Go语言中的if语句根据条件表达式的结果选择需要执行的业务流程。1、if控制语句1、if语法语法详情如下:if条件表达式{//条件表达式为true,执行的代码块}条件表达式必须返回布尔型的结果,与Java语法不同,在Go中,if的条件表达式不使用括号。2、if/else语法......
  • 用 Go 剑指 Offer 12. 矩阵中的路径
    给定一个 mxn二维字符网格 board和一个字符串单词 word。如果 word存在于网格中,返回true;否则,返回false。单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中“相邻”单元格是那些水平相邻或垂直相邻的单元格。同一个单元格内的字母不允许被重复使用。 例如,......