测试用例设计

一、测试用例概述

  1. 什么是测试用例:其实就是在做测试工作时,把需要输入的数据,以及执行的操作步骤,以及预期的执行结果按照一定的格式用文字描述出来。

  2. 测试用例的好处:可以理清楚思路,避免测试遗漏;还是可以随时跟踪测试进度,看到测试用例执行了多少,还剩下多少,进度一目了然;还可以当作重复测试时的重要参考;当然在其他的项目中还可以将其利用起来,是非常珍贵的资料。

  3. 测试用例的格式

  1. 简化版测试用例格式

二、测试用例设计方法

  1. 等价类分析法:把所有可能的输入数据,即程序的输入域划分成若干部分(子集),然后从每一个子集中选取少数具有代表性的数据作为测试用例。比如:需求文档要求邮箱长度为6~18个字符,那么在测试6~18字符长度的邮箱时,只需要选取其中一个进行测试即可,其代表符合需求的测试用例。假设这里选择的是7个字符,那么就不用再选取8、9、10、11等长度的字符进行测试了,因为它们都是属于6~18个字符长度区间的一类,意味着选择7和选择8、9、10个字符长度其实是等价的。
  2. 有效等价类:对程序的规格说明来说是合理的、有意义的输入数据构成的集合。利用有效等价类可检验程序是否实现了规格说明书中所规定功能和性能。
  3. 无效等价类:无效等价类与有效等价类相反。无效等价类指定对程序规格说明书是不合理的或者无意义的输入数据构成的集合。对于具体的问题,无效等价类至少应有一个,也可能有多个。设计测试用例是要同时考虑这两种等价类。因为软件不仅要能接收合理的数据数据,也要能经受意外的考验,这样的测试才能确保软件具有更高的可靠性。
  1. 边界值分析法:就是对输入和输出的边界值进行测试的黑盒测试方法。通常边界值分析法是作为对等价类分析法的补充,这种情况下,其测试用例来自等价类的边界。

    • 边界值分析不是从某个等价类中随便挑一个作为代表,而是使这个等价类的每个边界都要作为测试条件。
    • 边界值分析不仅要考虑输入条件,还要考虑输出空间产生的测试情况。
    • 使用边界值分析法设计测试用例,应当选取正好等于,刚刚大于或者刚刚小于边界的值作为测试数据,而不是选取等价类中的典型值或任意值作为测试数据。
  2. 边界值分析法选择测试用例的原则

    • 如果输入条件规定了值的范围,则应取刚达到这个范围的边界值,以及刚刚超越这个范围边界的值作为测试输入数据。例如程序的规格说明书中规定:“重要在10公斤至50公斤范围内的邮件,其邮费计算公式为...”。作为测试用例,应该选取10及50,还应该选取10.01、49.99、9.99和50.01等。
    • 如果输入条件规定了值的个数,则用最大的个数和最小的个数,比最大的个数大一,比最小的个数小一的数作为测试数据。比如,一个输入文件应该包括1~255个记录,则测试用例可取1和255,还应该取0及256等。
    • 如果程序使用了一个内部数据结果,则应当选择这个内部数据结果的边界上的值作为测试用例。
  3. 场景分析法:结合用户使用的真实场景进行真实模拟,从而进行测试。

  4. 错误猜测法:基于经验和直觉推断程序中所有可能存在的错位,从而针对性的设计测试用例的方法。

    • 比如:输入数据和输出数据为0的情况;输入表格为空格或输入表格只有一行。这些都容易发生错误的情况。可选择这些情况的例子作为测试用例。
    • 比如:测试一个对线性表(比如数组)进行排序的程序,可推测列出以下几项需要特殊情况。输入的线性表为空;表中只含有一个元素;输入表中所有元素已排好顺序;输入表已按逆序排好;输入表中部分或者全部元素相同。
  5. 因果图法:这是一种利用图解分析输入各种可能组合情况,从而设计测试用例的方法。

    • 首先,分析软件规格说明书中,哪些是原因(即输入条件的等价类),哪些是结果(即输出条件),并给每个原因和结果赋予一个标识符。
    • 然后,分析软件规格说明书中的语义,找出原因与结果之间,原因与原因之间的对应关系,根据这些关系,画出因果图。
    • 由于语法或环境限制,有些原因与原因之间,原因与结果之间的组合情况不可能出现,为表明这些特殊情况,在因果图上用一些记号表明约束或限制条件。
    • 把因果图转换为判定表。
    • 把判定表的每一项拿出来作为依据,设计测试用例。
  6. 设计测试用例的综合策略

    • 在任何情况下都必须使用边界值分析法,经验表明用这种方法设计出的测试用例发现程序的错误最多。
    • 必要时用等价类分析法补充一些测试用例。
    • 用错误推断发补充一些测试用例。
    • 对照程序逻辑,检查已经设计出的测试用例的逻辑覆盖程度,如果没有达到要求的覆盖标准,应当补充足够的测试用例。
    • 如果程序的功能说明中含有输入条件的组合情况,那么一开始就可选用因果图法。

