测试用例的设计方法(全):等价类划分方法

 .方法简介


1.定义
  是把所有可能的输入数据,即程序的输入域划分成若干部分(子集),然后从每一个子集中选取少数具有代表性的数据作为测试用例。该方法是一种重要的,常用的黑盒测试用例设计方法。
   

2.划分等价类:
  等价类是指某个输入域的子集合。在该子集合中,各个输入数据对于揭露程序中的错误都是等效的,并合理地假定:测试某等价类的代表值就等于对这一类其它值的测试,因此,可以把全部输入数据合理划分为若干等价类,在每一个等价类中取一个数据作为测试的输入条件就可以用少量代表性的测试数据取得较好的测试结果。等价类划分可有两种不同的情况:有效等价类和无效等价类。
  1)有效等价类
    是指对于程序的规格说明来说是合理的、有意义的输入数据构成的集合。利用有效等价类可检验程序是否实现了规格说明中所规定的功能和性能。
  2)无效等价类
    与有效等价类的定义恰巧相反。无效等价类指对程序的规格说明是不合理的或无意义的输入数据所构成的集合。对于具体的问题,无效等价类至少应有一个,也可能有多个。
  设计测试用例时,要同时考虑这两种等价类。因为软件不仅要能接收合理的数据,也要能经受意外的考验,这样的测试才能确保软件具有更高的可靠性。
  

3.划分等价类的标准:
  1)完备测试、避免冗余;
  2)
划分等价类重要的是:集合的划分,划分为互不相交的一组子集,而子集的并是整个集合;
  3)
并是整个集合:完备性;
  4)
子集互不相交:保证一种形式的无冗余性;
  5)
同一类中标识(选择)一个测试用例,同一等价类中,往往处理相同,相同处理映射到"相同的执行路径"

4.划分等价类的方法
  1)在输入条件规定了取值范围或值的个数的情况下,则可以确立一个有效等价类和两个无效等价类。如:输入值是学生成绩,范围是0100

2)在输入条件规定了输入值的集合或者规定了"必须如何"的条件的情况下,可确立一个有效等价类和一个无效等价类;
  3)在输入条件是一个布尔量的情况下,可确定一个有效等价类和一个无效等价类。
  4)在规定了输入数据的一组值(假定n个),并且程序要对每一个输入值分别处理的情况下,可确立n个有效等价类和一个无效等价类。
    例:输入条件说明学历可为:专科、本科、硕士、博士四种之一,则分别取这四种这四个值作为四个有效等价类,另外把四种学历之外的任何学历作为无效等价类。
  5)在规定了输入数据必须遵守的规则的情况下,可确立一个有效等价类(符合规则)和若干个无效等价类(从不同角度违反规则);
  6)在确知已划分的等价类中各元素在程序处理中的方式不同的情况下,则应再将该等价类进一步的划分为更小的等价类。
 
5.设计测试用例
  在确立了等价类后,可建立等价类表,列出所有划分出的等价类输入条件:有效等价类、无效等价类,然后从划分出的等价类中按以下三个原则设计测试用例:
  1)为每一个等价类规定一个唯一的编号;
  2)设计一个新的测试用例,使其尽可能多地覆盖尚未被覆盖地有效等价类,重复这一步,直到所有的有效等价类都被覆盖为止;
  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位表示月。现用等价类划分法设计测试用例,来测试程序的"日期检查功能"。
  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           1912616
  强一般等价类测试用例同弱一般等价类测试用例
  注:弱--有单缺陷假设;健壮--考虑了无效值
 
  (
)弱健壮等价类测试
  用例ID   月份  日期              预期输出
  WR1      6      15    1912      1912616
  WR2     -1     15    1912      月份不在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)      枪管(25)          销售额     佣金
    1               5             5                5                  500        50
    2              15           15              15                 1500       175
    3              25           25              25                 2500       360

根据输出域选择输入值,使落在输出域等价类内,可以结合弱健壮测试用例结合。

  • 0
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
等价类划分法是一种常用的测试用例设计方法,它将系统的输入域划分为等价类,然后从每个等价类中选择测试用例。这样可以最大程度地覆盖输入空间,并减少冗余的测试用例。 以下是一个简单的例子,以帮助理解等价类划分法的应用: 假设我们要测试一个登录功能,其中用户名和密码是必填项,且用户名只能包含字母和数字,密码长度必须在6到12个字符之间。 根据等价类划分法,我们可以将输入域划分为以下等价类: 1. 用户名为空 2. 密码为空 3. 用户名包含非法字符(如特殊符号) 4. 密码长度小于6个字符 5. 密码长度大于12个字符 6. 用户名和密码符合要求(合法的输入) 接下来,我们从每个等价类中选择一个测试用例: 1. 用户名为空: - 输入:用户名为空,密码为有效值 - 预期结果:登录失败,提示用户名不能为空 2. 密码为空: - 输入:用户名为有效值,密码为空 - 预期结果:登录失败,提示密码不能为空 3. 用户名包含非法字符: - 输入:用户名包含特殊字符,密码为有效值 - 预期结果:登录失败,提示用户名包含非法字符 4. 密码长度小于6个字符: - 输入:用户名为有效值,密码长度小于6个字符 - 预期结果:登录失败,提示密码长度不能小于6个字符 5. 密码长度大于12个字符: - 输入:用户名为有效值,密码长度大于12个字符 - 预期结果:登录失败,提示密码长度不能大于12个字符 6. 用户名和密码符合要求: - 输入:用户名和密码都符合要求的合法值 - 预期结果:登录成功 通过以上的测试用例,我们可以覆盖到所有的等价类,并验证系统对各种情况的处理是否正确。 当然,实际应用中可能还有更多的等价类,需要根据具体情况进行划分和选择。这里只是一个简单的示例,希望对你有所帮助。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

度假的小鱼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值