【测试二】黑盒测试的测试用例设计方法

黑盒测试的测试用例设计方法:
1. 等价类划分
2. 边界值分析
3. 错误推测法
4. 因果图

一、等价类划分

定义:等价类划分设计方法是把所有可能的输入数据,即程序的输入域划分成若干部分(子集),然后从每一个子集中选取少量具有代表性的数据作为测试用例。
等价类是指某个输入域的子集合,在该子集合中,各个输入数据对于揭露程序中的错误都是等效的(可合理假设:测试某等价类的代表值就等于对这一类其他值的测试)。

确定等价类的原则:

  1. 如果输入条件规定了取值范围,或者是值得个数,则可以确立一个有效等价类和两个无效等价类。
  • 例如:序号值可以从1到999。
    一个有效等价类:1<=序号值<=999
    两个无效等价类:序号值<1,序号值>999
  1. 如果输入条件规定了输入值的集合,或者是规定了“必须如何”的条件,可确立一个有效等价类和一个无效等价类。
  • 例如:在C语言中对变量标识符规定为“以字母打头的”。
    所有字母打头的构成有效等价类
    不在此集合内的为无效等价类
  1. 如果输入条件是布尔量,确立一个有效等价类和一个无效等价类
  • 例如:0和1,是和非
  1. 如果规定了输入数据是一组值,而且程序要对每个输入值分别进行处理,这时可为每一个输入值确立一个有效等价类,此外再针对这组值确立一个无效等价类,它应是所有不允许输入值的集合。
  • 例如:在规定教师分房方案中对教授、副教授、讲师和助教分别计算分数,然后做处理。
    四个有效等价类为:教授、副教授、讲师、助教
    一个无效等价类,即所有不符合以上四个的集合
  1. 如果规定了输入数据必须遵守的规则,则可以确立一个有效等价类(符合的),和若干无效等价类(以不同角度违反规则)。
  • 例如:在C语言中,规定“一个语句必须以分号‘;’结束”。
    一个有效等价类:以“;”结束
    若干无效等价类:以“;,.”等符号结束
  1. 如果确定以划分的等价类中各元素在程序中的处理方式不同,则应将此等价类进一步划分为更小的等价类。

每一个无效等价类至少要用一个测试用例,否则就有可能漏掉某一类错误,但允许若干个有效等价类合用同一个测试用例,以便进一步减少测试次数。

确立测试用例原则:

  1. 为每一个等价类规定一个唯一的编号。
  2. 设计一个新的测试用例,使其尽可能的覆盖尚未被覆盖的有效等价类,重复,直至覆盖所有的有效等价类。
  3. 设计一个新的测试用例,使其仅覆盖尚未被覆盖的无效等价类,重复,直至覆盖所有无效等价类。

二、边界值分析

采用边界值分析法来选择测试用例,可使得北侧程序能在边界值及其附近运行,从而更有效的地暴露程序中潜藏的错误。

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

基于边界值分析法选择测试用例原则:

  1. 如果输入条件规定了值得范围,应取刚达到这个范围的边界值,以及刚刚超过这个范围边界的值作为测试输入的数据。
  2. 如果输入条件规定了值的个数,应取最大个数、最小个数、比最小个数少一、比最大个数多以的数作为测试输入的数据。
  3. 如果程序的规格说明给出的输入域或者输出域是有序集合,则应选取集合的第一个元素和最后一个元素作为测试用例数据。
  4. 如果程序中使用了一个内部数据结构,应当选择这个内部数据结构边界上的值作为测试用例。

三、错误推测法

错误推测法发是根据经验和直觉推测程序中所有可能存在的各种错误,从而有针对性地设计测试用例的方法。

四、因果图法

因果图法是一种适合于描述对于多种条件的组合,相应产生多个动作的形式的测试用例设计方法。

利用因果图生成测试用例的基本步骤:

  1. 分析软件规格说明描述中哪些是原因,哪些是结果,并给每个原因和结果赋予一个标识符。
  2. 分析软件规格说明描述的语言,找出原因和结果之间,原因和原因之间的关系,根据这些关系,画出因果图。
  3. 在因果图上用一些记号表明约束或限制条件。
  4. 把因果图转换为判定表。
  5. 把判定表的每一列拿出来作为数据,设计测试用例。

因果图法适用于被测程序具有多种输入条件,程序的输出有依赖于输入条件的各种组合的情况,因果图一种简化了的逻辑图,它能直观地表明程序输入条件和输出动作之间的相互关系。

例:第一列字符必须是A或B,第二列字符必须是一个数字,在此情况下进行文件的修改,但如果第一列字符不正确,则给出信息L;如果第二列字符不是数字,则给出信息M。

解:

  1. 画出因果关系表和因果图。


    因果图
  1. 根据因果图建立判定表。
    按条件的各种组合情况产生对应的动作。原因1和原因2不能同时成立,故可排除这种情况。
    从判定表可设计出测试用例:6个测试用例是所需的数据。
判定表

五、测试方法的选择

  • 在任何情况下都应该使用边界值分析方法
  • 必要时用等价类划分法补充测试方法
  • 必要时再用错误推测法补充测试方法
  • 对照程序逻辑,检查已经设计出的测试方案
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,482评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,377评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,762评论 0 342
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,273评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,289评论 5 373
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,046评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,351评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,988评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,476评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,948评论 2 324
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,064评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,712评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,261评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,264评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,486评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,511评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,802评论 2 345

推荐阅读更多精彩内容

  • 等价类划分方法: 一.方法简介 1.定义是把所有可能的输入数据,即程序的输入域划分成若干部分(子集),然后从每一个...
    繼續hug阅读 5,579评论 1 16
  • 1.测试与软件模型 软件开发生命周期模型指的是软件开发全过程、活动和任务的结构性框架。软件项目的开发包括:需求、设...
    Mr希灵阅读 21,938评论 7 278
  • 1.测试与软件模型 软件开发生命周期模型指的是软件开发全过程、活动和任务的结构性框架。软件项目的开发包括:需求、设...
    宇文臭臭阅读 6,713评论 5 100
  • 测试用例的设计是测试实现阶段的核心工作,也是指导如何执行测试的基础。 测试用例(Test Case)是为某个特殊目...
    倔强的潇洒小姐阅读 8,753评论 1 21
  • 相关文章: 《再说说APP测试设计-1》《再说APP测试设计-2》《关于ad hoc test》《干了这碗蛋炒饭 ...
    慧众rodman阅读 3,187评论 1 34