黑盒测试方法---等价类划分

等价类划分方法

一.方法简介

 

1.定义
   是把所有可能的输入数据,即程序的输入域划分成若干部分(子集),然后从每一个子集中选取少数具有代表性的数据作为测试用例。该方法是一种重要的,常用的黑盒测试用例设计方法。
   
2.划分等价类:
   等价类是指某个输入域的子集合。在该子集合中,各个输入数据对于揭露程序中的错误都是等效的,并合理地假定:测试某等价类的代表值就等于对这一类其它值的测试,因此,可以把全部输入数据合理划分为若干等价类,在每一个等价类中取一个数据作为测试的输入条件就可以用少量代表性的测试数据取得较好的测试结果。等价类划分可有两种不同的情况:有效等价类和无效等价类。
      1) 有效等价类:是指对于程序的规格说明来说是合理的、有意义的输入数据构成的集合。利用有效等价类可检验程序是否实现了规格说明中所规定的功能和性能。 

  2) 无效等价类:与有效等价类的定义恰巧相反。无效等价类指对程序的规格说明是不合理的或无意义的输入数据所构成的集合。对于具体的问题,无效等价类至少应有一个,也可能有多个。
     设计测试用例时,要同时考虑这两种等价类。因为软件不仅要能接收合理的数据,也要能经受意外的考验,这样的测试才能确保软件具有更高的可靠性。
  
3.划分等价类的标准
     1) 完备测试、避免冗余;
     2) 划分等价类重要的是:集合的划分,划分为互不相交的一组子集,而子集的并是整个集合;
     3) 并是整个集合:完备性;
     4) 子集互不相交:保证一种形式的无冗余性;
     5) 同一类中标识(选择)一个测试用例,同一等价类中,往往处理相同,相同处理映射到"相同的执行路径"。

 

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

2) 在输入条件规定了输入值的集合或者规定了"必须如何"的条件的情况下,可确立一个有效等价类和一个无效等价类;
     3) 在输入条件是一个布尔量的情况下,可确定一个有效等价类和一个无效等价类。
     4) 在规定了输入数据的一组值(假定n个),并且程序要对每一个输入值分别处理的情况下,可确立n个有效等价类和一个无效等价类。
      例:输入条件说明学历可为:专科、本科、硕士、博士四种之一,则分别取这四种这四个值作为四个有效等价类,另外把四种学历之外的任何学历作为无效等价类。
     5) 在规定了输入数据必须遵守的规则的情况下,可确立一个有效等价类(符合规则)和若干个无效等价类(从不同角度违反规则);
     6) 在确知已划分的等价类中各元素在程序处理中的方式不同的情况下,则应再将该等价类进一步的划分为更小的等价类。 

5.设计测试用例
  在确立了等价类后,可建立等价类表,列出所有划分出的等价类输入条件:有效等价类、无效等价类,然后从划分出的等价类中按以下三个原则设计测试用例:
     1) 为每一个等价类规定一个唯一的编号;
     2) 设计一个新的测试用例,使其尽可能多地覆盖尚未被覆盖地有效等价类,重复这一步,直到所有的有效等价类都被覆盖为止;
     3) 设计一个新的测试用例,使其仅覆盖一个尚未被覆盖的无效等价类,重复这一步,直到所有的无效等价类都被覆盖为止。

 

6.等价类的特点
  等价类数据的共同特点有以下几点:
  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 ,函数的输出为输入日期后一天的日期。 例如,输入为 2006年3月 7日,则函数的输出为 2006年3月8日 。要求输入变量 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年6月16日
  强一般等价类测试用例同弱一般等价类测试用例
  注:弱--有单缺陷假设;健壮--考虑了无效值 
 
  (一)弱健壮等价类测试
  用例ID   月份  日期    年          预期输出
  WR1      6      15    1912      1912年6月16日
  WR2     -1     15    1912      月份不在1~12中
  WR3     13     15    1912      月份不在1~12中
  WR4      6      -1    1912      日期不在1~31中
  WR5      6      32    1912      日期不在1~31中
  WR6      6      15    1811      年份不在1812~2012中
  WR7      6      15    2013      年份不在1812~2012中

 

(二)强健壮等价类测试
  用例ID   月份    日期      年          预期输出
  SR1       -1      15       1912      月份不在1~12中
  SR2        6      -1        1912      日期不在1~31中
  SR3        6      15       1811      年份不在1812~2012中
  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
根据输出域选择输入值,使落在输出域等价类内,可以结合弱健壮测试用例结合。

 

 

 

 

原文:http://luyongxin88.blog.163.com/blog/static/925580720108243853398/ 

时间: 2024-10-28 13:57:06

黑盒测试方法---等价类划分的相关文章

软件的黑盒测试方法解析与优化

摘要:软件测试是保证软件质量的重要手段,尤其是自动化测试可以提高测试效率,降低成本.黑盒测试是针对非计算机专业人员进行的测试,为了确保测试质量,必须总结出一套适合业务人员使用的测试方法.文章从实际需要出发,对黑盒测试方法进行了分析,并提出了优化方案.希望可以降低软件测试成本,提高测试效率,对软件测试人员的工作有所帮助. 关键词:软件测试:黑盒测试:测试策略 引言 黑盒测试是目前软件业界采用的主流测试方法,这种方法以业务应用为驱动,通过控制输入及其对业务的预期影响来判断代码实现是否正确. 实践证明

