【2007】知识是需要沉淀的; 思想是在不断学习,磨练中成熟的; 技术是在创新中开拓的…………… 【2007】不经历风雨,怎能见彩虹,没有人能随随便便成功。加油!

黑盒测试的测试用例设计方法

上一篇 / 下一篇  2010-03-01 18:32:55 / 个人分类:软件测试理论

Yf1DAx,v!k~%upTB{0等价类划分方法51Testing软件测试网 \ |/Iu[

51Testing软件测试网!Q;F9P6p M%C'T^ Z/V[

  ·边界值分析方法

~fr y"F051Testing软件测试网M9me{jz$^?%U_

  ·错误推测方法51Testing软件测试网]+Y~2D*a{

51Testing软件测试网m0S-^B+iR

  ·因果图方法51Testing软件测试网&J'X;L+j:@dv6g

51Testing软件测试网hbT)I&T

  等价类划分:

9BA.w)vvh0

,I-Lk)d[ d-_E0  是把所有可能的输入数据,即程序的输入域划分成若干部分(子集),然后从每一个子集中选取少数具有代表性的数据作为测试用例.该方法是一种重要的,常用的黑盒测试用例设计方法.51Testing软件测试网KL Kvl3B.R A

51Testing软件测试网/e9WC$~@1G F

  1)划分等价类:等价类是指某个输入域的子集合.在该子集合中,各个输入数据对于揭露程序中的错误都是等效的.并合理地假定:测试某等价类的代表值就等于对这一类其它值的测试.因此,可以把全部输入数据合理划分为若干等价类,在每一个等价类中取一个数据作为测试的输入条件,就可以用少量代表性的测试数据.取得较好的测试结果.等价类划分可有两种不同的情况:有效等价类和无效等价类.51Testing软件测试网"w~&R.}+mM:L_

;N\/R#r#^Eb0  有效等价类:是指对于程序的规格说明来说是合理的,有意义的输入数据构成的集合.利用有效等价类可检验程序是否实现了规格说明中所规定的功能和性能.51Testing软件测试网7AY\`g(o

0V7R"ZHn` k!{9]0  无效等价类:与有效等价类的定义恰巧相反.51Testing软件测试网W`#j_o)z|e

51Testing软件测试网Q-a |M1I;}!k

  设计测试用例时,要同时考虑这两种等价类.因为,软件不仅要能接收合理的数据,也要能经受意外的考验.这样的测试才能确保软件具有更高的可靠性.

o)tk(b0@} c$H0

h"jKK6Mpe*l0  2)划分等价类的方法:下面给出六条确定等价类的原则.51Testing软件测试网 @ {q][h2a2F,g

51Testing软件测试网TGI}kb

  在输入条件规定了取值范围或值的个数的情况下,则可以确立一个有效等价类和两个无效等价类.51Testing软件测试网 UI2@#_b

51Testing软件测试网*l.H:N+u B

  在输入条件规定了输入值的集合或者规定了必须如何的条件的情况下,可确立一个有效等价类和一个无效等价类.51Testing软件测试网!C!p5w_*i

1s)NPiGC%N0  在输入条件是一个布尔量的情况下,可确定一个有效等价类和一个无效等价类.

YjjKZ h051Testing软件测试网dW~6y A1z5Uo

  在规定了输入数据的一组值(假定n),并且程序要对每一个输入值分别处理的情况下,可确立n个有效等价类和一个无效等价类.51Testing软件测试网/~,A5`6d#u!{)?-O

51Testing软件测试网*M#nur(q(tsB

  在规定了输入数据必须遵守的规则的情况下,可确立一个有效等价类(符合规则)和若干个无效等价类(从不同角度违反规则).

*mM)LNE k${"{051Testing软件测试网B`!bR/ye

  在确知已划分的等价类中各元素在程序处理中的方式不同的情况下,则应再将该等价类进一步的划分为更小的等价类.51Testing软件测试网3jFPu+cr&Q9i

q^%Hf0W.h*|0  3)设计测试用例:在确立了等价类后,可建立等价类表,列出所有划分出的等价类:

` Fj|@ ]6C:lw051Testing软件测试网a[G+Cs y p

  输入条件有效等价类无效等价类51Testing软件测试网!TW ePPT7J3Tr

+l6[:i5e!o,kui0  ... ... ...

%p2h ^_$@#aw3z B;G0

(O(IwC+Bc f-^DA0  ... ... ...51Testing软件测试网M&D.@2}"Y-Bw

51Testing软件测试网\+@4b`j_x

  然后从划分出的等价类中按以下三个原则设计测试用例:

qrHUYU*L051Testing软件测试网l&j"cC%R1u

  为每一个等价类规定一个唯一的编号.

@ g,^mN9y }]'l4q0

WQ$t3[3S.w0  设计一个新的测试用例,使其尽可能多地覆盖尚未被覆盖地有效等价类,重复这一步.直到所有的有效等价类都被覆盖为止.51Testing软件测试网}%jU mi7MS

51Testing软件测试网,M4?i8J0S'a}$}

  设计一个新的测试用例,使其仅覆盖一个尚未被覆盖的无效等价类,重复这一步.直到所有的无效等价类都被覆盖为止.

#_.lG*{/?0

C"t i D _Alr0边界值分析法:51Testing软件测试网TT C b7@d"Z,u

