白盒测试详细总结,测试著作

测试著作内容,包含部分测试语句,因为不含有丰富的用语,所以必须输入充裕的口舌,才能健康的入库处理。

测试作品内容,包含部分测试语句,因为不含有丰硕的词语,所以必须输入丰硕的话语,才能正常的入库处理。

白盒测试中央要求

  • 确保一个模块中的所有独立路线至少被实践一遍;
  • 对富有的逻辑值均需要测试真、假五个支行;
  • 在内外边界及可操作范围内运行具有循环;
  • 自我批评其中数据结构以保险其行之有效。

白盒测试又称结构测试、透明盒测试、逻辑驱动测试或遵照代码的测试。白盒测试是一种测试用例设计模式,盒子指的是被测试的软件,白盒指的是盒子是可视的,你知道盒子内部的事物以及其中是何等运转的。”白盒”法全面摸底程序内部逻辑结构、对拥有逻辑路径举办测试。”白盒”法是穷举路径测试。白盒测试并不是简单的按照代码设计用例,而是需要依照不同的测试需要,结合不同的测试对象,使用符合的点子开展测试。

测试覆盖标准

  1. 说话覆盖:是一个相比较弱的测试标准,它的含义是:接纳丰裕的测试用例,使得程序中每个语句至少都能被实践三次
  • 它是最弱的逻辑覆盖,效果有限,必须与其他格局交互使用。
  1. 白盒测试详细总结,测试著作。认清覆盖(也称为分层覆盖):执行充分的测试用例,使得程序中的每一个拨出至少都由此几回
  • 判定覆盖只比语句覆盖稍强一些,但实际效果表明,只是一口咬定覆盖,还无法确保一定能意识到在认清的准绳中设有的失实。由此,还需要更强的逻辑覆盖准则去验证判断其中条件。
  1. 条件覆盖:执行丰硕的测试用例,使程序中每个判断的每个条件的各样可能取值至少实施两次
  • 规则覆盖深切到判断中的每个条件,但恐怕无法满意判定覆盖的要求。
  1. 判定/条件覆盖:执行充裕的测试用例,使得判定中各类条件取到各种可能的值,并使每个判定取到各样可能的结果
  2. 规范构成覆盖:执行丰硕的例证,使得各样判定中原则的各个可能构斯图加特至少现身四次
  • 这是一种十分强的掩盖准则,可以使得地检
    查各样可能的规范取值的整合是否正确。
  • 它不光可覆盖所有标准的可能取值的组合,还可覆盖所有判断的优点分支,但或许有的路径会遗漏掉。
  • 测试还不完全。

白盒测试用例设计的一个很关键的评估标准就是对代码的覆盖度白盒测试中广泛的遮盖模式有六种:语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、组合覆盖和途径覆盖。下面我们就各自看望这二种不同的掩盖吧

第一模式

  1. 逻辑驱动测试
  • 话语覆盖
  • 判断覆盖
  • 基准覆盖
  • 认清/条件覆盖
  • 规范构成覆盖
  1. 途径测试
  • 途径测试就是规划丰裕多的测试用例,覆盖被测试目的中的所有可能路径。这是最强的掩盖准则。
  • 主干途径测试:设计丰富多的测试用例,运行所测程序,要覆盖程序中负有可能的路线。但在路子数目很大时,真正成功完全覆盖是很劳累的,必须把覆盖路径数目减弱到早晚限度。例如程序中的循环体只举行三回。

一、语句覆盖(Statement Coverage)

  1. 首要特色:语句覆盖是最起码的构造覆盖要求,语句覆盖需要拔取充足的测试用例,使大家统筹出来的测试用例要确保程序中的每一个言辞至少被实施五回
  2. 优点:可以很直观地从源代码拿到测试用例,无须细分每条判定表明式。
  3. 缺陷:由于这种测试方法仅仅针对程序逻辑中显式存在的言语,但对于隐藏的标准化和可能到达的隐
    式逻辑分支,是心有余而力不足测试的。
  4. 举例

public int foo(int a,int b)
{
      return a/b;
}

