测试用例设计——等价类划分法

一、分析问题
如果我们需要对下面的这个两位数加法器设计测试用例,在测试了1+1,1+2,(-1)+1和(-1)+2之后,是否有必要测试1+3,1+4 ,1+(-3)和1+(-4)呢?
如果不对两位数加法器程序进行穷举测试,我们能否放心的认为其他所有的参数组合都是正确的呢?
在这里插入图片描述
可想而知,我们不可能输入这么多的组合进行测试。那么,如果不可能输入这些组合进行测试,是否会担心会遗漏测试中会存在bug呢?

等价类是建立在这种思想之上——即我们不可能进行穷举测试,那么我们就必须对输入进行分类。我们知道程序是通过数据结构和算法来实现的,计算机按照算法来运行程序,这种运行是稳定的,不会因为我们的输入而导致计算机处理不稳定,即我们输入某种组合,即使输入成千上万次,也是得到同一结果。输入用同一数据结构表示的数据是稳定的,在某值域范围内,程序处理方法是相同的。如果输入不在同一值域,则不能称为同一类。实践证明,这种假设是成立的,所以等价类划分法也是有效的。

等价类划分法是一种最常用、也是最重要的黑盒测试方法,它将不能穷举的测试过程进行合理分类,从而保证设计出来的测试用例具有完整性和代表性。

二、等价类划分
等价类划分是把所有可能的输入数据,即程序的输入域划分成若干部分(子集),然后从每一个子集中选取少数具有代表性的数据作为测试用例。测试某等价类的代表值就等于对这一类其它值的测试。因此,可以把全部输入数据合理划分为若干等价类,在每一个等价类中取一个数据作为测试的输入条件,就可以用少量代表性的测试数据,取得较好的测试结果。

如何划分?——先从程序的规格说明书中找出各个输入条件,再为每个输入条件划分两个或多个等价类,形成若干个互不相交的子集。

三、等价类划分步骤
以两位数加法器为例:
1、划分等价类(依据是需求)
有效数据等价类:由那些对程序的需求说明中有意义的、合理的输入数据所构成的集合
无效数据等价类:有那些不合理的或无意义的输入数据所构成的集合
在这里插入图片描述
2、建立等价类表
在这里插入图片描述
3、设计测试用例
在设计测试用例时,应同时考虑有效等价类和无效等价类测试用例的设计。
根据已列出的等价类表可确定测试用例,具体过程如下:
(1)首先为等价类表中的每一个等价类分别规定一个唯一的编号。
(2)设计一个新的测试用例,使它能够尽量覆盖尚未覆盖的有效等价类。重复这个步骤,直到所有的有效等价类均被测试用例所覆盖。
(3)设计一个新的测试用例,使它仅覆盖一个尚未覆盖的无效等价类。重复这一步骤,直到所有的无效等价类均被测试用例所覆盖。
在这里插入图片描述
四、实例
某工厂2019年公开招工,规定报名者年龄应在16周岁至36周岁之间,出生年月规定日期由6位数字组成,前4位表示年份,后2位表示月份。出生年月不在上述范围内,将拒绝接受,并显示“年龄不合格”等出错信息。

1、根据程序要求划分等价类

出生年份:4位整数,值的有效范围是1983-2003
出生月份:2位整数,值的有效范围是1-12

2、建立等价类表
在这里插入图片描述
3、设计测试用例
在这里插入图片描述

  • 22
    点赞
  • 167
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
测试用例设计方法是测试过程中非常重要的一环,其中等价类与场景法是常用的两种方法。 等价类法是一种将输入和输出值划分为有效和无效类的测试方法。在这种方法中,输入和输出值分成若干个等价类,每个等价类代表一组具有相同特征和行为的输入或输出值。然后从每个等价类中选择一个测试用例,以确保测试覆盖了每个等价类。 例如,考虑一个要测试的登录功能,用户名和密码是输入参数。假设用户名必须是5-10个字符之间,密码必须是6-12个字符之间。我们可以将输入值划分为以下等价类: - 有效用户名:5-10个字符之间 - 无效用户名:不是5-10个字符之间 - 有效密码:6-12个字符之间 - 无效密码:不是6-12个字符之间 然后从每个等价类中选择一个测试用例,以确保测试覆盖了每个等价类。 场景法是一种基于实际场景设计测试用例的方法。在这种方法中,测试用例是基于产品或应用程序的实际使用场景设计的。这种方法强调对产品或应用程序的实际使用进行分析,以便发现可能存在的问题。 例如,考虑一个要测试的在线购物网站。场景法可能涉及以下测试用例: - 用户添加商品到购物车并检查购物车中的商品 - 用户选择结账并填写收货地址和付款方式 - 用户在订单页面检查订单详细信息 场景法可以帮助测试人员更好地理解产品或应用程序的实际使用,以便设计更准确、全面的测试用例。 总之,等价类与场景法是测试用例设计中常用的两种方法,它们可以帮助测试人员设计更准确、全面的测试用例,以确保产品或应用程序的质量和可靠性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值