资源描述:
《路径分析测试.ppt》由会员上传分享,免费在线阅读,更多相关内容在PPT专区-天天文库。
1、2.4.2路径分析测试对于比较简单的小程序来说,实现路径覆盖是可能的,但如果程序比较复杂,存在多个判断和多个循环,可能的路径数目将会急剧增长,以致路径覆盖难以实现。实际上可以做到的只是有选择地测试程序中某些有代表性的路径。独立路径选择和Z路径覆盖是两种常见的路径覆盖方法。2.4.2控制流图控制流图是由节点和控制边组成的,具有以下几个特点:具有唯一入口节点,即源节点,表示程序段的开始语句;具有唯一出口节点,即汇节点,表示程度段的结束语句;节点由带有标号的圆圈表示,表示一个或多个无分支的源程序语句;
2、控制边由带箭头的直线或弧表示,代表控制流的方向。2.4.2控制流图2.4.2控制流图程序的环路复杂性是一种描述程序内部逻辑复杂度的标准。给定一个控制流图G,设其环形复杂度为V(G),在这里介绍三种常见的计算方法来求解V(G):V(G)=E-N+2,其中E是控制流图G中边的数量,N是控制流图中节点的数目;V(G)=P+1,其中P是控制流图G中判断节点(即包含条件的节点)的数目;节点由带有标号的圆圈表示,表示一个或多个无分支的源程序语句;V(G)=A,其中A是控制流图G中区域的数目。由边和节点围成的
3、部分叫做区域,当在控制流图中计算区域的数目时,控制流图外的部分也应记为一个区域。2.4.2独立路径测试62.4.2独立路径测试测试用例设计测试难点独立路径集合规模确定独立路径的抽取不可行路径的处理测试用例的设计72.4.2独立路径测试测试难点如何确定独立路径集合的规模如何从整个路径集合中抽取独立路径的集合,以确保路径的独立性和独立路径集合的完备性如何保证每条独立路径的可行性如何从独立路径设计测试用例82.4.2独立路径测试测试用例设计测试难点独立路径集合规模确定独立路径的抽取不可行路径的处理测试
4、用例的设计92.4.2独立路径测试按照McCabe的环复杂度概念,对于指定的程序图,对路径的测试中所需独立路径集合的大小就等于其程序图的环复杂度102.4.2独立路径测试测试用例设计测试难点独立路径集合规模确定独立路径的抽取不可行路径的处理测试用例的设计112.4.2独立路径测试独立路径抽取1、确定主路径该路径应包含尽可能多的判定节点应包含尽可能复杂的判定表达式应对应尽可能高的执行概率应包含尽可能多的语句2、根据基础路径抽取其他独立路径132.4.2独立路径测试独立路径Path1:A,B,C,G
5、(经过判定节点A、B、C);Path2:A,D,E,F,G(在判定节点A处执行e2分支);Path3:A,B,E,F,G(在判定节点B处执行e5分支);Path4:A,B,C,B,C,G(在判定节点C处执行e3分支);Path5:A,D,F,G(在判定节点D处执行e7分支)142.4.2独立路径测试测试用例设计测试难点独立路径集合规模确定独立路径的抽取不可行路径的处理测试用例的设计152.4.2独立路径测试不可行路径的处理程序的设计缺陷导致不可行路径原因在于:构成判定表达式的多个简单判定条件之间
6、存在一定关联,体现在多个简单判定条件的取值相互约束,从而导致部分路径不可行。若完全根据程序图来设计测试用例,往往无法发现这些不可行路径,最终导致测试失败162.4.2独立路径测试测试用例设计测试难点独立路径集合规模确定独立路径的抽取不可行路径的处理测试用例的设计172.4.2独立路径测试测试用例设计步骤根据程序源代码生成程序图计算程序图的环复杂度,确定独立路径集合的大小以最复杂的路径为基础路径,通过覆盖所有判定分支确定其他路径,抽取独立路径集合注意剔除不可行路径,必要时补充其他重要的路径根据得到
7、的路径集合对应设计测试用例2.4.2独立路径测试独立路径测试是在程序控制流图的基础上,通过分析控制流图的环路复杂性,导出可执行的独立路径集合,从而设计相应的测试用例。以下图所示程序流程为例:2.4.2独立路径测试从控制流图看,一条独立路径是至少包含有一条在其它独立路径中从未有过的边的路径。上图所示的控制流图中一组独立的路径是:Path1:111Path2:1234510111Path3:12368910111Path4:12367910111路径P
8、ath1、Path2、Path3、Path4组成了控制流图的一个独立路径集。通常,独立路径集并不唯一确定。独立路径测试包括3个步骤:1)导出程序控制流图;2)求出程序环形复杂度;3)基于独立路径集设计测试用例。2.4.2独立路径测试例2-6:下面是一个Java语言程序,用于统计一行字符中有多少个单词,单词之间用空格分隔开2.4.2独立路径测试程序2-2(续):12{13score=score-10;14num2++;15}16i++;17}18System.out.println(“num1=”