这是一个求两数之商的函数。假如大家规划如下的测试用例:
TestCase: a =2, b =1
此刻,该函数的代码覆盖率达到了100%,并且计划的case可以万事大吉经过测试。然而显明该函数有一个很精通的bug:当
b=0 时,会抛出分外。

话语覆盖

例1:

PROCEDURE  M(VAR A,B,X:REAL);  
BEGIN 
IF ((A>1) AND (B=0))  THEN X:=X/A; 
IF ((A=2) OR (X>1))   THEN X:=X+1; 
END.

www.8522.com 1

流程图

为使程序中每个语句至少实施两次,只需设计一个能经过路径ace的例子就足以了,例如采用输入数据为:
A=2,B=0,X=3
从上例可看到,语句覆盖实际上是很弱的,即使第一个尺码语句中的AND错误地编写成OR,下边的测试用例是无法发现那么些荒唐的;又如第五个规格语句中X>1误写成X>0,这些测试用例也无法表露它,此外,沿着路径abd执行时,X的值应该保障不变,假诺这一面有错误,上述测试数据也不可以发现它们。

例2:

void  DoWork(int x,int y,int z)
{  int  k=0,j=0;
   if((x>3)&&(z<10))
   {  k=x*y-1;     //语句块1
      j=sqrt(k);
   }
   if((x= =4)||(y>5))
   {  j=x*y+10;   //语句块2
   }
   j=j%3;             //语句块3
}

www.8522.com 2

流程图

为了测试语句覆盖率只要规划一个测试用例就可以把多少个实施语句块中的语句覆盖了。测试用例输入为:x=4、y=5、z=5,程序执行的门径是:abd
该测试用例即便覆盖了可举行语句,但并不可以检查判断逻辑是不是有问题,例如在率先个判断中把&&错误的写成了||,则下边的测试用例还是可以够覆盖所有的施行语句。

二、判定覆盖(Decision Coverage)

  1. 根本特点:判定覆盖又称作分支覆盖,它要求挑选充裕的测试用例,使得运行这个测试用例时,每个判定的所有可能结果至少出现三次
  2. 优点:判定覆盖比语句覆盖要多几乎一倍的测试路径,当然也就拥有比语句覆盖更强的测试能力。同样判定覆盖也存有和讲话覆盖一样的简单性,无须细分每个判定就可以拿到测试用例。
  3. 症结:往往多数的判断语句是由四个逻辑条件组合而成(如,判定语句中包含AND、OR、CASE),若一味判断其全方位末了结出,而忽视每个条件的取值情状,必然会遗漏部分测试路径。
  4. 举例
