白盒测试之基本路径测试法

上一篇 / 下一篇  2008-04-23 14:40:41

51Testing软件测试网.E7e)wcimS5\

 白盒测试的测试方法有代码检查法、静态结构分析法、静态质量度量法、逻辑覆盖法、基本路径测试法、域测试、符号测试、Z路径覆盖、程序变异。

F)I!tyzJ1LY8q0

1J*{\`3{wt0  其中运用最为广泛的是基本路径测试法。51Testing软件测试网'f#_[[yZ6G

2|*Ki7d`;ce0  基本路径测试法是在程序控制流图的基础上,通过分析控制构造的环路复杂性,导出基本可执行路径集合,从而设计测试用例的方法。51Testing软件测试网,TB6aAK~

51Testing软件测试网7hSg.~o&[3x,Ar7Xz

  设计出的测试用例要保证在测试中程序的每个可执行语句至少执行一次。

#`0z0U b%k*y!Np051Testing软件测试网 OD lR(in%g I

  在程序控制流图的基础上,通过分析控制构造的环路复杂性,导出基本可执行路径集合,从而设计测试用例。包括以下4个步骤和一个工具方法:51Testing软件测试网!h'x)lwA1`

51Testing软件测试网uQm$T4T5yh

  1. 程序的控制流图:描述程序控制流的一种图示方法。

iW l{4[v0o+Q;_0

!x)} ?q.nIh RS0  2. 程序圈复杂度:McCabe复杂性度量。从程序的环路复杂性可导出程序基本路径集合中的独立路径条数,这是确定程序中每个可执行语句至少执行一次所必须的测试用例数目的上界。

G)_ V'f\8x+C&g[051Testing软件测试网E~a f`wy\!tW

  3. 导出测试用例:根据圈复杂度和程序结构设计用例数据输入和预期结果51Testing软件测试网X#Ns-U4N.z

51Testing软件测试网 DMTY8r2D

  4. 准备测试用例:确保基本路径集中的每一条路径的执行。51Testing软件测试网L%H@u(J;h+a5d`)j

;c2F!SFs2EPNN0  工具方法:

S E:U:E#Ebf+_051Testing软件测试网8} Y0{U;\

  图形矩阵:是在基本路径测试中起辅助作用的软件工具,利用它可以实现自动地确定一个基本路径集。

lZ A,A2U {D0

9AT ~n]O Qg0  程序的控制流图:描述程序控制流的一种图示方法。51Testing软件测试网*G's9Yn#| D%w9TQ.S

51Testing软件测试网/tf2r0dd8n%L$|\x

  圆圈称为控制流图的一个结点,表示一个或多个无分支的语句或源程序语句51Testing软件测试网kS(|"uK8t v

|T8P M+e^051Testing软件测试网1J h4c.P*|H

  流图只有二种图形符号:51Testing软件测试网C'W9dD"E6[[!o

51Testing软件测试网}l2e!DD{i4W

  图中的每一个圆称为流图的结点,代表一条或多条语句。51Testing软件测试网;khe`s PZ

51Testing软件测试网 OI._o)LBTMs1DK

  流图中的箭头称为边或连接,代表控制流51Testing软件测试网eGm-K h:aGsi

51Testing软件测试网} Cqs'~){

  任何过程设计都要被翻译成控制流图。

6XI }8n3b]0

