第四章 白盒测试方法
1. 简述白盒测试用例的设计方法,并进行分析总结。
从覆盖源程序语句的详尽程度分析,逻辑覆盖主要有以下不同的覆盖标准:语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、条件组合覆盖和路径覆盖。实际项目中,由于程序内部的逻辑存在不确定性和无穷性,尤其对于大规模复杂软件,不必采用所有的覆盖指标,而应根据实际情况选择合适的覆盖指标。
独立路径测试是在程序控制流图的基础上,通过分析控制结构的环路复杂性,导出可执行的独立路径集合,从而设计出相应的测试用例。设计出的测试用例要保证被测程序的每条可执行的独立路径至少被执行一次。独立路径测试给出了满足路径覆盖指标所需测试用例的下限,同时给出了语句覆盖的上限,它可以确保对所有相互独立的决策结果进行测试。
2. 分析归纳逻辑覆盖的各种策略,并比较每种覆盖的特点,分析在怎样的情况下采用何种覆盖方式。
(1)语句覆盖是选择足够多的测试数据,使被测程序中每个语句至少执行一次。语句覆盖是最弱的逻辑覆盖标准。
(2)判定覆盖又叫分支覆盖,它不仅每个语句必须至少执行一次,而且每个判定表达式的每种可能的结果都应该至少执行一次。判定条件覆盖比语句覆盖强,但是对程序逻辑的覆盖程度仍然不高。
(3)条件覆盖的含义是,使判定表达式中的每个条件都取到各种可能的结果。条件覆盖通常比判定覆盖强,但是也可能有相反的情况:虽然每个条件都取到了两个不同的结果,判定表达式却始终只取一个值。
(4)判定/条件覆盖的含义是,选取足够多的测试数据,使得判定表达式中的每个条件都取到各种可能的值,而且每个判定表达式也都取到各种可能的结果。但有时判定/条件覆盖也并不比条件覆盖更强。
(5)条件组合覆盖是更强的逻辑覆盖标准,它要求选取足够的测试数据,使得每个判定表达式中条件的各种可能组合都至少出现一次。满足条件组合覆盖标准的测试数据,也一定满足判定覆盖、条件覆盖和判定/条件覆盖标准。因此,条件组合覆盖是前述几种覆盖标准中最强的。但是,满足条件组合覆盖标准的测试数据并不一定能使程序中的每一条路径都执行到。
(6)路径覆盖的定义是选取足够多测试数据,使程序的每一条可能路径都至少执行一次。但在实际问题中,一个不太复杂的程序,其路径数都可能是一个庞大的数字,以致要在测试中覆盖所有的路径是不可能实现的。即使对于路径数有限的程序做到了路径覆盖,也不能保证被测程序的正确性。
3. 对图所示程序段进行语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、条件组合覆盖和路径覆盖方法进行测试用例设计。
语句覆盖:
x=90,y=90
x=79,y=90
x=70,y=60
判定覆盖:同上
条件覆盖:同上
判定/条件覆盖:同上
条件组合覆盖:
Ⅰx>=80,y>=80
IIx>=80,y<80
Ⅲx<80,y>=80
IVx<80,y<80
Vx>=90,y>=90,x+y>=140
VIx>=90,y<90,x+y>=140
VIIx<90,y>=90,x+y>=140
VIIIx<90,y<90,x+y>=140
IXx>=90,y>=90,x+y<140不存在
Xx>=90,y<90,x+y<140
XIx<90,y>=90,x+y<140
XIIx<90,y<90,x+y<140
x=90,y=90
x=90,y=70
x=70,y=90
x=70,y=70
x=100,y=30
x=30,y=100
x=80,y=50
路径覆盖:同语句覆盖
4. 请将下述语句按照各种覆盖方法设计测试用例。
if (a>2 && b<3 &line;&line; (c>4 && d<5))
statement;
语句覆盖:
a=3,b=2,c=5,d=5
a=2,b=2,c=5,d=5
判定覆盖:同上
条件覆盖:
a=3,b=2,c=5,d=5
a=2,b=4,c=3,d=4
判定/条件覆盖:同条件覆盖
条件组合覆盖:
I a>2,b<3,c>4,d<5
II a>2,b<3,c>4,d>=5
III a>2,b<3,c<=4,d<5
Iv a>2,b<3,c<=4,d>=5
v a>2,b>=3,c>4,d<5
vI a>2,b>=3,c>4,d>=5
vII a>2,b>=3,c<=4,d<5
vIII a>2,b>=3,c<=4,d>=5
Ix a<=2,b<3,c>4,d<5
x a<=2,b<3,c>4,d>=5
xI a<=2,b<3,c<=4,d<5
xII a<=2,b<3,c<=4,d>=5
xIII a<=2,b>=3,c>4,d<5
xIv a<=2,b>=3,c>4,d>=5
xw a<=2,b>=3,c<=4,d<5
xw a<=2,b>=3,c<=4,d>=5
a=2,b=2,c=5,d=4
a=2,b=2,c=5,d=5
a=2,b=2,c=4,d=4
a=2,b=2,c=4,d=5
......
5. 针对 test 函数按照基本路径测试方法设计测试用例。
6. 对下面的 N-S 图,计算所需的最少测试用例数。
(2+2*2)*2=12