![](https://upload-images.jianshu.io/upload_images/2298827-34f2268901fe3fb7.png)

X    Y   路径
90  90  OAE
50  50  OBDE
90  70  OBCE

判断覆盖

例1:
如若规划三个例证,使它们能因此路径ace和abd,或者通过路径acd和abe,就可达成“判定覆盖”标准,为此,可以选择输入数据为:
① A=3,B=0,X=1(沿路径acd执行)
② A=2,B=1,X=3(沿路径abe执行)
例2:
万一计划五个测试用例则可以满意条件覆盖的渴求。测试用例的输入为:
x=4、y=5、z=5【a b d】
x=2、y=5、z=5【a c e】
上边的多少个测试用例即使可以满意条件覆盖的渴求,可是也不可以对判断标准举办反省,例如把第二个原则y>5破绽百出的写成y<5,、上边的测试用例同样知足了分段覆盖。
留意:程序中带有判定的说话包括IF-THEN-ELSE、DO-WHILE、REPEAT-UNTIL等,除了双值的判断语句外,还有多值的判定语句,如PASCAL中的CASE语句、FORTRAN中蕴含多少个分支的IF语句等。所以“分支覆盖”更相像的意义是:使得每一个拨出得到每一种可能的结果

三、条件覆盖(Condition Coverage)

  1. 重大特征:务求所计划的测试用例能使各种判定中的每一个尺码都得到可能的取值,即每个条件至少有几遍真值、有五回假值。
  2. 亮点:显著条件覆盖比判定覆盖,增添了对适合判定情况的测试,扩大了测试路径。条件覆盖使得判定中的每一个规则都取到了不同的结果,这或多或少判断覆盖则不能确保。
  3. 缺陷:要高达标准化覆盖,需要充分多的测试用例,但规范覆盖并不可能保证判定覆盖。条件覆盖只可以保证每个条件至少有两回为真,而不考虑所有的论断结果。
  4. 举例

X    Y   路径
90  70  OBC
40        OBD

基准覆盖

一个判断中多次包含了好五个原则,如例1的主次中,判定 (A>1) AND
(B=0)包含了几个标准化: A>1以及
B=0,所以可援引一个更强的覆盖标准——“条件覆盖”。

  • 例1的先后有两个条件:
    A>1、 B=0、A=2、X>1
    为了达到“条件覆盖”标准,需要举办丰裕的测试用例使得在a点有:
    A>1、A≤1、B=0、B≠0 等各样结果出现,以及在b点有:
    A=2、A≠2、X>1、X≤1 等各类结果出现。
    今昔只需设计以下两个测试用例就可满意这一专业:
    ① A=2,B=0,X=4 (沿路径ace执行)
    ② A=1,B=1,X=1 (沿路径abd执行)

  • 对例2中的所有条件取值加以标记。

  • 对于第一个判断:
    规则x>3 取真值为T1,取假值为-T1
    条件z<10 取真值为T2,取假值为-T2

  • 对于第二个判断:
    规格x=4 取真值为T3,取假值为-T3
    基准y>5 取真值为T4,取假值为-T4

  • 则足以计划测试用例如下

![](https://upload-images.jianshu.io/upload_images/938465-207afe4db61770e8.png)

条件覆盖测试用例



注意:
  • “条件覆盖”经常比“分支覆盖”强,因为它使一个判断中的每一个条件都取到了多个例外的结果,而判定覆盖则不保险这一点。

  • “条件覆盖”并不含有“分支覆盖”,如对语句IF(A AND B)THEN S
    设计测试用例使其知足”条件覆盖”,尽管A为真并使B为假,以及使A为假而且B为真,然而它们都不许使语句S得以执行。

如对例2设计了上边的测试用例,则即便满意了标准化覆盖,但只覆盖了第一个尺码的取假分支和第二个标准化的取真分支,不满意分支覆盖的渴求。

www.8522.com 3

测试用例

参考文献:

议论白盒测试中的三种覆盖措施

分段(判定)/条件覆盖

本着地点的问题引出了另一种覆盖标准——“分支(判定)/条件覆盖”,它的意思是:执行丰硕的测试用例,使得分支中各样条件取到各个可能的值,并使每个分支取到各样可能的结果。

  • 对例1的主次,前边的两个例子
    ① A=2,B=0,X=4 (沿ace路径)
    ② A=1,B=1,X=1 (沿abd路径)
    是满意这一正式的。
  • 对例2,依照定义只需设计以下多个测试用例便得以覆盖8个标准化值以及4个判断分支。
![](https://upload-images.jianshu.io/upload_images/938465-2838323b3da2208e.png)

分支(判定)/条件覆盖测试用例



分支/条件覆盖从表面来看,它测试了所有条件的取值,但是实际上某些条件掩盖了另一些条件。
  • 比如对于规范表明式(x>3)&&(z<10)来说,必须六个条件都满意才能确定表明式为真。
  • 尽管(x>3)为假则相似的编译器不在判断是否z<10了。对于第二个表明式(x==4)||(y>5)来说,若x==4测试结果为真,就以为表明式的结果为真,这时不再检查(y>5)条件了。
  • 之所以,接纳分段/条件覆盖,逻辑表达式中的错误不自然可以查出来了。

标准构成覆盖

针对上述问题又提出了另一种标准——“条件构成覆盖”。它的意义是:执行丰硕的事例,使得各类判定中规格的各个可能构科威特城至少出现三回。满意“条件构成覆盖”的测试用例是肯定满意“分支覆盖”、“条件覆盖”和“分支/条件覆盖”的。

  • 再看例1的次第,大家需要拔取适宜的例证,使得下面8种标准构天津能够产出:

1) A>1, B=0    2) A>1, B≠0
3) A≤1, B=0    4) A≤1, B≠0
5) A=2, X>1    6) A=2, X≤1 
7) A≠2, X>1    8) A≠2, X≤1 