黑盒测试方法---边界值分析

边界值分析法 一.方法简介 1.定义:边界值分析法就是对输入或输出的边界值进行测试的一种黑盒测试方法.通常边界值分析法是作为对等价类划分法的补充,这种情况下,其测试用例来自等价类的边界.   2.与等价划分的区别    1)边界值分析不是从某等价类中随便挑一个作为代表,而是使这个等价类的每个边界都要作为测试条件.    2)边界值分析不仅考虑输入条件,还要考虑输出空间产生的测试情况.   3.边界值分析方法的考虑:    长期的测试工作经验告诉我们,大量的错误是发生在输入或输出范围的边界上,而不

关于统一等价类划分的术语和过程

等价类划分是很重要的软件测试设计技术之一.重要到几乎每一个测试员都要用到这项技术,他们中的一些人甚至还没有意识到被这他们称为 "常识"的实际上是一项正式的技术.但不知何故,作为一个测试团队,我们就等价类划分的过程这一点上似乎无法达成一致意见.甚至连它的术语都意见不一.划分和类是同一回事吗?等级划分的有效和无效意味着什么?当我们了解什么是类之后,又该如何把它运用到测试用例中呢?我们需要输出划分吗?在这篇文章里,我会提出一个关于统一等价类划分的术语的建议,并努力找出一个单一的方法来得到测试

系统测试用例设计之等价类划分

什么是等价类? 等价类:一类数据具有等价性. 从正向来说,它们具有相同的功能. 从逆向来说,它们暴露相同的错误. 有效数据->有效等价类 无效数据->无效等价类 如何划分等价类? 可以根据测试数据背后的处理信息,分析数据有无共同特点.将含有共同特点的数据划为一个等价类. 等价类划分的原则 1.在输入条件规定了取值范围或取值的个数的情况下,可以确立一个有效等价类和两个无效等价类. 2.在输入条件规定了输入值的集合或者规定了"必须如何"的条件的情况下,可以确立一个有效等价类和一

好的黑盒测试方法应该是什么?

很多测试人员会询问, 是否有一种测试方法, 可以很系统化地, 来开立所有测试个案. 我也很期待有这种东西, 可惜一直没有看到, 不管哪种黑盒测试方法, 都有它的优点和缺点. 更重要的是黑盒测试有个重大的致命点, 它是完全依赖测试人员的经验. 如果测试人员的产品领域知识, 以及产品所处的系统知识丰富, 就能开出更好的测试个案. 例如: 等价分析法(Equivalence Class). 他要求先找出等价区域 (Partition or equivalence class),  然后对每个区域开出一

黑盒测试方法大对决

软件测试的方法有很多种, 其中黑盒测试方法被使用最多, 主要的原因是容易上手, 进入门坎不高. 所以很多测试人员会使用这种方法. 可是很多人对于何时该使用却不是很清楚, 因此让我们来做个简单的比较吧 1. ECT (Equivalence Class Testing) a. 说明: 将受测软件的输入数据, 切成好几个分割(partitions), 对于每个分割, 将会有测试个案去涵盖它 b. 适用时机 比较小的功能, 或是单一 API. 或是画面某个 input control c. parti

浅说《测试用例》----给测试新手的

     在此之前我搜集一些关于测试用例的知识,后来在我们的QQ群里专门定了一期讨论,来探讨测试用例,毕竟这是一个很大的话题,很难做到面面俱到,但我会尽量全面,用通俗的语言来说测试用例. --------------------------------------------------------------------------------------- 注:我们这里要说的测试用例指功能测试用例. 一.什么是测试用例?      测试用例是为某个特殊目标而编制的一组测试输入.执行条件以及预

等价类结和判定表的软件测试方法应用

摘要:软件测试的类型通常分为白盒测试和黑盒测试,其中基于等价类的划分法与基于判定表的测试法都是较为典型和实用的黑盒测试技术方法.在实际工作中,为了使测试用例的覆盖更加全面,测试目的更加明确,通常不仅仅局限于某一种测试手段.针对等价类和判定表这两种方法各自的特点,可以将两者有机结合,通过对输入条件进行等价类划分,对输出行为进行判定表列举,用综合的手段进行软件测试工作,从而达到使测试用例的设计覆盖全面.条理清晰的目的. 关键词:等价类:判定表:软件测试 1.概述 软件测试的类型一般来说,可以划分为白

从零开始学测试(2)测试方法术语总结

1.白盒测试 a.白盒测试把测试对象看作一个透明的盒子,所以又称为玻璃盒测试. b.它允许测试人员利用程序内部的逻辑结构及有关信息,设计或选择测试用例,对程序所有逻辑路径进行测试. c.通过在不同点检查程序的状态,确定实际的状态是否与预期的状态一致. 假如现在有一辆车,你想知道它能不能跑起来? 按照白盒测试的思想,你需要测试车的发动机.底盘.车身.电气设备是否正常,然后做出这辆车能否跑起来的判断(所以我个人认为,白盒测试你需要熟悉项目所用到的技术框架.编码语言.运行环境.等等系列的问题,这项测试