【软件测试】编写测试用例篇

前面部分主要是编写测试用例的方法和方向,后面一部分是编写出具体的测试用例

目录

什么是测试用例

1.设计测试用例的万能公式

1.1.从思维出发

1.2.万能公式

1.3.弱网测试

1.4.安装与卸载测试

2.设计测试用例的方法

2.1.基于需求的设计方法

2.2.等价类

2.3.正交法

​编辑

2.4.场景法

2.5.判定表法


什么是测试用例

背景:我们在写程序或者刷题的时候,要想验证自己写的程序是否正确,都会代入几个特殊值去测试该程序,通过程序的结果就能判断出来。而对于我们的项目也是一样,但是测试用例会非常的多喝复杂,所以也就需要我们去学习,做到全方面的想出测试用例。

因此,对于设计测试用例有一个原则:

测试用例中一个必需部分 是 对预期输出或者结果进行定义

什么意思呢?使用当前的测试用例,就一定会有一个预期的结果,是通过或者失败。然后通过测试,就能显而易见的对比结果了。

(1)对新自行车进行测试

对于一个新项目,我们需要测试。那我们现在对一辆新买的自行车也需要测试,就需要设计测试用例,才能知道从哪些方面入手。

  • 是否可以正常骑行
  • 刹车是否灵敏/正常
  • 坐垫是否舒服
  • 外观是否有掉漆
  • 等等等

这些都是我们从脑子里面想出来的一些测试用例,如果不进行记录,很快就会忘记,而且会想的不全面,因此,我们就有一些记录测试用例的手段。

(2)记录测试用例的手段

第一种:通过excel表格

第二种:通过思维导图/脑图

我们在日常学习和面试中,都是推荐使用第二种。

下面,我们通过第二种举例说明。

(3)使用脑图设计测试用例

下面是对一个键盘进行设计的测试用例

虽然通过脑图记录了很多的测试用例,但是不够具体,远远不可以作为工作中具体的测试依据。而且对于不同的对象,每次去设计测试用例都是要重新出发。

因此,我们就需要去学习设计测试用例的万能公式和方法,后续在设计测试用例的时候,就可以固定的从大多数方向入手,设计的也快,也更加全面和具体。


1.设计测试用例的万能公式

这里介绍的万能公式有两个方面,一方面是思维上的万能公式,另一个方面是具体的万能公式(方向)

1.1.从思维出发

对于设计测试用例,都需要哪些思维呢?也就是需要往那些方向去思考。

常规思考 + 逆向思维 + 发散性思维

因此,得出设计测试用例也存在几条原则

(1)测试用例的编写不仅应当根据有效和预料到的输入情况,而且也应该根据无效和未料到的输入情况

比如我们测试登陆页面,不仅要测试输入正确密码时的情况,也要测试错误密码时的情况或者其他的格式

(2)检查程序是否“未做其应该做的”仅是成功的一半,还应该测试另一半是否“做了其不应该做的”

和上一条一样,输入错误的就是不应该做的,也要进行测试

(3)计划测试工作时不应该默许假定不会发生错误

和上面的一样,不应该默认输入的密码都是正确的

上述只是设计测试用例的一些思维,仅供一些方向,但是还不够,还需要一些具体的方法。

1.2.万能公式

(1)万能公式

功能测试+界面测试+性能测试+兼容性测试+易用性测试+安全性测试

这就是设计测试用例的万能公式,可以帮助我们从哪些方向出发,进行设计测试用例。 

(2)每个方向应该测试的

  • 功能测试

从产品的功能出发,验证功能是否正常(功能就是此类产品通常都具有的)

  • 界面测试

我们肉眼可以看到的成为界面。可以从颜色、大小、外观入手进行测试

  • 性能测试

也就是测试一些极端的情况

  • 兼容性测试

例如,测试不同系统的版本、不同的浏览器等等

  • 易用性测试

是否具备一些新手引导教学或者看起来易操作

  • 安全性测试

是否可以保证用户的隐私安全,信息是否容易被窃取等情况

(3)登陆页面-测试用例

这些是自己通过万能公式设计的一些设计用例,看起来都非常的少。

我们看一下比较官方的设计:

上述的万能公式也只是针对大部分场景,还有一些特殊情况可能还未测试到

1.3.弱网测试

(1)弱网测试的目的

目的是尽可能保证用户的使用体验。具体的点包括下面:

  • 页面响应时间是否可以接受(不同网络下,页面刷新成功的时间是否可以接受)
  • 页面呈现是否完成一致(比如只加载了部分内容)
  • 超时文案是否符合定义,异常信息是否显示正常(是否会提升加载超时等)
  • 是否有超时重连
  • 安全角度
  • 大流量事件风险

