如何设计出一个比较全面的测试用例

目录

1. 测试用例的基本要素(不需要执行结果)

2. 测试用例的给我们带来的好处

3. 用例编写步骤

4. 设计测试用例的方法

    4.1 基于需求进行测试用例的设计

    4.2 具体的设计方法

      1.等价类

      2.边界值

      3.判定表(因果图)

      4.正交表法

      5.场景设计法

      6.错误猜测法


1. 测试用例的基本要素(不需要执行结果)

  测试环境 -> 操作步骤 -> 测试数据 -> 预期结果

2. 测试用例的给我们带来的好处

    1) 提高测试效率,节省测试时间

    2) 测试用例是自动化测试的前提

    3) 积累测试的方法思路以供后续借鉴

3. 用例编写步骤

   拿到测试需求 -> 分析需求(画思维导图) -> 确定测试范围,划分用例优先级 -> 编写用例

4. 设计测试用例的方法

    4.1 基于需求进行测试用例的设计

      在基于需求进行测试用例设计时,我们需要从功能需求和非功能需求两个方面进行分析。以下是详细的步骤:

      1. 功能需求测试分析--参考标准:需求文档

  • 明确测试目标:首先,需要明确测试的目标,即确保软件的功能实现与需求文档中的描述一致。

  • 识别关键功能点:从需求文档中提取出关键的功能点,这些功能点是用户最关心的,也是最容易出错的地方。

  • 设计测试场景:针对每个关键功能点,设计相应的测试场景。测试场景应尽可能覆盖所有可能的使用情况,包括正常情况、异常情况和边界条件。

  • 编写测试用例:根据测试场景,编写详细的测试用例。测试用例应包含明确的前置条件、操作步骤、预期结果和实际结果等信息。

      2. 非功能需求测试分析--参考标准:需求文档

  • 性能测试:评估系统的性能指标,如响应时间、吞吐量和资源利用率等。设计测试用例来模拟不同的负载情况,以验证系统在高负载下的稳定性和性能表现。

  • 安全性测试:检查系统的安全性措施是否有效,如身份验证、访问控制和数据加密等。设计测试用例来尝试攻击系统,以发现潜在的安全漏洞。

  • 兼容性测试:验证系统在不同平台、浏览器或设备上的兼容性。设计测试用例来测试系统在各种环境下的表现,以确保其能够在不同环境中正常运行。

  • 可用性测试:评估系统的易用性和用户体验。通过用户调查、问卷调查或用户测试等方式,收集用户反馈,以改进系统的设计和交互方式。

      3. 总结

      在基于需求进行测试用例设计时,我们需要从功能需求和非功能需求两个方面进行全面的分析。通过明确测试目标、识别关键功能点、设计测试场景和编写测试用例等步骤,可以确保软件的质量满足需求文档中的要求。同时,我们还需要关注系统的性能、安全性、兼容性和可用性等方面,以提供更好的用户体验和保障系统的稳定性。

    4.2 具体的设计方法

      1.等价类

        概念:

        将所有可能输入的数据,有无效等价类和有效等价类(即正确输入和非法输入),测试的时候,然后从每一个类别中选取少数具有代表性的数据作为测试用例,如果测试通过,即代表这一类测试通过。

有效等价类:满足用户需求的一个数据集合

无效等价类:不满足用户需求的数据集合

        设计测试用例的流程:

        充分理解需求 -> 将需求分类(有效等价类,无效等价类)-> 针对有效等价类和无效等价类设计测试用例

        举例:

        比如说,如果你要测试一个输入年龄的字段,你可以分成几组:小于0的年龄、0到100之间的年龄、大于100的年龄。然后,从每组中选一个典型的数字来测试,比如-1、50、101。这样就可以覆盖大部分情况了。

      2.边界值

        概念:

        边界值分析法就是测试输入或输出的边界值的一种黑盒测试方法。因为程序在边界值的地方最容易出问题,所以我们专门测试这些边界值。

        通常边界值分析法是作为对等价类划分法的补充,这种情况下,其测试用例来自等价类的边界。

这里还涉及到三个概念:

上点:边界上的点就是上点(不管范围是开区间还是闭区间)

内点:边界内的点(不管范围是开区间还是闭区间)

离点:如果区间是开区间,区间内最靠近上点的点