.a/[[M Yino0  如何根据程序流程图画出控制流程图?

RB'u&K/sD$B051Testing软件测试网,B3R"ZGg!] S2tFA

  在将程序流程图简化成控制流图时,应注意:

4a-F%E&rV` X e-JW051Testing软件测试网 _}`.Afg~6e

  n 在选择或多分支结构中,分支的汇聚处应有一个汇聚结点。

!g pZ4~-P&G"dW7[0

0gU`*I[ww0  n 边和结点圈定的区域叫做区域,当对区域计数时,图形外的区域也应记为一个区域。

,]i({FLX9d X6mn0

WN d)\S;S'^f%D0  如下页图所示51Testing软件测试网?:V1vrw ?+d

51Testing软件测试网l O9o G hijX;rI

n 如果判断中的条件表达式是由一个或多个逻辑运算符 (OR, AND, NAND, NOR) 连接的复合条件表达式,则需要改为一系列只有单条件的嵌套的判断。

TB&@)ue9s*gj051Testing软件测试网*^[Uu4kG P

  例如:

HnW}~0

\0y-gXxfH0  1 if a or b51Testing软件测试网%y3v Y0JuT$@@!B

51Testing软件测试网 {cf@2Cv6s

  2 x

?._oo(\]_051Testing软件测试网)J+dgo]

  3 else

z/GN3]"d-h9m-y2?N0

-~7pY$w+~$R ^(@7`:J0  4 y51Testing软件测试网TD||R:KNy'^/M

51Testing软件测试网5l%P%d+Tx

  对应的逻辑为:

W] W0H${ki0

51Testing软件测试网Pz3o.H ne rl

51Testing软件测试网&y yumI

  独立路径:至少沿一条新的边移动的路径51Testing软件测试网QY0a8Kr eo'~

51Testing软件测试网 w;b{Z~m2z`e

o 第一步:画出控制流图

#ERU.b}@051Testing软件测试网dcZ Bf-d

  流程图用来描述程序控制结构。可将流程图映射到一个相应的流图(假设流程图的菱形决定框中不包含复合条件)。在流图中,每一个圆,称为流图的结点,代表一个或多个语句。一个处理方框序列和一个菱形决测框可被映射为一个结点,流图中的箭头,称为边或连接,代表控制流,类似于流程图中的箭头。一条边必须终止于一个结点,即使该结点并不代表任何语句(例如:if-else-then结构)。由边和结点限定的范围称为区域。计算区域时应包括图外部的范围。

/_2\+TG8m mG V0

51Testing软件测试网,c[F*Y!XF} K

51Testing软件测试网?9Y} K-`5dK0g

  画出其程序流程图和对应的控制流图如下

H&[p |D%_0

3qN'ei ~mgH0

'HnX0KD!ag0  o 第二步:计算圈复杂度

\qZ?@ Jk0

{k.o iJei\0  圈复杂度是一种为程序逻辑复杂性提供定量测度的软件度量,将该度量用于计算程序的基本的独立路径数目,为确保所有语句至少执行一次的测试数量的上界。独立路径必须包含一条在定义之前不曾用到的边。

b1Ds#N&Z.\@4s0

H)Kl.EV9wN6_(_0  有以下三种方法计算圈复杂度:51Testing软件测试网O@C"Fpp%y

X2LJT[IsN/\g A0  流图中区域的数量对应于环型的复杂性;

;n,v r9w@M0

L3Sm n a*j%}~0  给定流图G的圈复杂度V(G),定义为V(G)=E-N+2,E是流图中边的数量,N是流图中结点的数量;51Testing软件测试网!C;@:ksLgt-j

51Testing软件测试网GO%?Q e.Y

  给定流图G的圈复杂度V(G),定义为V(G)=P+1,P是流图G中判定结点的数量。

:{Y^*O"^0

]6JX?0x!\2~ @-Z+_0

o 第三步:导出测试用例51Testing软件测试网U,GphI)Y}

(U#n:?:F6\iK0  根据上面的计算方法,可得出四个独立的路径。(一条独立路径是指,和其他的独立路径相比,至少引入一个新处理语句或一个新判断的程序通路。V(G)值正好等于该程序的独立路径的条数。)51Testing软件测试网#??U;Ij"]qs(E.X

51Testing软件测试网4S9CK&Or!r{$K

  ü 路径1:4-1451Testing软件测试网#a8OE3U"i#r3}'\e

51Testing软件测试网``*}k(tH^ b U

  ü 路径2:4-6-7-1451Testing软件测试网'sY?xJ\-T n

51Testing软件测试网(Ye~1k}t/Bh

  ü 路径3:4-6-8-10-13-4-1451Testing软件测试网%ih:E4Edh R

51Testing软件测试网l"X;u J(j#~g~

  ü 路径4:4-6-8-11-13-4-1451Testing软件测试网I&^:?]K*hv~

51Testing软件测试网$}3H3tjN5[Z

  根据上面的独立路径,去设计输入数据,使程序分别执行到上面四条路径。51Testing软件测试网Z-m L f'Y]

51Testing软件测试网"^ TeO}!m)k}

  o 第四步:准备测试用例51Testing软件测试网8fOOh9]P*{V DoW

!ps*t&LU0Ss?0  为了确保基本路径集中的每一条路径的执行,根据判断结点给出的条件,选择适当的数据以保证某一条路径可以被测试到,满足上面例子基本路径集的测试用例是:

}d["R$N"?0X;LG@0

51Testing软件测试网S9]&pQA ef1b,Rr

举例说明:

^)[6?5nm.ba0

B%Q&Kx _{f\l/W!?0  例:下例程序流程图描述了最多输入50个值(以–1作为输入结束标志),计算其中有效的学生分数的个数、总分数和平均值。

Fe$N/YD+C8m l0

!\T\7G U3`7[6Sz\g#}051Testing软件测试网P R\ e7_Jd

  步骤1:导出过程的流图。

3|R5]F)Y(`QF`0

51Testing软件测试网F-Ny8}'UXxm

51Testing软件测试网5V8G7S#^{_(ihi;m Tq I

  步骤2:确定环形复杂性度量V(G):51Testing软件测试网Q2Bb"W;U!^

-|?r*l$mJz0  1)V(G)= 6 (个区域)51Testing软件测试网q`%] UR

51Testing软件测试网kg Iz%hf:| wE

  2)V(G)=E–N+2=16–12+2=6

o`8L#h/x#|B;]0

$G~kvy0  其中E为流图中的边数,N为结点数;

9l3D,SiQ/y3C3l0

2h(eUJ)H9utA9[+F0  3)V(G)=P+1=5+1=6

U"?pk!X J b0

&ml ^0eQ$FA-}{0  其中P为谓词结点的个数。在流图中,结点2、3、5、6、9是谓词结点。

0{0J8D E&u$S0

4\:vSaQ;BP!ph3]0  步骤3:确定基本路径集合(即独立路径集合)。于是可确定6条独立的路径:51Testing软件测试网xG4g)k*P4cI4o/P

51Testing软件测试网6|O ]-R4IQEXZH P A

  路径1:1-2-9-10-1251Testing软件测试网A)OJ,C"eX)d4d^

BKq$w)k0  路径2:1-2-9-11-1251Testing软件测试网t6Ia |;oA+M

"rXtSBA0  路径3:1-2-3-9-10-12

8j`4x%u0d2Dd:E0

ta(t[z9I.`0  路径4:1-2-3-4-5-8-2…

2BLgvM#D]~051Testing软件测试网)K@^g {

  路径5:1-2-3-4-5-6-8-2…51Testing软件测试网.r tw+VA Y rBB

51Testing软件测试网8oE-_v(Ig*k+I8el+Or)d

  路径6:1-2-3-4-5-6-7-8-2…

+NU f"Fp{0FX051Testing软件测试网?wu?C(n/{

  步骤4:为每一条独立路径各设计一组测试用例,以便强迫程序沿着该路径至少执行一次。

En?E6CD051Testing软件测试网/C?^_c

  1)路径1(1-2-9-10-12)的测试用例:51Testing软件测试网x)E C\A#LC

51Testing软件测试网o/[p0B ^i T*vI

  score[k]=有效分数值,当k < i ;

0eo.mT6PC9s|:P0

%Cvj`+j |Qa0  score[i]=–1, 2≤i≤50;51Testing软件测试网1Ap8c#p l7r5ZZ5y9?

[:ZN4C;vlz,y ];Qy0  期望结果:根据输入的有效分数算出正确的分数个数n1、总分sum和平均分average。

W&v1T;`Nn/sn0

5u%Vu(J\a wq0  2)路径2(1-2-9-11-12)的测试用例:

$E3p3J0Q:qr+d*t0

9\i\#~1R0  score[ 1 ]= – 1 ;51Testing软件测试网[ m bXAPu!`!Re

51Testing软件测试网n'_Y t7t

  期望的结果:average = – 1 ,其他量保持初值。

}~OP@#q$U#b051Testing软件测试网`!l&d~O R0D

  3)路径3(1-2-3-9-10-12)的测试用例:

$jv|vh:Xs0

U(C'o%q6}PY}0  输入多于50个有效分数,即试图处理51个分数,要求前51个为有效分数;51Testing软件测试网 UTn^9BE:F

j$d j[4fu \G2x0  期望结果:n1=50、且算出正确的总分和平均分。51Testing软件测试网Tn"l%_ Tc`$[W

51Testing软件测试网e u a*i\E

  4)路径4(1-2-3-4-5-8-2…)的测试用例:

"_Z6O(k r q5n_P"s051Testing软件测试网3ga ['T:Z']r;h.~3H

  score[i]=有效分数,当i<50;51Testing软件测试网)N1B$_g8ZeB}

51Testing软件测试网:Ck+M}*b)[1xA0J'P

  score[k]<0, k< i ;

,I%D\}WD{4G9^]/{o#l0

"B7eu^0E!x)l0  期望结果:根据输入的有效分数算出正确的分数个数n1、总分sum和平均分average

,O8j4Pl1mv0

:p*s9p2In N"c[[{,y"vzF0  score[i]=有效分数, 当i<50;51Testing软件测试网gZ:b7h$^c*UClP7`

51Testing软件测试网*}L!Sf` VUF-y.V

  score[k]>100, k< i ;

)O"Z'],tjjN%J D051Testing软件测试网Yx:Mg\L'dI

  期望结果:根据输入的有效分数算出正确的分数个数n1、总分sum和平均分average。