(2)如何进行弱网测试

我们需要借助抓包工具,我们就以fiddler为举例

步骤:

第一步:打开fiddler

第二步:开启弱网

第三步:打开脚本编辑器设计网速

出现该页面

查询 

输入关键词:m_simulateModem

找到可以设计网速的代码位置

通过前面勾选的弱网开关,就会执行里面的代码,也就是会按照里面设置的网速执行。

如何设计网速?

里面的两个数字,设置的越大,网速就越慢,反之越快。

1.4.安装与卸载测试

对于一些需要安装的软件,我们也需要进行安装和卸载的测试

主要包括两个方面

(1)安装

  • 安装包是否可以正常安装
  • 卸载之后,再次选择安装是否可以安装

(2)卸载

  • 安装后是否可以卸载
  • 安装一天后再进行卸载
  • 反复多次安装和卸载
  • 卸载到一半退出,卸载是否成功或者卸载一半

2.设计测试用例的方法

2.1.基于需求的设计方法

比如,要测试一个登陆的界面,首先根据万能公式写出大概得方向,然后针对每个方向,都会有很多的需求,根据需求来设计测试用例。

比如:登陆账号密码,可以分出测试登陆成功和登陆失败的两种测试用例;然后需要很限制密码的长度,针对密码的长度,也进行设计测试用例,这就是基于需求的设计测试用例方法

2.2.等价类

我们为什么要设计等价类呢?举个例子,比如上述的密码长度规定在6-15位,那如何更快的测试呢?总不能一个个长度的密码都要测试吧?显然这是不科学的做法,因此就需要有等价类。

(1)等价类概念

        依据需求将输⼊(特殊情况下会考虑输出)划分为若⼲个等价类,从等价类中选出⼀个测试⽤例,如果?这个测试⽤例测试通过,则认为所代表的等价类测试通过,这样就可以⽤较少的测试⽤例达到尽量多的?功能覆盖,解决了不能穷举测试的问题。

解决的问题:可能需要穷举的测试

(2)等价类分类

等价类分为:有效等价类和无效等价类

1.有效等价类:满足需求的集合、有效的输入。比如密码长度要求6-15位,那么在这个范围内的等价类就成为有效等价类

2.无效等价类:根据需求说明书,不满足需求的集合。比如上面的,测试密码长度不在合理范围内的等价类就称为无效等价类

(3)有效、无效等价类举例

根据密码长度6-15位举例:

有效等价类:6位密码长度、15位密码长度,10位密码长度

无效等价类:5位密码长度、16位密码长度

(4)边界值

简介:边界值是基于等价类的一种补充,也就是测试边界值的一个黑盒方法,这里的边界也就是来自等价类的边界。

1)边界值分为:边界值+次边界值

1.有边界值是有效等价类中的数据,那么次边界值是无效等价类中的边界

2.若边界值是无效等价类中的数据,那么次边界值为有效等价类中的边界

2)举例:

需求范围1:密码有效长度为:[6,15]

有效等价类的范围:[6,15],无效等价类:<6或者>15

边界值:6,15-----边界值属于有效等价类中的数据,所以次边界值为5,16,也就是无效等价类的边界

需求范围1:密码有效长度为:(6,15)

有效等价类的范围:[7,14],无效等价类:<=6或者>=15

边界值:6,15-----边界值属于无效等价类中的数据,所以次边界值为:7,14;也就是有效等价类的边界值

2.3.正交法

这种方法比较困难,实际中一般很少直接使用,就算进行使用,也是借助工具生成的。

对于一些场景,比如部分填写信息,那得设计多少的测试用例?是庞大的一个数字,所以我们就需要通过正交法来辅助编写测试用例。

比如有如下的信息,姓名、电子邮箱、密码、确认密码、验证码,这五个信息,每个选项都有填写/不填写,组合起来就是32可能,实际肯定不会采取这种方案,因此就需要通过正交法产生一个正交表,正交表中就可以帮助我们编写测试用例了。

(1)概念

正交表的两个性质:

  • 每一列中,不同的数字出现的次数相等
  • 任意两列中数字的排列方式齐全而且均衡

对于性质1,比如第一列因素中:数字1、数字2、数字3都出现了3次,次数相同。

性质2:这就是对比两列得出的结果了,比如数字1在每一行中都出现过,数字2、3同理。

(2)设计正交表的步骤

1)根据需求找出因素和水平