如果是闭区间,区间外最靠近上点的点

        举例:

          上点:50,55

          内点:51,52,53,54,55

          离点:51 56

      3.判定表(因果图)

        概念:

        是一种用于描述复杂逻辑决策规则的技术,常用于需求分析阶段来定义业务规则,并在测试阶段用来设计测试用例。

        简单而言,判定表其实就是一个表格,它帮助我们清晰地列出所有可能的情况和对应的处理结果。

        设计测试用例的流程:

         (1)分析所有可能的输入和可能的输出

         (2) 找出输入与输出之间的对应关系

         (3) 设计判定表

         (4) 把判定表对应到每一个测试用例

        举例:

        1. 分析所有可能的输入和可能的输出--条件可能是来自用户界面的输入数据,或者是系统内部的状态变化等

        假设我们有一个简单的登录系统,其输入条件为用户名和密码,输出结果为登录成功或失败。

  • 输入条件:

    • 用户名(Username)

    • 密码(Password)

  • 输出结果:

    • 登录成功(Login Success)

    • 登录失败(Login Failed)

        2. 找出输入与输出之间的对应关系

        接下来,确定输入条件与输出结果之间的关系。这些关系通常由逻辑运算符(如与、或、非等)来表达。

  • 对于登录系统,我们可以有以下几种情况:

  • 用户名正确且密码正确 -> 登录成功

  • 用户名正确且密码错误 -> 登录失败

  • 用户名不存在 -> 登录失败

  • 密码为空 -> 登录失败

        3. 设计判定表

        根据上述关系,构建一个判定表。判定表包含一系列的条件组合以及对应的动作。

动作\条件

C1:用户名正确

C2:密码正确

C3:用户名存在

C4:密码非空

A1

A2

A3

-

-

A4

-

-

        4. 把判定表对应到每一个测试用例

  • 测试用例1(对应A1):

    • 输入:正确的用户名和密码。

    • 预期结果:登录成功。

  • 测试用例2(对应A2):

    • 输入:正确的用户名,错误的密码。

    • 预期结果:登录失败。

  • 测试用例3(对应A3):

    • 输入:不存在的用户名。

    • 预期结果:登录失败。

  • 测试用例4(对应A4):

    • 输入:密码为空。

    • 预期结果:登录失败。

        通过这样的方法,我们可以确保所有的输入组合都被考虑到,并且每个可能的结果都有对应的测试用例来验证。这样可以帮助我们发现潜在的问题并提高软件的质量。

      4.正交表法

        概念:

        是一种系统化的测试用例设计方法,主要用于减少测试用例的数量,同时保证较高的覆盖率。这种方法特别适用于那些具有多个输入参数和多种可能的参数组合的情况。

        设计测试用例的流程:

        充分理解需求 -> 确定因素水平 -> 画正交表 -> 补充正交表 -> 将正交表转换成测试用例

        举例:

        1. 充分理解需求

        首先,你需要彻底理解软件的功能需求和非功能需求。这一步是为了确保你知道要测试哪些方面。

        2. 确定因素和水平

          接下来,识别出所有影响系统行为的因素(即变量),并确定每个因素可能的水平(即变量取值)。

          例如,在一个在线购物系统中,因素可能包括支付方式、商品种类、用户类型等,而水平则包括具体的支付选项(信用卡、支付宝)、商品种类(电子产品、书籍)、用户类型(新用户、老用户)等。

  • 因素:

    • 支付方式(Payment Method)

    • 商品种类(Product Category)

    • 用户类型(User Type)

  • 水平:

    • 支付方式:信用卡(Credit Card)、支付宝(Alipay)

    • 商品种类:电子产品(Electronics)、书籍(Books)

    • 用户类型:新用户(New User)、老用户(Existing User)

        3. 画正交表

根据所识别的因素和水平,选择一个合适的正交表。正交表的特点是:

  • 每一列中各个数字(水平)出现的次数一样多。

  • 任何两列中的各有序数对出现的次数一样多。

正交表通常表示为 Lₙ(mᵏ),其中 n 是行数(测试用例数量),m 是水平数,k 是因素数。

        对于上述因素,可以选择 L₄(2³) 的正交表:

序号

支付方式

商品种类

用户类型

1

CC

Elec

New

2

CC

Books

Existing

3

Alipay

Elec

Existing

4

Alipay

Books

