(精品)Lect06A-测试的理论基础.ppt
理论基础测试用例设计的理论依据主要内容简单图论知识覆盖准则1简单图论知识无向图图G=,其中V=n1,n2,nm为有限非空集合,称为顶点集,ni为顶点,E=e1,e2,ek为有限集合,E称为边集,ei称为边。ei=(u,v)为无序顶点对,称ei为无向边,若任意eiE都是无向边,则G称为无向图。n1n2n3n4n5n6n7e1e2e3e4e5e6无向图相关定义节点的度:节点n的度定义为该节点作为顶点的边的数目,记为deg(n)路径:路径是一系列边的序列,该序列中任何连续的两个边都存在一个公共的顶点。无向图相关定义连接性:节点ni、nj是连接的,当且仅当ni、nj在同一条路径上。组件:图的组件是相连节点的最大集合图G的圈复杂度V(G)en2p,其中e为G的边数,n为节点数,p为组件数。有向图有向图:图G=,其中V=n1,n2,nm为有限非空集合,称为顶点集,ni为顶点,E=e1,e2,ek为有限集合,E称为边集,ei称为边。ei=为有序顶点对,称ei为有向边,若任意eiE都是有向边,则G称为有向图。n1n2n3n4n5n6n7e1e2e3e4e5e6有向图节点n的入度:有向图G中以n作为终点的边数目节点n的出度:有向图G中以n作为起点的边数目路径p是一个有向边的序列:相邻两条边满足前一条边的终点是后一条边的起点。有向图环路是一个开始节点与结束节点相同的有向路径3-连接:有向图的两个节点ni、nj,当且仅当从ni到nj有一条路径,且nj到ni有一条路径。强组件:有向图的强组件是3-连接节点的最大集合。如n1n3n7 n2 n5 n6n4n1n2n3n4n5n6n7e1e2e3e4e5e6n1s1n3n4n7e1e2e52覆盖准则路径覆盖准则数据流覆盖准则逻辑覆盖准则输入空间的划分准则覆盖准则测试需求:是软件制品(artifact)的一个特殊元素,测试用例必须要满足或覆盖它。测试需求通常成套出现,以TR表示一测试需求集合。如目标是覆盖程序中所有判断,则每个判断导致两个测试需求:判断成真、判断成假。若目标是每个方法被调用一次,则每个方法对应一个测试需求。覆盖准则覆盖准则:将测试需求加在一个测试集上的一个或一组规则。测试准则以一种完整明确的方式描述测试需求。覆盖:对于覆盖准则C,给定一组测试需求TR,测试集T满足C是指当且仅当对于每一个TR中的测试需求tr,T中至少存在一个测试t,使t满足tr。TTRC覆盖准则就是测试需求的抽象描述覆盖准则覆盖率:给定一组测试需求TR和一个测试集T,覆盖率是被T满足的测试需求的数量与TR大小的比率。有时满足覆盖准则代价昂贵,则满足覆盖率,如所有路径覆盖有些需求是不能被满足的,如无法到达的代码测试准则准则包含性:若每个测试集T在满足覆盖准则C1的同时,也满足覆盖准则C2,则称C1包含C2。C1的测试需求集是C2测试需求集的一个扩展,或者C1的测试需求与C2的测试需求之间存在一个多对一的映射。直觉上,测试准则C1包含C2,C1应该能够揭示更多错误。图覆盖准则图G(N,N0,Nf,E),其中N为节点的非空集合,N0是始节点的非空集合,Nf是终节点的非空集合,E是边的集合,E是NxN的子集。边记为,ni为前驱,nj为后继。一条路径是节点的序列,其中相邻的节点是图G的一条边。路径长度定义为所包含边的数量。子路径是路径p的子序列。图覆盖准则节点可达:如果存在一条从节点ni到n的路径,称节点n为从节点ni开始可达的。reachG(x):是从参数x开始可达的。参数可以是一个节点、一条边或节点集合reachG(n)是G的一个子图。reachG(N0)是G的一个子图,它是从始节点可达的图覆盖准则测试路径:从N0中某节点开始到Nf中某节点结束的一条路径称为一条测试路径。如果节点n在测试路径p中,则称测试路径p访问节点n;如果边e在测试路径中,则称测试路径p访问边e。如果q是测试路径p的子路径,则称测试路径遍历子路径q。pathG(t)表示测试用例t所执行的图G的测试路径。path(T)表示测试集T测试所执行的测试路径的集合,path(T)=path(t)|tT图覆盖准则n0n1n3n2abt1(a=0,b=1)p1:n0,n1,n3,n2t2(a=1,b=1)p2:n0,n3,n2t3(a=2,b=1)p3:n0,n2图覆盖准则图覆盖:给定一个关于图G的准则C的测试需求集合TR,测试集合T在图G上满足准则C当且仅当对TR中每个测试需求tr,path(T)中至少存在一条测试路径p满足tr。结构化覆盖准则涉及控制流的准则称为结构化覆盖准则节点覆盖:节点覆盖准则NC:TR包含图G中每个可达的节点 测试集合T满足图G上的节点覆盖准则当且仅当N中每个语法可达节点n在path(T)存在一条路径p,p访问n。TR包含图G中长度为零的可达路径结构化覆盖准则边覆盖(EC):TR包含图G中长度不大于1的可达路径。测试集合T满足图G上的边覆盖准则当且仅当E中每个语法可达边e在path(T)存在一条路径p,p访问e.n0n1n2xy xypath(t1)=n0,n1,n2path(t2)=n0,n2T=t1满足节点覆盖T=t1,t2满足边覆盖结构化覆盖准则简单路径:如果从ni到nj的一条路径中,除了始节点和终节点可以相同外,没有任何节点出现次数多于一次,则该路径为简单路径。简单路径没有内部环,但整个路径本身可以形成一个环。结构化覆盖准则主路径:如果从ni到nj是一条简单路径,并且它不作为任何其他简单路径的子路径出现,则称之为主路径。n0n1n2n4n3n0,n1,n2n0,n1,n3,n4 n1,n3,n4,n1n3,n4,n1,n3n4,n3,n1,n4n3,n4,n1,n2结构化覆盖准则主路径覆盖(PPC)准则:TR包含图中每一条主路径。n0n1n2n4n3n0,n1,n2n0,n1,n3,n4 n1,n3,n4,n1n3,n4,n1,n3n4,n3,n1,n4n3,n4,n1,n2path(t1)=n0,n1,n2path(t2)=n0,n1,n3,n4,n1,n3,n4,n1,n2T=t1,t2满足主路径覆盖结构化覆盖准则完全路径覆盖(CPC):TR包含图中的所有路径。如果图G中存在循环,则完全路径覆盖无效,因为路径数量无穷多,测试需求也无穷多。结构化覆盖准则指定路径覆盖(SPC):TR包含一个测试路径集S,S为指定参数。n0n3n1n2主路径:n0,n1,n3,n0,n2,n3path(t1)=n0,n1,n3path(t2)=n0,n2,n3T=t1,t2满足主路径覆盖T满足完全路径n0n1n2n4n3path(t1)=n0,n1,n2path(t2)=n0,n1,n3,n4,n1,n3,n4,n1,n2T=t1,t2满足主路径覆盖结构化覆盖准则遍历:测试路径p遍历子路径q,当且仅当q是p的一个子路径。边路遍历:测试路径p边路遍历子路径q,当且仅当q中的每一条边以同样的顺序出现在p中。绕路遍历:测试路径p绕路遍历子路径q,当且仅当q中的每个节点以同样的顺序出现在p中。结构化覆盖准则s0sfabdc设q=a,b,dp=s0,a,b,c,b,d,sf没有遍历q,因为q不是p的子路径但是p边路覆盖q,因为边,以同样顺序出现在p中结构化覆盖准则s0sfabdcs0sfabdcs0,a,b,c,b,d,sf边路覆盖q=a,b,d,从一个节点b离开,经一个环又回到相同的b节点,将环b,c,b压缩为节点b之后就满足了遍历的条件s0,a,b,c,d,sf绕路覆盖q=a,b,d,从一个节点b离开,绕过边直接到子路径的下一个节点,所以子路径b,c,d是a,b,d的一个绕路。结构化覆盖准则边路覆盖、绕路覆盖是解决由于循环引起的无限路径问题。例如:如果前图中循环b,c,b是do-while循环,一次都不执行不可能,导致a,b,d子路径不可能被遍历。结构化覆盖准则寻找主路径算法:1.长度为0的路径(即可达节点);2.扩展出长度为1的路径(即可达边);3.逐步扩展,直到不能扩展出新路径为止。扩展过程中不能扩展的路径为可能的主路径。4.按照主路径的定义进行筛选即可。结构化覆盖准则12463571.长度为0的路径:1,2,3,4,5,6,7#由于节点7是终节点,不能扩展。2.扩展出长度为1的路径:1,2,1,7#,2,3,2,4,3,2 4,5,4,6,5,6,6,13.扩展出长度为2的路径:1,2,3 1,2,4 2,3,2*2,4,5 2,4,6 3,2,3*3,2,4 4,5,6,4,6,1,5,6,16,1,2 6,1,7#*标注路径是环,不能进一步扩展结构化覆盖准则4.找长度为3的路径:1,2,3扩展为1,2,3,2是不合适的扩展,因为2出现两次,且不是始点、终点,不是简单路径 1,2,4,5 1,2,4,6,2,4,5,6 2,4,6,1 3,2,4,5 3,2,4,6 4,5,6,1 4,6,1,2 4,6,1,7#5,6,1,2 5,6,1,7#6,1,2,3 6,1,2,41246357结构化覆盖准则5.找长度为4的路径:1,2,4,5,6 1,2,4,6,1*2,4,5,6,1 2,4,6,1,2*2,4,6,1,7#3,2,4,5,6 3,2,4,6,1 4,5,6,1,2 4,5,6,1,7#4,6,1,2,3 4,6,1,2,4*5,6,1,2,3 5,6,1,2,4 6,1,2,4,5 6,1,2,4,6*1246357结构化覆盖准则6.找长度为5的路径:124561*245612*245617#324561 324617#456123 456124*561245*612456*7.找长度为6的路径:3245617#1246357结构化覆盖准则8.扩展结束,过程中所有、*的路径是可能的主路径,然后删除非主路径即可。232 323 12461 24612 46124 61246 124561 245612 324617 456124 561245 612456 3245617进一步得出测试路径:12323245617 124561245617 12324617 1246124617数据流覆盖准则为充分测试程序,应该关注数据值的流动,以数据定义(def变量值被写入内存)、使用(use变量的值被访问)来描述数据值从定义位置传递到使用位置,称为du路径。假设涉及判断的变量在关联的边上使用。n0n1n2n3abdef(n0)=a,buse(n2)=a,buse(n0,n1)=a,b数据流覆盖准则定义清除路径:从位置li到lj的路径是关于变量v定义清楚路径是指,如果对于路径上每个节点nk和每条边ek,ki且kj,v不在集合def(nk)和def(ek)中。定义清除路径表明从li到lj变量v没有改变,称为在li定义的变量到达了lj的使用。数据流覆盖准则du遍历:如果测试路径p遍历关于v的子路径q,并且p与q相对应的部分是关于v的定义清除路径,则称测试路径p为du遍历v的子路径q。数据流覆盖准则关于变量v的du路径是一条简单路径,该路径是关于变量v从节点ni到节点nj定义清除的,其中v在集合def(ni)和use(nj)中。定义路径集du(n,v)是从节点n开始的关于变量v的du路径集合。全定义覆盖(ADC):对于每一个“定义路径”集合Sdu(n,v),TR至少包含S中的一条路径nvdef(n)n1n2nkvuse(ni)数据流覆盖准则“定义对”集du(ni,nj,v)作为关于从节点ni开始到节点nj结束的变量v的du路径集合。全使用覆盖(AUC):对于每一个“定义对”集合S=du(ni,nj,v),TR至少包含S中的一条路径。nvdef(n)n1n2nkvuse(nm)nm数据流覆盖准则全du路径覆盖(ADUPC):对于每一个“定义对”集合Sdu(ni,nj,v),TR包含S中的每一条路径。nvdef(n)n1n2nkvuse(nm)nm数据流覆盖准则0123456def(0)=xuse(5)=xuse(4)=x全定义ADC:0,1,3,4全使用AUC:0,1,3,4 0,1,3,5全du路径ADUPC:0,1,3,4 0,1,3,5 0,2,3,4 0,2,3,5图覆盖之间的包含关系完全路径覆盖CPC主路径覆盖PPC双边覆盖EPC边覆盖EC完全回路覆盖CRTC简单回路覆盖SRTC全使用覆盖AUC全定义覆盖ADC节点覆盖NC全du路径覆盖ADUPC逻辑覆盖准则逻辑谓词和子句谓词:由布尔变量、比较运算、逻辑运算构成的表达式。等价 异或 子句:不包含任何逻辑操作符的谓词,如 谓词(a=b)Cp(x)包含三个子句:关系表达式(a=b),布尔变量C和函数引用p(x)逻辑覆盖准则P为谓词集合,C为P的子句集合,每个谓词pP,Cp为p的子句集合。谓词覆盖(PC):每个谓词pP,TR包含两个需求条件:p成真、p成假。谓词覆盖对应图覆盖的边/分支覆盖。(a=b)Cp(x)a:4 b:4 C:true p(x):truea:x b:x C:false p(x):false逻辑覆盖准则子句覆盖(CC):对于每个cC,TR包含两个需求条件:c取真值、c取假值。(a=b)Cp(x)a:5 b:5 C:true p(x):truea:5 b:6 C:false p(x):false子句覆盖并不意味着谓词覆盖,反之亦然(CC)ab a:T b:F a:F b:T 谓词T(PC)ab a:T b:F a:F b:F 逻辑覆盖准则组合覆盖(CoC):对于每个pP,TR要求Cp中的每个子句均可取得真值组合中的每种可能情况。abc(ab)cTTTTTTFFTFTTTFFFFTTTFTFFFFTFFFFF逻辑覆盖准则子句判定谓词:在某些条件下,如果改变子句的取值,谓词取值也随之改变,则称该子句判定谓词。即子句决定谓词当前关注的子句称为谓词的主子句,其他子句称为次子句。p=ab 如果b为假,那么a判定p,因为p的取值取决于a的取值。逻辑覆盖准则活动子句覆盖(ACC):对于每个pP及每个主子句ciCp,选择次子句cjCp(ij)使得ci判定p。TR对每个ci要求:取真值、取假值。如p=ab,a判定p(此时b:F),同样b判定p(此时a:F),据此,三组取值(a:T b:F a:F b:F a:F b:T)满足ACC要求。逻辑覆盖准则一般活动子句覆盖(GACC):对于每个pP及每个主子句ciCp,选择次子句cjCp(ij)使得ci判定p。TR对每个ci要求:取真值、取假值。当ci取真值、假值时,次子句cj的取值不必相同。GACC不一定包含谓词覆盖,如p=ab,对于b的任意取值,a判定p,当a:T时,取b:T,当a:F时取b:F(GACC不要求不取相同值),对于b也同样取值,得到两组TT,FF,而p均为T,没有满足覆盖谓词。逻辑覆盖准则相关活动子句覆盖(CACC):对于每个pP及每个主子句ciCp,选择次子句cjCp(ij)使得ci判定p。TR对每个ci要求:取真值、取假值。当ci取真值、假值时,次子句cj的取值满足:主子句ci取某个值时p为真,取另一值时p为假。p=ab,对于b的任意取值,a判定p,当a:T时,取b:T,谓词为真,当a:F时要求p取假值,即b:T。最终CACC测试集TT,FT+TT,TF练习:p=a(bc)逻辑覆盖准则受限活动子句覆盖(RACC):对于每个pP及每个主子句ciCp,选择次子句cjCp(ij)使得ci判定p。TR对每个ci要求:取真值、取假值。当ci取真值、假值时,次子句cj的取值必须相同。p=ab,a为主子句(假定b:T)得到a:T b:T;a:F b:T;b为主子句(假定a:T)得到a:T b:T;a:T b:Fp=a(bc),a为主子句(假定b:T c:F)得到TTF,FTF,此时假定还有两种取值TT、FT,都可以满足a为主子句时RACC覆盖。逻辑覆盖准则非活动子句覆盖(ICC):对于每个pP及每个主子句ciCp,选择次子句cjCp(ij)使得ci不判定p。TR对每个ci要求:ci取真值P为真、ci取假值P为真、ci取真值P为假、ci取假值P为真假。逻辑覆盖准则一般非活动子句覆盖(GICC):对于每个pP及每个主子句ciCp,选择次子句cjCp(ij)使得ci不判定p。TR对每个ci要求:ci取真值P为真、ci取假值P为真、ci取真值P为假、ci取假值P为真假。次子句cj的取值四种情况下可以不同。逻辑覆盖准则受限非活动子句覆盖(RICC):对于每个pP及每个主子句ciCp,选择次子句cjCp(ij)使得ci不判定p。TR对每个ci要求:ci取真值P为真、ci取假值P为真、ci取真值P为假、ci取假值P为真假。次子句cj的取值前两种情况下必须相同,在后两种情况下也必须相同。逻辑覆盖准则组合覆盖CoC子句覆盖CC受限非活动子句覆盖RICC一般非活动子句覆盖GICC相关活动子句覆盖CACC一般活动子句覆盖ADC谓词覆盖PC受限活动子句覆盖RACC输入空间的划分准则输入域D为输入参数的可能取值集合。考虑域D的一个抽象划分q,q定义了一系列等价类,简称为块集Bq,满足:不相交性、完全性b2b1b3输入域建模输入域建模步骤:识别可测试功能:例如依据UML用例图确定被测对象的可测试功能;识别会影响给定可测功能行为的所有参数,包括内部状态;输入域建模:利用输入特征描述输入域的结构,为每种特征都产生一个划分。一个划分是一个块集,从每种特征的角度来看,每块的值都是等价的。应用测试覆盖准则选择值的组合。将块的组合精化为测试输入。输入域建模基于接口的输入域建模:单独考虑每个特殊的参数,每个参数都被作为一个特征。由于单独考虑每一个特征/参数,因此,可能某些重要的组合被遗漏。例如:Triangle(int a,int b,int c)a作为一个单独的特征,整数:0 输入域建模基于功能的输入域建模:明确被测对象想要实现的功能所对应的特征,将某些语义或领域知识结合到输入域模型。例如,三角形问题:输入的是三角形,而不是三个整数可以依据输入规约/需求进行设计,不必等到软件设计完成之后才能开始。输入域建模Public Boolean findElement(List list,Object element)/Function:if list or element is null throw NullPointer Exception/else return true if element is in the list,and false otherwise.输入域建模使用基于接口的方法,有两个特征list、element。如list特征list是0/nullb1:listnull trueb2:listnull falseList是空/emptyb1:list=empty trueb2:list=empty falseb1:list=nullb2:listnulllist=emptyb3:listnulllistempty输入域建模利用基于功能的方法list中element出现的次数b1:0b2:1b3:多于1次Element第一个出现在list中b1:trueb2:false输入域建模识别块中值的策略:有效值:至少包含一组有效值;子划分:可以将一个划分按照另一特征进行进一步划分;边界:边界或距边界很近的值常引起错误;无效值:至少包含一组无效值;平衡:各特征尽可能划分出数量基本一致的块;遗漏划分:检查块的并集是否完全覆盖该特征的输入域;重叠划分:检查是否有值属于超过一个块。输入域建模例如:三角形问题的划分如下(a、b、c为整数):注意:本例中,分别在三个划分的某个块中取一个值才能构成一组输入。划分b1b2b3q1“边1和0的关系”大于0 等于0 小于0q2“边2和0的关系”大于0 等于0 小于0q3“边3和0的关系”大于0 等于0 小于0输入域建模当然也可以选择其他形式的划分,如:注意:如果边为浮点数,上表中不是一个有效的划分,因为没有一个块包含(0,1)。划分b1b2b3b4q1“边1的长度”大于1 等于1 等于0 小于0q2“边2的长度”大于1 等于1 等于0 小于0q3“边3的长度”大于1 等于1 等于0 小于0输入域建模三角形问题的基于功能特性的划分:划分b1b2b3b4q1=“几何分类”不等边 等腰三角形 等边三角形 无效划分b1b2b3b4q1=“几何分类”不等边 等腰不等边 等边三角形 无效上述划分不能构成一个有效划分,因为b2与b3存在重叠,修正如下:输入域建模使用多种输入域模型:使用多个小的模型比一个大的模型还要好。注意多个模型的输入域划分块可以重叠划分b1b2b3q1成绩取值小于00100大于100划分b1b2b3b4b5b6q2成绩取值 不及格 及格 中等 良好 优秀 无效输入域建模检查输入域模型检查是否有关该功能的某些信息没有合并到特征中根据完整性、不相交性检查每个特征/划分组合策略准则所有组合策略(ACoC):从所有特征得到的所有块的组合必须被覆盖。如:三个划分得到的块A,B,1,2,3,x,y,ACoC需要12种测试:(A,1,x),(B,3,y)组合策略准则每个选择覆盖(ECC):对于来自每个特征的每个块的一个值,必须至少在一个测试用例中使用过。如:三个划分得到的块A,B,1,2,3,x,y,(A,1,x),(B,2,y),(A,3,x)满足ECC准则。组合策略准则成对覆盖(PWC):每种特征的每个块的一个值必须与其他特征的每个块的一个值进行组合如:三个划分得到的块A,B,1,2,3,x,y,(A,1),(A,2),(A,3),(A,x),(A,y)(B,1),(B,2),(B,3),(B,x),(B,y)(1,x),(1,y),(2,x),(2,y),(3,x),(3,y)最后测试用例组合:(A,1,x),(B,1,y),(A,2,y),(B,2,x),(A,3,x),(B,3,y)(A,1,x)覆盖了(A,1),(A,x),(1,x)组合策略准则T-组合覆盖(TWC):来自每组t个特征的每个块的一个值必须进行组合。t=2即为PWC,因此TWC是PWC的一般化形式。据此,每个选择覆盖ECC可以理解为t=1的TWC。组合策略准则基本选择覆盖(BCC):对每种特征选定一个基本选择块,通过使用每个特征的基本选择块来构成一个基本测试。后面的测试按如下方法构成,保留前面的除了一个基本选择块常量外的所有值并且使用每个非基本快选择来代替。块A,B,1,2,3,x,y,假设基本选择为A,1和x,则基本选择测试为(A,1,x),后续的测试选择为(B,1,x)/1,x不变,(A,2,x)/A,x不变,(A,1,y)/A,1不变组合策略准则多基本选择覆盖(MBCC):对每种特征选择至少一个,也可能选择多个基本块,并且基本测试通过使用每个特征的每个基本选择至少一次来构成。后面的测试通过以下方法构成,即对每一个基本测试保留前面的除了一个基本选择常量外的所有值,并且使用每个非基本选择来替换他。组合策略准则全组合覆盖ACoC每个选择覆盖ECC多基本选择覆盖MBC基本选择覆盖BCC成对覆盖PWCT组合覆盖TWC划分中的约束输入空间划分时有时一些块的组合不可行,如boolean findElement(list l,element e)按照如下划分:存在两个不可能组合特征 块1234A:长度内容 一个元素 多个,未排序多个(不全同),排序多个同样元素B:匹配未匹配匹配1次匹配多次无效组合(A1,B3),(A2,B3)划分中的约束约束:块的不同特征之间的联系从一个特征导出的块不能与另一特征的块组合,如“小于0”与“不等边三角形”;从一个特征导出的块必须与从另一特征导出的特定块组合。约束与覆盖规则:仍然按照无约束的情况进行,然后把约束中的不可能组合丢弃。划分中的约束排序问题:输入为某任意类型的可变长度的数组;输出为:升序排列的数组;最大值;最小值。可以有如下划分:数组长度:0,1,2,MAXINT元素类型:整型,字符型,字符串,其他最大值:0,1,1,a,最小值:最大值位置:1,2,length最小值位置:1,2,length只有长度大于0时才能组合出有意义的测试小结本章主要内容为测试设计的理论依据,包括:图:无向图、有向图测试覆盖准则图覆盖数据流覆盖逻辑覆盖输入空间覆盖