2)将因素和水平写入到表格中(表格不需保存)

3)在allparis.exe同级文件夹下创造一个txt文件,将excel表格中的内容复制进去(可以保证格式没有问题,否则后续操作会出问题)

4)使用allparis.exe工具对txt文件生产正交表文件(通过cmd控制台,使用allparis.exe test01.txt > res-test01.txt,两个txt是文件名字,可随意)

5)根据生成的正交表编写测试用例

(3)使用正交法编写测试用例

1)根据需求找出因素和水平

2)将因素和水平写入到表格中(表格不需保存)

3)在allparis.exe同级文件夹下创造一个txt文件,将excel表格中的内容复制进去(可以保证格式没有问题,否则后续操作会出问题)

创造txt文件

复制内容

4)使用allparis.exe工具对txt文件生产正交表文件(通过cmd控制台,使用allparis.exe test01.txt > res-test01.txt,两个txt是文件名字,可随意)

第一步:

第二步:

第三步:查看新文件

5)根据正交表,编写测试用例

其中,~的意思是可以填写,也可以不填写 

  1. 姓名填写,电子邮箱填写,密码填写,确认密码填写,验证码填写
  2. 姓名填写,电子邮箱不填写,密码不填写,确认密码不填写,验证码不填写
  3. 姓名不填写,电子邮箱填写,密码不填写,确认密码填写,验证码不填写
  4. 姓名不填写,电子邮箱不填写,密码填写,确认密码不填写,验证码填写
  5. 姓名~填写,电子邮箱填写,密码填写,确认密码不填写,验证码不填写
  6. 姓名~填写,电子邮箱不填写,密码不填写,确认密码填写,验证码填写
  7. 姓名不填写,电子邮箱不填写,密码不填写,确认密码不填写,验证码不填写

 

2.4.场景法

目前很多的软件的每个功能都可以形容成一个个事件,也就是一个个流程,所以我们就可以根据场景来设计测试用例

(1)概念

我们通常以正常的⽤例场景分析开始,然后再着⼿其他的场景分析。场景法⼀般包含基本流和备⽤流,从⼀个流程开始,通过描述经过的路径来确定的过程,经过遍历所有的基本流和备⽤流来完成整个场景。

场景主要包括4种主要的类型:正常的⽤例场景,备选的⽤例场景,异常的⽤例场景,假定推测的场景。

(2)举个例子

我们以去逛街买衣服为例

正常的流程就是:逛街-->到达服装店-->选上衣服-->拿下衣服。但是呢,在实际生活中,难免会出现一些意外或者突发情况,就会导致无法按照正常的流程完成,即使这样,最终也是完成了买衣服的任务。

所以,我们就可以根据不同的流程去测试软件的功能。

(3)场景法软件测试举例

我们以登陆邮箱为例

正常流程:输入正确邮箱账号,输入正确密码,在输入验证码,点击登陆即可完成。但是我们也要测试一些其他的流程,也就是备用流

测试1:输入正确邮箱账号,输入正确密码,输入验证码,点击登陆,登陆成功。

测试2:输入正确的邮箱账号,输入正确的密码,输入错误验证码,登陆失败,输入正确验证码,登陆成功。

测试3:输入正确邮箱账号,输入错误密码,输入正确验证码,登陆失败,重新输入正确密码和验证码,登陆成功。

……

像这样的场景测试用例有很多很多,大家可以去试试看。

2.5.判定表法

对于上面的一些方法,显然还不能应付所有的场景,比如说,有几个选项,不同的组合会造成结果不一样,如果使用正交法就无法解决了。

判定表法是一种逻辑判断工具,几种条件组合在一起会得出一个结果

(1)步骤

1)确认需求中输入条件和输出条件

2)找出输入条件和输出条件之间的关系

3)画判定表

4)根据判定表编写测试用例

下面我们以上面的步骤来进行举例

(2)举例

有一个需求是这样的,对于邮箱注册,如果账号中包含admin字符,或者通过内部链接进入注册页面,最后提交注册按钮,就可以成为管理员身份,反之都不行。

所以成为管理员身份有两个条件

1)确认需求中输入条件和输出条件

输入条件:账号包含admin字符,或者内部链接,最后提交注册按钮

输出条件:管理员身份/非管理员身份

2)找出输入条件和输出条件之间的关系

账号包含admin字符,提交注册按钮,成为管理员身份;

通过内部链接进入注册页面,提交注册按钮,成为管理员身份

其他的条件,都不能成为管理员身份

3)画判定表

我们以上面的表格为例使用excil画出表格

4)根据判定表书写测试用例