New

        这里的 CC 表示 Credit Card,Alipay 表示支付宝;Elec 表示 Electronics,Books 表示 Books;New 表示 New User,Existing 表示 Existing User。

        4. 补充正交表

        有时,标的正交表可能不足以涵盖所有重要的测试场景。这时,可以根据实际情况对正交表进行补充或调整,以确保关键路径得到充分测试。

        5. 将正交表转换成测试用例

        最后,根据正交表中的每一行设计具体的测试用例。每一行代表一组输入参数的组合,以及对应的预期输出或行为。

  • 测试用例1(对应第1行):

    • 输入:支付方式为信用卡,商品种类为电子产品,用户类型为新用户。

    • 预期结果:支付成功,订单创建。

  • 测试用例2(对应第2行):

    • 输入:支付方式为信用卡,商品种类为书籍,用户类型为老用户。

    • 预期结果:支付成功,订单创建。

  • 测试用例3(对应第3行):

    • 输入:支付方式为支付宝,商品种类为电子产品,用户类型为老用户。

    • 预期结果:支付成功,订单创建。

  • 测试用例4(对应第4行):

    • 输入:支付方式为支付宝,商品种类为书籍,用户类型为新用户。

    • 预期结果:支付成功,订单创建。

        通过这种方式,你可以有效地设计出覆盖广泛输入组合的测试用例,同时减少测试的工作量。

      5.场景设计法

        概念:

        通过模拟特定的使用场景来测试系统功能或业务流程的一种方法。具体来说,就是设定一个具体的场景,模拟在这个场景下会发生什么,然后观察最终的结果,以此来发现需求中存在的问题。

        设计测试用例的流程:

        充分理解需求 -> 确定主事件流 -> 确定次事件流 -> 每个事件流就是一个测试用例

        举例:

          比如说,你要测试一个在线购物网站的结账流程:

  • 你可以设定一个场景:用户添加商品到购物车,然后去结账。

  • 在这个场景中,你会模拟用户点击“添加到购物车”和“去结账”的动作。

  • 观察最终的结果,比如是否能顺利结账、订单信息是否正确等。

      6.错误猜测法

       概念:

        一种依靠测试人员的经验和直觉来找出程序中可能出现的错误,并据此设计测试用例的方法。

        简单来说,就是测试人员根据自己以前遇到过的bug或者是对系统的理解,猜测哪里可能会出错,然后专门去测试这些地方。

        举例:

        比如,如果你曾经在一个项目中遇到过某个特定类型的错误,那么在测试新的项目时,你可能会特别留意类似的情况,看看同样的错误会不会再次出现。这就是错误猜测法的实际应用。

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

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

相关文章

[产品管理-33]:实验室技术与商业化产品的距离,实验室技术在商业化过程中要越过多少道“坎”?

目录 一、实验室技术 1.1 实验室研究性技术 1.2 技术发展的S曲线 技术发展S曲线的主要阶段和特点 技术发展S曲线的意义和应用 二、实验室技术商业化的路径 2.1 实验室技术与商业化产品的距离 1、技术成熟度与稳定性 - 技术自身 2、市场需求与适应性 - 技术是满足需求 …

快递物流短信API接口代码

官网:快递鸟 API参数 用户信息类 一.短信模版 1.接口说明 使用快递鸟短信功能时,预先设置好短信模板和对应的发送规则,快递鸟短信API将根据设置的好的模板和规则,进行短信的发送和反馈。 (1)仅支持Json格式。 (2)请求指令810…

org.eclipse.paho.client.mqttv3.MqttException: 无效客户机标识

需求背景 最近有一个项目,需要用到阿里云物联网,不是MQ。发现使用原来EMQX的代码去连接阿里云MQTT直接报错,试了很多种方案都不行。最终还是把错误分析和教程都整理一下。 需要注意的是,阿里云物联网平台和MQ不一样。方向别走偏了。 概念描述 EMQX和阿里云MQTT有什么区别…

国标GB28181视频融合监控汇聚平台的方案实现及场景应用

Liveweb国标视频融合云平台基于端-边-云一体化架构,部署轻量简单、功能灵活多样,平台可支持多协议(GB28181/RTSP/Onvif/海康SDK/Ehome/大华SDK/RTMP推流等)、多类型设备接入(IPC/NVR/监控平台),在视频能力上&#xff0…

CNS-WRFID-01地标卡读写器|写卡器DEMO软件读、写操作说明

CNS-WRFID-01地标卡读写器|写卡器是一款高频读写设备,支持ISO15693协议芯片卡,地标标签读写,支持兴颂系列抗金属|非抗金属RFID标签,如:CNS-CRFID-01、CNS-CRFID-02、CNS-CRFID-03、CNS-CRFID-04、CNS-CRFID-05、CNS-CR…

chorme浏览器 您的连接不是私密连接

‌当浏览器显示“您的连接不是私密连接,攻击者可能会试图从 localhost 窃取您的信息(例如:密码、消息或信用卡信息)”的警告时,这通常意味着您正在尝试访问的网站的安全证书存在问题,可能是因为它使用的是自…

2015年国赛高教杯数学建模A题太阳影子定位解题全过程文档及程序