三、测试用例优先级

  1. 为什么要分优先级:根据二八定律,全世界20%的人占据约80%的财富,80%的人占据约20%的财富。而在测试工作中,也同样如此,意味着20%的测试用例可以发现80%的重要bug。那么在做测试工作时,需要关注发现80%重要bug的这20%测试用例,并将其设置为高优先级,其结果就是可以发现更多的重要bug,提高了效率,节省了成本。

  2. 测试优先级分类:高优先级、中优先级、低优先级

    • 高优先级:对应核心功能、业务流的主干流程、正常完成这个逻辑的流程

    • 中优先级:一般功能,非核心功能、分支流程、异常流程

    • 低优先级:界面文案、产品易用性、视觉表现等

  3. 如何划分优先级

    • 用例执行不通过,将导致所有用户无法正常使用,那就设置成高优先级

    • 用例执行不通过,将导致部分用户无法正常使用,那就设置成中优先级

    • 用例执行不通过,虽然不会影响用户使用,但用户体验会下降,那就设置成低优先级

四、测试用例管理

  1. 为什么要管理测试用例:因为测试用例会被多次执行,在不同的测试阶段,测试用例会被重复执行;其次,因为需求的不断变更,也会让测试用例实时修正,所以测试用例会需要支持更新。那么管理测试用例就能有效的避免重复性工作,有效提高测试执行效率,避免无效的测试工作。

  2. 多人协作

    • 同步测试用例:测试用例的执行,以及测试用例的更新,需要多人协作同步,否则测试用例更新后,可能会导致部分人员没有发现,导致重复遗漏测试,或者重复执行等问题。

    • 同步测试结果:测试过的用例需要共享,让大家都能看到测试结果,避免重复执行相同测试用例

  3. 管理工具

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

推荐阅读更多精彩内容

  • 一、常用黑盒测试用例设计方法 等价类划分法 边界值分析法 判定表法 因果图法 状态迁移图法 流程分析法 正交试验法...
    hollow_s阅读 1,084评论 0 1
  • 一、为什么要使用测试用例 1、理清思路,避免遗漏 如果我们测试的项目大而复杂,我们可以把项目功能细分,根据每一个功...
    小喜_ww阅读 2,353评论 1 24
  • 测试用例的设计是测试实现阶段的核心工作,也是指导如何执行测试的基础。 测试用例(Test Case)是为某个特殊目...
    倔强的潇洒小姐阅读 8,786评论 1 21
  • 1等价类划分方法 1.1定义 是把所有可能的输入数据,即程序的输入域划分成若干部分(子集),然后从每一个子集中选取...
    wildwolf_f34c阅读 809评论 0 0
  • 我是演说家:王龙玺 我想我们很多人都听过这句话:生活不只是眼前的苟且,还有诗和远方。但是很少有人知道这句话其实是一...
    把孩子培养成幸福的普通人阅读 1,286评论 1 4