比如上述有8列,就可以编写出8个测试用例

  1. 账号包含admin,提交注册按钮,成为管理员身份;
  2. 内容链接进入注册页面,提交注册按钮,成为管理员身份
  3. 账号包含admin,不提交注册按钮,不能成为管理员身份
  4. 账号包含admin,通过内部链接进入,提交注册按钮,成为管理员身份
  5. ……

以上就是关于测试用例篇的全部内容了,感谢各位观看

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/801011.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Git分支管理】分支合并冲突及其解决

目录 0.合并冲突 1.创建和切换dev1 ​2.dev1 bbb on dev branch ​3.master ccc on dev branch 4.dev1和master合并冲突 5.合并冲突解决 ​6.git log查看合并流程图 先提交再合并 0.合并冲突 在使用git进行合并操作的时候&#xff0c;在合并两个分支的时候就有可能出…

【EXCELL技巧篇】使用Excel公式,获取当前 Excel的Sheet页的名字

【通知】&#xff1a; 正式跟大家说个难过的消息&#xff0c;本来在「中国朝代史」结束后&#xff0c;开启的下一个专栏「中国近代史」前面几期做的还好好的&#xff0c;可是今天起正式通知审核不过&#xff0c;因为一些原因。 其实我对于历史这一块我还是很感兴趣的&#xff0…

13、Shell自动化运维编程基础

弋.目录 RHCE板块一、为什么学习和使用Shell编程二、Shell是什么1、shell起源2、查看当前系统支持的shell3、查看当前系统默认shell4、Shell 概念 三、Shell 程序设计语言1、Shell 也是一种脚本语言2、用途 四、如何学好shell1、熟练掌握shell编程基础知识2、建议 五、Shell脚本…

海外媒体投稿:精准定位目标受众!掌握这5个软文代发推广要点

在当今互联网时代&#xff0c;软文代发成为了一种常见的推广手段。要想取得成功&#xff0c;就需要掌握精准定位目标受众这一关键要素。本文将介绍5个软文代发推广要点&#xff0c;帮助读者了解如何更好地利用软文代发来吸引目标受众。 软文代发要点 1. 熟悉目标受众 在进行软…

怎麼使用指紋流覽器Hubstudio促進跨境電商業務?

指紋流覽器是一種基於流覽器指紋技術開發的工具&#xff0c;能夠模擬不同的流覽器環境和指紋資訊&#xff0c;實現多個帳號的同時登錄和管理。此項技術提升了帳號的安全性&#xff0c;同時顯著降低了帳號被封禁的風險。指紋流覽器通常用於隱私保護、安全性增強、多帳號管理、數…

房地产市场2024年展望——深度解读行业趋势

作为一名有十多年经验的地产营销人&#xff0c;对于2024年房地产行业的发展趋势&#xff0c;我认为可以从以下几个方面来探讨&#xff0c;如果觉得对你有帮助&#xff0c;请不吝一个三连&#xff08;赞同喜欢收藏&#xff09; 一、市场调整与分化加剧 在经历了较长时间的市场…

Python excel知识库批量模糊匹配的3种方法实例(fuzzywuzzy\Gensim)

前言 当然&#xff0c;基于排序的模糊匹配&#xff08;类似于Excel的VLOOKUP函数的模糊匹配模式&#xff09;也属于模糊匹配的范畴&#xff0c;但那种过于简单&#xff0c;不是本文讨论的范畴。 本文主要讨论的是以公司名称或地址为主的字符串的模糊匹配。 使用编辑距离算法进…

ATFX集团高层受到中国驻约旦大使馆经商处接见

全球领先的差价合约经纪商ATFX宣布&#xff0c;在全球扩张、深耕区域市场与本地化运营的战略指导下&#xff0c;公司深耕区域市场方面取得显著进展&#xff0c;在中东市场&#xff0c;其高层更是获得了中国驻约旦大使馆经商处的特别接见。近日&#xff0c;在中国驻约旦哈希姆王…

【计算机网络】学习指南及导论

个人主页&#xff1a;【&#x1f60a;个人主页】 系列专栏&#xff1a;【❤️计算机网络】 文章目录 前言我们为什么要学计算机网络&#xff1f;计算机网络概述计算机网络的分类按交换技术分类按使用者分类按传输介质分类按覆盖网络分类按覆盖网络分类 局域网的连接方式有线连接…

更新:彩虹云商城系统 自助下单免授权无后门源码(修复完整版)