ngx9tT)e0

U9c3M@xCR9M m]&qf0  6)路径6(1-2-3-4-5-6-7-8-2…)的测试用例:51Testing软件测试网i\f0O7I|D

51Testing软件测试网0nhV M { pn

  score[i]=有效分数, 当i<50;

I:`o"Dv/aP#KUzA#^051Testing软件测试网zjz^X'J:@9x8o

  期望结果:根据输入的有效分数算出正确的分数个数n1、总分sum和平均分average。

^K:No/K)C4X051Testing软件测试网RJc-jf&ym7y

  注意事项:51Testing软件测试网@(Zs^{2RCt

N#e?+Lfy#v3]0  必须注意,一些独立的路径,往往不是完全孤立的,有时它是程序正常的控制流的一部分,这时,这些路径的测试可以是另一条路径测试的一部分。

/F(Wa[j:`1Zu{0

!m `"q2J1vd0  方法工具:图形矩阵

Vi{"Q3w{SM051Testing软件测试网py `'mv$e-o.^| q%a

  o 导出控制流图和决定基本测试路径的过程均需要机械化,为了开发辅助基本路径测试的软件工具,称为图形矩阵(graph matrix)的数据结构很有用。51Testing软件测试网K7M|WW(AJ*r5o4q

51Testing软件测试网$^I.B,T1|1~Gv

  利用图形矩阵可以实现自动地确定一个基本路径集。一个图形矩阵是一个方阵,其行/列数控制流图中的结点数,每行和每列依次对应到一个被标识的结点,矩阵元素对应到结点间的连接(即边)。在图中,控制流图的每一个结点都用数字加以标识,每一条边都用字母加以标识。如果在控制流图中第i个结点到第j个结点有一个名为x的边相连接,则在对应的图形矩阵中第i行/第j列有一个非空的元素x。

;WD[ n1Q1z?051Testing软件测试网k)z |%})JHQK

  对每个矩阵项加入连接权值(link weight),图矩阵就可以用于在测试中评估程序的控制结构,连接权值为控制流提供了另外的信息。最简单情况下,连接权值是 1(存在连接)或0(不存在连接),但是,连接权值可以赋予更有趣的属性:51Testing软件测试网 v2g?W(Gru [[

h:s){ D'_fd~O?0  执行连接(边)的概率。

B}i'v;I pM~2]#~051Testing软件测试网0Ah }g9Of

  穿越连接的处理时间。

.` P `/`_"n z0

/EW+dEfo.]^0  穿越连接时所需的内存

g{$@cXX ^9@0

+[7aNj?8g,x rA6W_0  穿越连接时所需的资源51Testing软件测试网)ZT1\Ba(j

51Testing软件测试网8Q8S B%Yk_0q ML2FD2}"x

  根据上面的方法对例4画出图形矩阵如下:51Testing软件测试网9_UJ0Z zth~

6n9SZr]^(XZZ051Testing软件测试网X9a8b9xJ1nd2J!q|-]&z

  连接权为“1”表示存在一个连接,在图中如果一行有两个或更多的元素“1”,则这行所代表的结点一定是一个判定结点,通过连接矩阵中有两个以上(包括两个)元素为“1”的个数,就可以得到确定该图圈复杂度的另一种算法。

g!~7u#Ws$zsH+D$S0

TAG:

 

评分:0

我来说两句

日历

« 2024-05-09  
   1234
567891011
12131415161718
19202122232425
262728293031 

数据统计

  • 访问量: 11565
  • 日志数: 22
  • 建立时间: 2008-03-11
  • 更新时间: 2009-02-06

RSS订阅

Open Toolbar