• 0
  • 0
分享
  • 测试工程师必备:设计方法编写测试用例~思路分析——软件测试圈
  • 恬恬圈 2021-12-06 13:59:49 字数 2537 阅读 1036 收藏 0

一四年我在YX公司带测试团队,一个用例评审的会议上,一不小心超常发挥,结果卡在了一个用例设计方法上,印象非常深刻,当时的业务场景是支付方式的选择和优惠方案。

在后来的工作中,也曾几次遇到需要选择合理的设计方法来写用例,不过每次在网上都是搜索了半天,也找不到令人满意的答案。很多简单的问题被复杂化,然后给出的解题思路更是令人百思不得其解。

网络资源下,任何一个问题都不缺答案,更多的时候缺的是个让人一目了然的答案。

测试前准备

作为一个测试人员,软件测试的流程首先是要非常熟悉的,何时何地都能脱口而出,避免一切翻车的可能。需要注意的是流程没有唯一答案,具体由项目决定。所以给出的只是一个还算通用的参考流程。

总结一下:在测试流程中,有6个部分,其中3个部分涉及到了用例,可见写好用例的重要性。

所以,结合这些年吃过的亏,我来给大家缕缕,如何快速的get到测试用例的设计方法。

5种常见的测试用例设计方法

一、等价类划分

1)概念

某个输入域的集合,在这个集合中每个输入条件都是等效的,如果其中一个的输入不能导致问题发生,那么集合中其它输入条件进行测试也不太可能发现错误。

关于等价类划分的两个重要概念:

有效等价类:有效等价类是程序规格说明有意义,合理的输入数据。

比如用正确的用户名和密码来登录系统就是有效等价类。

无效等价类:无效等价类是程序规格说明无意义,不合理的输入数据。

比如用不存在的用户名和密码来登录系统就是无效的等价类。

2)等价类法设计测试用例的步骤

为每个输入划分等价类,得到等价类表,为每个等价类规定一个唯一编号

设计一个测试用例,使其尽可能多的覆盖所有尚未覆盖的有效等价类。重复这一步骤,使得有效等价类均被测试用例所覆盖设计一个测试用例,使其只覆盖一个无效等价类。重复这一步骤使得所有无效等价类均被覆盖。

假设上面的文字你都没有看懂,那么做个题目就懂啦。

3)案例来了

程序规定:输入三个正整数作为三边的边长构成三角形。请用等价类方法设计测试用例分别判断输入3个整数时的三角形为一般三角形、等腰三角形、等边三角形时情况:

提示:

需求提取:

1、三条边需求:整数/3个数/非零数/正数

2、一般三角形的要求:二边之和大于第三边

3、等腰三角形:二二边相等且满足二边之和大于第三边

4、等边三角形:三条边相等

答案解析:符合的需求条件的即是有效等价类,比如,等腰三角形,那么要求至少有两条边相等,所有有效等价类就包括a=bb=ca=c,那么不符合条件的就是无效等价类包括a!=bb!=ca!=c

二、边界值分析

1)概念

边界值分析方法的理论基础是假定大多数的错误是发生在各种输入条件的边界上,如果在边界附近的取值不会导致程序出错,那么其它的取值导致程序错误的可能性也很小。

2)边界值分析法设计用例的步骤

分析输入参数的类型:从测试规格中分析得到输入参数类型

等价类划分(可选):对于输入等价类划分方法进行等价类的划分

确定边界:运用域测试分析方法确定域范围的边界(上点、离点与内点)

相关性分析(可选):如果存在多个输入域,则需要运用因果图、判定表方法这些输入域边界值的组合情况进行进一步分析

形成测试项:选择这些上点、离点与内点或者这些点的组合形成测试项

3)案例来了

假设存在以下的测试场景,某个网站的登录页面:

1、用户名:1—20个字符,包括1和20,其他不考虑

2、密码:6个数字,其他不考虑

现要求用边界值分析法测试用户名和密码这两个输入框。

边界值分析方法如下:

答案解析:密码这个字段的范围是闭区间【1-20】,用边界值设计用例,那么去找这两个数的左邻右舍+自己,1则是0和1和2,20则是19,20,21。

三、判定表

1)概念

判定表是分析和表达多种输入条件下系统执行不同动作的工具,它可以把复杂的逻辑关系和多种条件组合的情况表达得既具体又明确。

2)判定表法设计用例的步骤

列出所有的条件桩和动作桩

填入条件桩、条件项

填入动作桩、动作项

化简,合并相似规则

将每条规则转化为用例

3)案例来了

假设有以下逻辑:

运用判定表设计用例。

答案解析:判定表的解题思路就是先列出所有条件,然后列出每个条件的取值,最后如上图,一列就是一条用例。

四、正交试验法

1)概念

正交试验设计(Orthogonalexperimentaldesign)是研究多因子多水平的又一种设计方法,它是根据正交性从全面试验中挑选出部分有代表性的点进行试验,这些有代表性的点具备了“均匀分散,齐整可比”的特点。

关于正交试验表的两个重要概念:

1、所有参与试验、影响试验结果的条件称为因子。

2、影响试验因子的取值或输入叫做因子的水平。

如何选择正交表:

1、考虑因子的个数

2、考虑水平的个数

3、考虑正交表的行数