源码简介&#xff1a; 最新更新彩虹云商城系统&#xff0c;自助下单免授权无后门源码&#xff08;修复完整版&#xff09; 自助下单彩虹云商城系统。这玩意儿不简单&#xff0c;它是高效稳定的电商平台&#xff01;免授权源码版本&#xff0c;灵活方便。源码是用PHP语言写的。…

十五、C++11常用新特性—Lambda表达式

1.基本 这个好像是很好用的&#xff0c;其有以下有点&#xff1a; 声明式的编程风格&#xff1a;直接匿名定义目标函数或函数对象&#xff0c;不需要额外写一个命名函数或函数对象。简洁&#xff1a;避免了代码膨胀和功能分散&#xff0c;让开发更加高效。在需要的时间和地点…

Java实现经纬度坐标转换---CGCS2000坐标、gps84 、GCJ-02、 BD-09

Java实现经纬度坐标转换 目录 一、坐标系统简介1.经纬度坐标系2.坐标系统3.坐标转换简介 二、地图经纬度转换工具类&#xff08;CGCS2000坐标 与 WGS84坐标 互转&#xff09;1.对于 CGCS2000 需要引入 proj4j依赖&#xff1a;2.坐标转换工具类 三、地图经纬度转换工具类(gps84 …

【Linux】多线程_7

文章目录 九、多线程8. POSIX信号量根据信号量环形队列的生产者消费者模型代码结果演示 未完待续 九、多线程 8. POSIX信号量 POSIX信号量和SystemV信号量作用相同&#xff0c;都是用于同步操作&#xff0c;达到无冲突的访问共享资源目的。 但POSIX可以用于线程间同步。 创建…

38 IRF+链路聚合+ACL+NAT组网架构

38 IRF链路聚合ACLNAT组网架构 参考文献 34 IRF的实例-CSDN博客 35 解决单条链路故障问题-华三链路聚合-CSDN博客 36 最经典的ACL控制-CSDN博客 37 公私网转换技术-NAT基础-CSDN博客 32 华三vlan案例STP-CSDN博客 一 网络架构 二 采用的技术 1 vlan 2 ip 3 stp 4 链…

【问题记录】Docker配置mongodb副本集实现数据流实时获取

配置mongodb副本集实现数据流实时获取 前言操作步骤1. docker拉取mongodb镜像2. 连接mongo1镜像的mongosh3. 在mongosh中初始化副本集 注意点 前言 由于想用nodejs实现实时获取Mongodb数据流&#xff0c;但是报错显示需要有副本集的mongodb才能实现实时获取信息流&#xff0c;…

数据结构(Java):队列Queue集合力扣面试OJ题

1、队列 1.1 队列的概念 队列是一个特殊的线性表&#xff0c;只允许在一端&#xff08;队尾&#xff09;进行插入数据操作&#xff0c;在另一端&#xff08;对头&#xff09;进行删除数据。队列具有先进先出FIFO(First In First Out)的特性。 入队&#xff1a;数据只能从队尾…

【密码学】密码学数学基础:群的定义

一、群的定义 在密码学中&#xff0c;群&#xff08;Group&#xff09;的概念是从抽象代数借用来的&#xff0c;它是一种数学结构&#xff0c;通常用于描述具有特定性质的运算集合。 群的定义 群定义中的几个关键要素&#xff1a; 集合&#xff1a;首先&#xff0c;群是由一系…

ES快速开发,ElasticsearchRestTemplate基本使用以及ELK快速部署

最近博主有一些elasticsearch的工作&#xff0c;所以更新的慢了些&#xff0c;现在就教大家快速入门&#xff0c;并对一些基本的查询、更新需求做一下示例&#xff0c;废话不多说开始&#xff1a; 1. ES快速上手 es下载&#xff1a;[https://elasticsearch.cn/download/]()这…

以数据编织,重构数据管理新范式

大数据产业创新服务媒体 ——聚焦数据 改变商业 人工智能几乎统一了全球最顶尖科技公司的认知&#xff1a;这个时代&#xff0c;除了AI&#xff0c;没有第二条路可走。 人工智能的技术逻辑颇有一种“暴力美学”&#xff0c;它依托于海量大数据和超高算力的训练和推理&#xff…

PE73_E6_BLE

PE73_E6_BLE 产品参数 产品型号 PE73_E6_BLE 尺寸(mm) 180*130*13mm 显示技术 电子墨水屏 显示区域(mm) 163.2(H) * 97.92(V) 分辨率(像素) 800*480 像素尺寸(mm) 0.204*0.204 显示颜色 黑/白/红/黄/橙/蓝/绿 视觉角度 180 工作温度 0-50℃ …