5)、 6)、 7)、8)四种情形是第二个
IF语句的基准构成,而X的值在该语句从前是要经过总计的,所以还必须依照程序的逻辑推算出在先后的入口点X的输入值应是什么样。
下边设计的三个例子可以使上述 8种标准构成至少出现四回:

① A=2,B=0,X=4  
    使 1)、5)两种情况出现; 
② A=2,B=1,X=1
    使 2)、6)两种情况出现;
③ A=1,B=0,X=2
    使 3)、7)两种情况出现;
④ A=1,B=1,X=1
    使 4)、8)两种情况出现。

下边两个例子尽管知足条件组合覆盖,但并不能够遮住程序中的每一条路子,例如路径acd就从不进行,因而,条件构成覆盖标准还是是不根本。

  • 现对例2中的各种判断的规则取值组合加以标记如下:

1、x>3,z<10    记做T1 T2,第一个判断的取真分支
2、x>3,z>=10   记做T1 -T2,第一个判断的取假分支
3、x<=3,z<10   记做-T1 T2,第一个判断的取假分支
4、x<=3,z>=10  记做-T1 -T2,第一个判断的取假分支
5、x=4,y>5     记做T3 T4,第二个判断的取真分支
6、x=4,y<=5    记做T3 -T4,第二个判断的取真分支
7、x!=4,y>5    记做-T3 T4,第二个判断的取真分支
8、x!=4,y<=5   记做-T3 -T4,第二个判断的取假分支

基于定义取4个测试用例,就能够覆盖上边8种标准取值的整合。
测试用例如下表:

www.8522.com 4

基准构成覆盖测试用例

上边的测试用例覆盖了具有条件的可能取值的组成,覆盖了富有判断的独到之处分支,可是却不见了一条路子abe。

途径测试

  • 对此例1,上面的测试用例则可对程序举办任何的门路覆盖。
