黑盒测试用例设计方法

1.概述

 

黑盒测试用例设计方法包括等价类划分法、边界值分析法、错误推测法、因果图法、判定表驱动法、正交试验设计法、功能图法等 


2.等价类划分法

 

等价类划分法是把程序的输入域划分成若干部分(子集),然后从每个部分中选取少数代表性数据作为测试用例。每一类的代表性数据在测试中的作用等价于这一类中的其他值。

 

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

·      有效等价类:是指对于程序的规格说明来说是合理的,有意义的输入数据构成的集合.利用有效等价类可检验程序是否实现了规格说明中所规定的功能和性能。

·      无效等价类:与有效等价类的定义恰巧相反。

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

2.   划分等价类的六大原则:

·      在输入条件规定了取值范围或值的个数的情况下,则可以确立一个有效等价类和两个无效等价类.

例:输入值是学生成绩,范围是0100

 

·      在输入条件规定了输入值的集合或者规定了必须如何的条件的情况下,可确立一个有效等价类和一个无效等价类.

·      在输入条件是一个布尔量的情况下,可确定一个有效等价类和一个无效等价类.布尔量是一个二值枚举类型, 一个布尔量具有两种状态: true 和 false 。

·      在规定了输入数据的一组值(假定n个),并且程序要对每一个输入值分别处理的情况下,可确立n个有效等价类和一个无效等价类.

例:输入条件说明输入字符为:中文、英文、阿拉伯文三种之一,则分别取这三种这三个值作为三个有效等价类,另外把三种字符之外的任何字符作为无效等价类。

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

·      在确知已划分的等价类中各元素在程序处理中的方式不同的情况下,则应再将该等价类进一步的划分为更小的等价类

3.   将等价类转化成测试用例:

·         按照[输入条件][有效等价类][无效等价类]建立等价类表,列出所有划分出的等价

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

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

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

 

 

1.     某程序规定:"输入三个整数 a b c分别作为三边的边长构成三角形。通过程序判定所构成的三角形的类型,当此三角形为一般三角形、等腰三角形及等边三角形时,分别作计算 … "。用等价类划分方法为该程序进行测试用例设计。(三角形问题的复杂之处在于输入与输出之间的关系比较复杂。)

分析题目中给出和隐含的对输入条件的要求:

1)整数   2)三个数   3)非零数  4)正数  
5)两边之和大于第三边    6)等腰    7)等边
 
如果 a b c满足条件( 1 ~ 4),则输出下列四种情况之一:
 1)
如果不满足条件(5),则程序输出为 "非三角形 "
 2)
如果三条边相等即满足条件(7),则程序输出为 "等边三角形 "
 3)
如果只有两条边相等、即满足条件(6),则程序输出为 "等腰三角形 "
 4)
如果三条边都不相等,则程序输出为 "一般三角形 "
 
列出等价类表并编号

 

覆盖有效等价类的测试用例:

a      b      c             覆盖等价类号码

3      4      5            1--7

4      4      5            1--7),(8

4      5      5            1--7),(9   

5      4      5            1--7),(10

4      4      4            1--7),(11

覆盖无效等价类的测试用例:

2.    设有一个档案管理系统,要求用户输入以年月表示的日期。假设日期限定在1990年1月~2049年12月,并规定日期由6位数字字符组成,前4位表示年,后2位表示月。现用等价类划分法设计测试用例,来测试程序的"日期检查功能"。(不考虑2月的问题)

1)划分等价类并编号,下表等价类划分的结果

输入等价类

有效等价类

无效等价类

日期的类型及长度

6位数字字符

有非数字字符

少于6位数字字符

多于6位数字字符

年份范围

1990~2049之间

小于1990

大于2049

月份范围

01~12之间

等于00

大于12

2)设计测试用例,以便覆盖所有的有效等价类在表中列出了3个有效等价类,编号分别为①、⑤、⑧,设计的测试用例如下:

测试数据   期望结果     覆盖的有效等价类
200211     
输入有效     、⑤、⑧
3)
为每一个无效等价类设计一个测试用例,设计结果如下:
   
测试数据   期望结果     覆盖的无效等价类
    95June     无效输入         
    20036     
无效输入          
    2001006   
无效输入         
    198912    
无效输入         
    200401    
无效输入         
    200100    
无效输入         
    200113    
无效输入         

3.     NextDate函数包含三个变量:month day year,函数的输出为输入日期后一天的日期。例如,输入为 20063 7日,则函数的输出为 200638。要求输入变量 month day year 均为整数值,并且满足下列条件:
 
1≤month≤12
 
1≤day≤31
 
1920≤year≤2050 
1)
有效等价类为:
    M1
{ 月份:1≤月份≤12}
    D1
{ 日期:1≤日期≤31}
    Y1
{ 年:1812≤≤2012}
2)
若条件 ~中任何一个条件失效,则 NextDate函数都会产生一个输出,指明相应的变量超出取值范围,比如 "month的值不在 1-12范围当中 " 。显然还存在着大量的 year month day 的无效组合, NextDate函数将这些组合作统一的输出: "无效输入日期 " 。其无效等价类为:
    M2
{ 月份:月份<1}
    M3
{ 月份:月份>12}
    D2
{ 日期:日期<1}
    D3
{ 日期:日期>31}
    Y2
{ 年:年<1812}
    Y3
{ 年:年>2012}
 
弱一般等价类测试用例
 
月份    日期                     预期输出
   6       15        1912           1912
616
 
强一般等价类测试用例同弱一般等价类测试用例
 
注:弱--有单缺陷假设;健壮--考虑了无效值
 
  (
)弱健壮等价类测试
 
用例ID   月份  日期            预期输出
  WR1      6      15    1912      1912
616
  WR2     -1     15    191
2      月份不在112
  WR3     13     15    1912     
月份不在112
  WR4      6      -1    1912     
日期不在131
  WR5      6      32    1912     
日期不在131
  WR6      6      15    1811      
年份不在18122012
  WR7      6      15    2013     
年份不在18122012

  ()强健壮等价类测试
    
用例ID   月份    日期              预期输出
    
SR1       -1      15       1912      月份不在112
    
SR2        6      -1        1912      日期不在131
    
SR3        6      15       1811      年份不在18122012
    
SR4       -1      -1       1912      两个无效一个有效
    
SR5        6      -1        1811      两个无效一个有效
    
SR6       -1      15       1811      两个无效一个有效
    
SR7       -1      -1       1811      三个无效

4.     佣金问题等价类测试用例,它是根据佣金函数的输出值域定义等价类,来改进测试用例集合。
输出销售额≤1000    佣金10
1000<
销售额≤1800    佣金=100+(销售额-1000)*15%
销售额>1800             佣金=220+(销售额-1800)*20%
测试用例         枪机(45)   枪托(30)     枪管<

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值