菜单

bwin必赢白盒测试详细总结

2019年6月16日 - 美术艺术
bwin必赢白盒测试详细总结

测试文章内容,包含一些测试语句,因为不包含足够的词语,所以必须输入足够的语句,才能正常的入库处理。

白盒测试基本要求

测试覆盖标准

  1. 语句覆盖:是一个比较弱的测试标准,它的含义是:选择足够的测试用例,使得程序中每个语句至少都能被执行一次
  1. 判定覆盖(也称为分支覆盖):执行足够的测试用例,使得程序中的每一个分支至少都通过一次
  1. 条件覆盖:执行足够的测试用例,使程序中每个判断的每个条件的每个可能取值至少执行一次
  1. 判定/条件覆盖:执行足够的测试用例,使得判定中每个条件取到各种可能的值,并使每个判定取到各种可能的结果
  2. 条件组合覆盖:执行足够的例子,使得每个判定中条件的各种可能组合都至少出现一次

主要方法

  1. 逻辑驱动测试
  1. 路径测试

语句覆盖

例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.

bwin必赢 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
}

bwin必赢 2

流程图

为了测试语句覆盖率只要设计一个测试用例就可以把三个执行语句块中的语句覆盖了。测试用例输入为:x=4、y=5、z=5,程序执行的路径是:abd
该测试用例虽然覆盖了可执行语句,但并不能检查判断逻辑是否有问题,例如在第一个判断中把&&错误的写成了||,则上面的测试用例仍可以覆盖所有的执行语句。

判定覆盖

例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语句等。所以“分支覆盖”更一般的含义是:使得每一个分支获得每一种可能的结果

条件覆盖

一个判定中往往包含了若干个条件,如例1的程序中,判定 (A>1) AND
(B=0)包含了两个条件: A>1以及
B=0,所以可引进一个更强的覆盖标准——“条件覆盖”。

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

条件覆盖测试用例



注意:

如对例2设计了下面的测试用例,则虽然满足了条件覆盖,但只覆盖了第一个条件的取假分支和第二个条件的取真分支,不满足分支覆盖的要求。

bwin必赢 3

测试用例

分支(判定)/条件覆盖

针对上面的问题引出了另一种覆盖标准——“分支(判定)/条件覆盖”,它的含义是:执行足够的测试用例,使得分支中每个条件取到各种可能的值,并使每个分支取到各种可能的结果。

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

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



分支/条件覆盖从表面来看,它测试了所有条件的取值,但是实际上某些条件掩盖了另一些条件。

条件组合覆盖

针对上述问题又提出了另一种标准——“条件组合覆盖”。它的含义是:执行足够的例子,使得每个判定中条件的各种可能组合都至少出现一次。满足“条件组合覆盖”的测试用例是一定满足“分支覆盖”、“条件覆盖”和“分支/条件覆盖”的。

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就没有执行,因此,条件组合覆盖标准仍然是不彻底。

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种条件取值的组合。
测试用例如下表:

bwin必赢 4

条件组合覆盖测试用例

上面的测试用例覆盖了所有条件的可能取值的组合,覆盖了所有判断的可取分支,但是却丢失了一条路径abe。

相关文章

发表评论

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

网站地图xml地图