![](https://upload-images.jianshu.io/upload_images/938465-ebde278645656a84.png)

路径测试测试用例
  • 对于例2,下面的测试用例则可对先后开展总体的路线覆盖。
![](https://upload-images.jianshu.io/upload_images/938465-b93d82ef84436427.png)

路径覆盖测试用例

主干路径测试

要旨路线测试在次第控制图的基本功上,通过分析控制构造的环行(圈,loop)复杂性,导出基本可实施路径集合,从而设计测试用例的章程。设计出的测试用例要管教在测试中先后的每一个可举行语句至少实施两回
包括以下4个步骤和一个工具方法。

4个步骤:
  1. 先后的支配流图:描述程序控制流的一种图示方法
  2. 程序圈复杂度:McCabe复杂性度量。从程序的环路复杂性可导出程序基本路径集合中的独立路线条数。
  3. 导出测试用例:遵照圈复杂度和程序结构设计用例数据输入和预期结果。
  4. 预备测试用例:确保基本路线集中的每一条路径的实践。
一个方法:

图形矩阵:是在主导路线测试中起襄助效能的软件工具,利用它可以兑现自动地规定一个中央途径集。

操纵流图的标志
  • 在介绍大旨途径方法此前,必须先介绍一种简易的控制流表示方法,即流图。

  • 流图是相对而言测试程序过程处理的一种象征。

  • 流图使用下边的标志描述逻辑控制流,每一种结构化构成要素有一个应和的流图符号。

![](https://upload-images.jianshu.io/upload_images/938465-a61a70367e802948.png)

控制流图的符号
  • 流图只有两种图形符号

  • 图中的每一个圆称为流图的结点,代表一条或多条语句。

  • 流图中的箭头称为边或连续,代表控制流。

  • 在将先后流程图简化成控制流图时,应小心:

  • www.8522.com ,在甄选或多分支协会中,分支的汇集处应当一个会晤结点。

  • 边和结点圈定的区域叫做区域,当对区域计数时,图形外的区域也应记为一个区域。

![](https://upload-images.jianshu.io/upload_images/938465-e3151c39ac5fdd34.png)

程序流程图简化成控制流图
  • 尽管判断中的条件表明式是由一个或三个逻辑运算符 (OR, AND, NAND, NOR)
    连接的复合条件表明式,则需要改为一多元唯有单条件的嵌套的论断。例如:

  1 if a or b
  2    x
  3 else
  4    y

相应的逻辑为

www.8522.com 5

Paste_Image.png

单身路线

独自路线:至少沿一条新的边移动的路径

www.8522.com 6

独立路线

  • ###### 第一步:画出控制流图

  • 流程图用来描述程序控制结构。

  • 可将流程图映射到一个相应的流图(假诺流程图的菱形决定框中不带有复合条件)。

  • 在流图中,每一个圆,称为流图的结点,代表一个或六个语句。

  • 一个处理方框连串和一个菱形决测框可被映射为一个结点,流图中的箭头,称为边或连续,代表控制流,类似于流程图中的箭头。

  • 一条边必须下马于一个结点,就算该结点并不表示任何语句(例如:if-else-then结构)。

  • 由边和结点限定的限定称为区域

  • 总计区域时应包括图外部的界定。

![](https://upload-images.jianshu.io/upload_images/938465-0a2602acb5e8d1a0.png)

代码



![](https://upload-images.jianshu.io/upload_images/938465-b3e4f28c482c3755.png)

第一步
  • ###### 第二步:统计圈复杂度

圈复杂度是一种为程序逻辑复杂性提供定量测算的软件度量,将该度量用于统计程序的骨干的单独路线数目。独立路线必须包含一条在概念以前从未用到的边。
有以下二种方法总结圈复杂度:

  1. 流图中区域的数据对应于环型的纷繁;
  2. 给定流图G的圈复杂度V(G),定义为V(G)=E-N+2,E是流图中边的数码,N是流图中结点的数额;
  3. 给定流图G的圈复杂度V(G),定义为V(G)=P+1,P是流图G中判断结点的数据。
![](https://upload-images.jianshu.io/upload_images/938465-da44feed01ae1cb1.png)

计算圈复杂度
  • ###### 第三步:导出测试用例

依照地方的计量办法,可得出六个独立的门径。(V(G)值正好等于该程序的独自路线的条数。)

路径1:4-14
路径2:4-6-7-14
路径3:4-6-8-10-13-4-14
路径4:4-6-8-11-13-4-14

遵照地点的独立路线,去规划输入数据,使程序分别施行到地方四条路子。

  • ###### 第四步:准备测试用例

为了保险基本途径集中的每一条途径的推行,遵照判断结点给出的准绳,采纳十分的数码以保险某一条路子可以被测试到,满足下边例子基本路径集的测试用例是:

www.8522.com 7

基本路线测试用例

非得注意,一些单身的路线,往往不是一点一滴孤立的,有时它是程序正常的控制流的一部分,那时,这一个途径的测试可以是另一条途径测试的一有些。

工具方法:图形矩阵
  • 导出控制流图和操纵基本测试路径的进程均需要机械化,为了支付援救基本路径测试的软件工具,称为图形矩阵的数据结构很有用。
  • 利用图形矩阵可以实现活动地确定一个主干路线集。
  • 一个图纸矩阵是一个方阵,其行/列数控制流图中的结点数,每行和每列依次对应到一个被标识的结点,矩阵元素对应到结点间的接连(即边)。
  • 在图中,控制流图的每一个结点都用数字加以标识,每一条边都用字母加以标识。
  • 假定在控制流图中第i个结点到第j个结点有一个名为x的边相连接,则在对应的图样矩阵中第i行/第j列有一个非空的元素x。

对每个矩阵项参预连天权值,图矩阵就足以用于在测试中评估程序的控制结构,连接权值为控制流提供了此外的音讯。最简便易行状况下,连接权值是
1(存在连接)或0(不设有连接),但是,连接权值可以给予更有趣的属性:

1. 执行连接(边)的概率。
2. 穿越连接的处理时间。
3. 穿越连接时所需的内存。
4. 穿越连接时所需的资源。

www.8522.com 8

图表矩阵

连接权为“1”表示存在一个总是,在图中只要一行有六个或更多的元素“1”,则这行所表示的结点一定是一个断定结点,通过连接矩阵中有多少个以上(包括三个)元素为“1”的个数,就足以拿走确定该图圈复杂度的另一种算法。

发表评论

电子邮件地址不会被公开。 必填项已用*标注