51Testing软件测试网EN l2dF0[2\

  边界值分析方法是对等价类划分方法的补充.51Testing软件测试网{7Z%BKge

51Testing软件测试网qE O_F'` Q/{

  (1)边界值分析方法的考虑:51Testing软件测试网D-`_"hP#v{8]

*s'SYZTX0  长期的测试工作经验告诉我们,大量的错误是发生在输入或输出范围的边界上,而不是发生在输入输出范围的内部.因此针对各种边界情况设计测试用例,可以查出更多的错误.51Testing软件测试网a1J+o2jV

51Testing软件测试网 ZX+kc1_6s{)gH

  使用边界值分析方法设计测试用例,首先应确定边界情况.通常输入和输出等价类的边界,就是应着重测试的边界情况.应当选取正好等于,刚刚大于或刚刚小于边界的值作为测试数据,而不是选取等价类中的典型值或任意值作为测试数据.

#c%\7Ws!_0

fN\'`o([0o0  (2)基于边界值分析方法选择测试用例的原则:

?c^8i~F H ^0

'q,O#u#dW;B[0  1)如果输入条件规定了值的范围,则应取刚达到这个范围的边界的值,以及刚刚超越这个范围边界的值作为测试输入数据.

Xkx#S(D{.D051Testing软件测试网O4qn;k(UTa7k

  2)如果输入条件规定了值的个数,则用最大个数,最小个数,比最小个数少一,比最大个数多一的数作为测试数据.51Testing软件测试网ZY'@;ewy+]9p^ D

jh n2S+o0  3)根据规格说明的每个输出条件,使用前面的原则1).51Testing软件测试网9F1o/f6Pt8|u

51Testing软件测试网GP H/K'[ @.r(M

  4)根据规格说明的每个输出条件,应用前面的原则2).51Testing软件测试网 R1L)Q s!r._4W

51Testing软件测试网@'u4s uy%?U%d

  5)如果程序的规格说明给出的输入域或输出域是有序集合,则应选取集合的第一个元素和最后一个元素作为测试用例.51Testing软件测试网 H7hVv(V}Vn

*Nh N7l1lvg#A0  6)如果程序中使用了一个内部数据结构,则应当选择这个内部数据结构的边界上的值作为测试用例.51Testing软件测试网9jkm"M&\N

51Testing软件测试网~7F&_)B7L He9Uq

  7)分析规格说明,找出其它可能的边界条件.51Testing软件测试网(Y"v2N d!GM@ l%Y^0c

51Testing软件测试网crl5bOBr4]&C

  错误推测法

#Iws)w.\ijs0

;ypS2}UX&O0  错误推测法:基于经验和直觉推测程序中所有可能存在的各种错误,从而有针对性的设计测试用例的方法.

3T J!?$i|*C\9VR:PY$J0

F M r|5@)N0  错误推测方法的基本思想:列举出程序中所有可能有的错误和容易发生错误的特殊情况,根据他们选择测试用例.例如,单元测试时曾列出的许多在模块中常见的错误.以前产品测试中曾经发现的错误等,这些就是经验的总结.还有,输入数据和输出数据为0的情况.输入表格为空格或输入表格只有一行.这些都是容易发生错误的情况.可选择这些情况下的例子作为测试用例.

1gM)Y%BM Oi,d0

XAoa)D EO [0因果图方法:

6SLI$FAP)OD0

{\gC,v9jU AS0  前面介绍的等价类划分方法和边界值分析方法,都是着重考虑输入条件,但未考虑输入条件之间的联系,相互组合等.考虑输入条件之间的相互组合,可能会产生一些新的情况.但要检查输入条件的组合不是一件容易的事情,即使把所有输入条件划分成等价类,他们之间的组合情况也相当多.因此必须考虑采用一种适合于描述对于多种条件的组合,相应产生多个动作的形式来考虑设计测试用例.这就需要利用因果图(逻辑模型).

EV0@7fo5wW0

CHp7zQ-cB5X0  因果图方法最终生成的就是判定表.它适合于检查程序输入条件的各种组合情况.

yd!VTm&C*M0  利用因果图生成测试用例的基本步骤:
4lb\8}LUaHU051Testing软件测试网 f]ILf6c4Xg
  (1) 分析软件规格说明描述中, 那些是原因(即输入条件或输入条件的等价类),那些是结果(即输出条件), 并给每个原因和结果赋予一个标识符.

qb)Rgg:_)`4L9ZG0  (2)分析软件规格说明描述中的语义.找出原因与结果之间,原因与原因之间对应的关系.根据这些关系,画出因果图.

/V#dd-Yk4]fdYl5Ax0

4gf z-k"w#w/{!Ao0  (3)由于语法或环境限制,有些原因与原因之间,原因与结果之间的组合情况不不可能出现.为表明这些特殊情况,在因果图上用一些记号表明约束或限制条件.51Testing软件测试网^`&g)K ]

Z}&la-x3l$i`@$e0  (4)把因果图转换为判定表.51Testing软件测试网(LF0S/s8Q.r`z|

&]q;@}8q Ht8B;z0  (5)把判定表的每一列拿出来作为依据,设计测试用例.

f9QPh]FhRt051Testing软件测试网/xjv7?Q1z,XHt

  从因果图生成的测试用例(局部,组合关系下的)包括了所有输入数据的取TRUE与取FALSE的情况,构成的测试用例数目达到最少,且测试用例数目随输入数据数目的增加而线性地增加.51Testing软件测试网0E.Ptp\.C)h

T8e w1P S(?0  除了上述几种黑盒测试的测试用例设计方法之外其他方法还包括判定表驱动分析方法、正交实验设计方法、功能图分析方法等

D(O)k$Z+@j"A*|0

 

;}[ZGEc BB1I0

TAG:

小不点蜗牛的个人空间 引用 删除 小不点蜗牛   /   2010-03-02 19:37:12
赞一个
 

评分:0

我来说两句

Open Toolbar