2015年国赛高教杯数学建模 A题 太阳影子定位 技术就是通过分析视频中物体的太阳影子变化,确定视频拍摄的地点和日期的一种方法。   1.建立影子长度变化的数学模型,分析影子长度关于各个参数的变化规律,并应用你们建立的模型画出2015年10月…

ESP32-WROOM-32 [创建AP站点-客户端-TCP透传]

简介 基于ESP32-WROOM-32 开篇(刚买), 本篇讲的是基于固件 ESP32-WROOM-32-AT-V3.4.0.0(内含用户指南, 有AT指令说明)的TCP透传设置与使用 设备连接 TTL转USB线, 接ESP32 板 的 GND,RX2, TX2 指令介绍 注意,下面指…

利士策分享,如何在有限的时间内过上富足的生活?

利士策分享,如何在有限的时间内过上富足的生活? 在快节奏的现代生活中,追求富足不仅仅是物质上的丰盈,更是心灵的满足与生活的平衡。 如何在有限的时间内实现这一目标,是许多人心中的疑问。 以下是一些实用建议&#…

Linux centerOS 服务器搭建NTP服务

1,安装 NTP软件 sudo yum -y install ntp2,编辑配置文件 sudo vim /etc/ntp.conf 3,修改配置 在ntp.conf文件中,可以配置服务器从哪些上游时间源同步时间。如果你想让你的服务器对外同步时间,可以去掉restrict d…

BGP实验

1、实验拓扑 EBGP:位于不同AS的BGP路由器之间的BGP对等体关系。两台路由器之间要建立EBGP对等体关系,必须满足两个条件: 两个路由器所属AS不同(即AS号不同)。 在配置EBGP时,Peer命令所指定的对等体IP地址要…

【Docker】Docker快速入门

Docker学习笔记 一、Docker概述 为什么会出现Docker? 安卓开发流程:apk(java开发的)发布到应用商店,用户安装apk即可使用。 后端开发流程: jar(java开发的)带上环境发布到Docker仓库,用户从Docker仓库拉取镜像并部署。 总结…

智慧安防监控EasyCVR视频汇聚管理平台如何修改视频流分辨率?

智慧安防监控EasyCVR视频管理平台能在复杂的网络环境中,将前端监控设备进行统一集中接入与汇聚管理。EasyCVR平台支持H.264/H.265视频压缩技术,可在4G/5G/WIFI/宽带等网络环境下,传输720P/1080P/2K/4K高清视频。视频流经平台处理后&#xff0…

ByteTrack多目标跟踪流程图

ByteTrack多目标跟踪流程图 点个赞吧,谢谢。

VulnHub-Bilu_b0x靶机笔记

Bilu_b0x 靶机 概述 Vulnhub 的一个靶机,包含了 sql 注入,文件包含,代码审计,内核提权。整体也是比较简单的内容,和大家一起学习 Billu_b0x.zip 靶机地址: https://pan.baidu.com/s/1VWazR7tpm2xJZIGUS…

php thinkphp 小程序发送订阅模板消息通知

小程序需要在我的模板中先选用模板 小程序需要先订阅模板 wx.requestSubscribeMessage({tmplIds: ["XII_0By8D9WabnUjVPB_8S1itsm2d4_xxx"],success:

**CentOS7安装redis**

CentOS7安装redis 首先解压压缩包 redis-7.0.0.tar.gz tar -xvf redis-7.0.0.tar.gz接着进入到redis中 cd redis-7.0.0.tar.gz执行make命令编译 make接着执行安装命令 make install之后编译安装完后 程序都会在/usr/local/bin目录下 这里需要将在redis目录中redis.conf配置…

基于STM32的电压检测WIFI模拟

目录 一、主要功能 二、硬件资源 三、程序编程 四、实现现象 一、主要功能 基于STM32单片机,通过滑动变阻器模拟电压传感器检测电压,通过12864显示显示电压和电压阈值,按键可以控制阈值的增加,并通过串口实时显示相关参数和状…

2024年主流前端框架的比较和选择指南

在选择前端框架时,开发者通常会考虑多个因素,包括框架的功能、性能、易用性、社区支持和学习曲线等。以下是一些主流前端框架的比较和选择指南。 1. 主流前端框架简介 React 优点: 组件化开发,易于复用和维护。虚拟DOM提高了性能。强大的生…

二叉树进阶oj题【二叉树相关10道oj题的解析和代码实现】

目录 二叉树进阶oj题1.根据二叉树创建字符串2.二叉树的层序遍历3.二叉树的层序遍历 II4.二叉树的最近公共祖先5.二叉搜索树和双向链表6.从前序与中序遍历序列构造二叉树7.从中序和后序遍历序列来构造二叉树8.二叉树的前序遍历,非递归迭代实现9.二叉树中序遍历 &…