4、取行数最少的一个

2)案例来了

有如下用户登录页面,三个登录条件:用户名、密码、验证码,考虑填写或不填写,用正交表设计测试用例。

参考答案

分析因子数,以及因子水平值:

3因子2状态

经过组合合并之后的对应用例

补充:

答案解析:正交试验法主要在于选取因子数和水平值,将两者结果列出再合并,工作中用的不多,但是合适的业务逻辑下可以选择。

五、流程分析法

1)概念

流程分析法是将软件系统的某个流程看成路径,用路径分析的方法来设计测试用例。根据流程的顺序依次进行组合,使得流程的各个分支都能走到。

2)流程分析法设计用例步骤

1、画出业务流程图

2、设置功能路径优先级

3、确定测试路径

4、选取测试数据

5、构造测试用例

3)案例来了

案例:安装QQ,安装系统之家版QQ。

对应的测试用例

答案解析:看起来非常复杂的流程图和用例,设计的核心其实就两个方向,一个是正常流程,即安装安装向导一直点击【下一步】直到完成。另一个方向则是每个判断条件选择【否】的场景,那么这样的话,就会产生很多条其他分支的用例。

结尾篇

测试用例设计方法不止上面提到的5种,但是工作中遇到的业务场景基本可以通过上述的方法来得到解决。等价类划分和边界分析方法较为简单,很多时候可以结合起来一起用。正交实验表和判定表一般用在需要将多个输入组合起来测试的情况。流程分析法顾名思义就是存在不同分支流程的时候选用。希望上述的方法能够帮助到大家。


文章链接:http://blog.itpub.net/31407649/viewspace-2651777/

  • 【留下美好印记】
    赞赏支持
登录 后发表评论
+ 关注

热门文章

    最新讲堂

      • 推荐阅读
      • 换一换
          • 社区团购迎来大震动,美团优选单飞要做“电商零售”了。10月12日,据美团优选官方公众号发布文章称,其社区团购品牌美团优选将品牌定位调整为“明日达超市”。这一定位与美团闪购、美团买菜的即时零售定位形成互补,也意味着,美团又会直面京东超市、京东到家、天猫超市、饿了么准时达等产品竞争。此前,隶属于美团到家事业群的电商业务团好货已经合并至美团优选。有知情人士分析称,团好货事业部划归美团优选后,有可能为后者扩充sku,或者打造自有品牌,甚至在下沉市场可以与京东到家、猫超等业务形成对抗。实际上,美团创始人王兴一直意图开拓电商零售业务。在今年的第二季度电话会议上,王兴就曾表示,即时零售的商业模式将对零售业产...
            0 0 946
            分享
          • 一、100个真实的用户1、一个账号模拟100虚拟用户同时登录和100账号同时登录区别(1)1个账号100个人用,同时登录;(2)100个人100个账号,同时登录。相同(1)两个都是100人同时登录,具体看项目需求。2、账号来源(1)利用“注册”或“创建”账号接口,创建100个用户;(2)“查询”接口,保存100个账号的账号、密码到一个文件。3、提取100个账号、密码的文件(1)jmeter脚本整体布局线程组(一级)---->请求默认值、请求头、http请求、察看结果树(二级)----->正则表达式、BeanShell 后置处理程序(三级)。HTTP请求默认值:是存放系统通...
            0 0 1386
            分享
          •   WEB渗透测试检查项  1. WEB漏洞类  2. 认证授权类  3. 命令执行类  4. 业务逻辑类  5. 注入类  6. 客户端侧攻击类  7. 信息泄露类  8. 其他作者:乔木滴滴    来源:http://www.51testing.com/html/71/n-7796271.html
            0 0 277
            分享
          •   迪斯尼一直在暗示 Disney Plus 品牌的一些重大变化。最近几天,很多用户在查看自己的电视、平板电脑或手机时发现,这款流媒体应用换上了新标识--标志性的迪士尼蓝色被发光的绿色背景取代。  新标识引起了争议:有些人认为这是对熟悉的设计进行了不必要的简化;有些人则赞赏新标识与其他流媒体服务看起来并不一样;有些人则怀疑新标识的颜色是否真的变了,还是他们一直以来都看错了电视。  这种新的绿色被称为"Aurora",既是为了向极光致敬,也是为了向《睡美人》中的主角致敬。(我不太记得那部电影中出现过这种绿色,但不管怎么说。)这是迪斯尼蓝和 Hulu 绿的混合色--这里有一个非...
            0 0 908
            分享
          • 前言在一线大厂,没有测试这个岗位,只有测开这个岗位即使是做业务测试,那么你的title也是测开所以想聊一聊测开的看法但不代表这是正确的看法,仅供参考还没来阿里之前,我对测开的看法一直以为专职做自动化测试和性能测试是测试这条路的最终归宿测试开发,只是大厂才可能存在的角色测试平台,少部分公司才会用到的东西,肯定不会成为主流的啦况且测试平台要会前端还得会后端,你都这么全栈为什么不做开发呢做 UI 自动化、接口自动化直接写 python 脚本不就好了嘛,做性能测试用 Jmeter 就好了嘛多数人眼中的测试开发开发一个测试平台,就要包揽前后端至...
            0 0 1040
            分享
      • 51testing软件测试圈微信