测试用例设计指南

测试用例,设计,指南 · 浏览次数 : 263

小编点评

4.1 等价类划分法定义输入具有代表性的数据子集等价类划分法分类有效等价类:满足需求的无效等价类:不满足需求的适用范围 4.2 边界值分析法边界值的定义对于输入等价类和输出等价类而言稍高于其边界或者稍低于其边界的一些特定情况边界值范围正好等于刚刚好大于刚刚好小于边界值分析法中的三个点上点 4.3 判定表法适用条件判定表表示的是有多个输入和多个输出,而且输入与输入之间相互的组合关系,输入和输出之间有相互的制约和依赖关系组成部分条件桩 4.4 因果图法定义正交法又叫正交试验法,使用最小的测试过程集合获得最大的测试覆盖率,(测试用例的条数写的少一点,而测出的bug多一点),正交表:一种特制表,一般的正交表标记为Ln(mk)n表示行数,也就是需要测试组合的次数k表示的列数,表示控件的个数(因素的个数,或是因子的个数)m是每个控件包含的取值个数(各因素的水平数,即各因素的状态数)如:L9( 34 )有4个控件每个控件有3个取值9为需要测试的组合个数,有9条测试用例叫4因素3水平步骤根据需求形成因子状态表—因子:控件名称状态:每个控件对应的取值确定所采用的正交表将正交表中的数字用文字代替一行就是一条测试用例举例注意如果各个因子的状态数是不统一的,几乎不可能出现均匀的情况时,选择正交表为 等于或略大于因子数,状态数,且试验次数最少生成正交试验表的一些方法在线生成:https://jaccz.github.io/pairwise/tools.html输入每个控件和控件的取值生成的表正交试验的实例表可套用到用例中http://www.york.ac.uk/depts/maths/tables/orthogonal.htm正交试验的实例表可套用到用例中http://support.sas.com/techsup/technote/ts723_Designs.txt

正文

作者:京东物流 王玉坤

软件测试设计是测试过程中重要的测试活动,怎么样设计测试用例能提高我们测试的效率和质量,从以下几个方面做了简单的讲解。

1 测试用例设计原则

测试用例设计的基本原则包括:有效性、清晰性、可复用性、可维护性、完整性、兼容性、易操作性、可管理性、可评估性

  1. 有效性:测试用例步骤必须描述清晰,不能出现模棱两可的以及重复的话语,测试用例应该按照一定的顺序进行编写,这样执行的时候效率比较高。
  2. 清晰性:用例的操作步骤要描述清晰,包含清晰的输入数据以及预期输出,验证点必须明确清晰,并能突出重点,对于流程性的用例建议按照流程顺序进行用例安排,从第一个验证点到最后一个验证点,组成流程的开始到结束,方便测试执行。 测试用例包含前置条件的必须将前置条件描述清楚,包括入口等。
  3. 可复用性:可重复使用,并尽量将具有相似功能的测试用例抽象并归类。
  4. 可维护性:测试用例因为业务需求发生变更的时候,需要及时更新维护测试用例,做到测试用例的实时性与有效性,测试用例需要细化和不断的完善,是个循序渐进的过程。
  5. 完整性:用例是否完成并覆盖所有需求点,做到对需求的完全理解。
  6. 兼容性:测试用例要包含新老版本的兼容、新老数据兼容、浏览器兼容等测试点。
  7. 可管理性:能够检测测试人员的测试进度、工作量等。
  8. 可评估性:测试用例的通过率和缺陷的数目是评估软件质量的好坏的标准。

2 测试用例的生命周期

软件测试用例的设计阶段包含:需求分析、测试用例设计、测试用例实现、测试用例执行、测试用例管理

2.1 需求分析

测试用例过程的第一步是确定测什么,标识出测试点,并且对测试点进行优先级的划分。

2.2 测试用例设计

测试用例设计确定了如何来测试已经分析出的测试点。

测试设计的主要点是确定测试预期结果。为了确定测试预期结果,测试人员不仅需要关注测试输出,同时也需要注意测试数据和测试环境的前后置条件。假如测试用例没有测试的预期结果,则测试用例对于测试结果的对错判断是毫无意义的。

测试预期结果可以是各种各样的,包括需要创建或者输出的结果,也可以是需要更新或者变更的结果,也可以是删除的结果。每个测试用例都应该清楚的描述测试的预期结果。这样,就需要测试人员具有被测系统相关的丰富的知识和经验,才可能对软件系统的测试输出作出正确的评估。假如测试输出结果评估认为是正确的,那么就可以作为测试用例的期望输出结果。

2.3 测试用例实现

测试用例实现的过程包括准备测试脚本、测试输入、测试数据以及预期结果等。测试脚本指的是按照标准的语法组织数据或者指令。测试执行之前,首先必须满足测试前置条件,比如一个测试用例需要用到配置好的一些数据,那么这个数据就必须提前创建等。

2.4 测试用例执行

通过运行测试用例来对被测系统进行测试。对于手动测试来说,主要参照测试用例的步骤来进行测试执行,比较预期结果和实际结果、并记录测试过程中发现的问题。

对于自动化测试过程,执行时需要借助测试工具,运行测试用例脚本等,记录测试结果。

执行测试时如实际结果和预期结果是一样的,则认为是通过的,如果不一样,那用例执行失败,或存在问题,对于用例执行失败,需要进一步的检查,确定是软件问题还是用例的预期结果有问题,或者是数据问题,环境问题引起的,需要从不同的方面进行问题分析。

2.5 测试用例管理

1)测试用例组织

每一个项目,其测试用例的数目都非常多。如何来组织、跟踪和维护测试用例是一件非常重要的事情。如何来组织测试用例,是测试成功与否的一个重要因素,也是提高测试效率的一个重要步骤。

测试用例的组织,可以用不同的方法来进行组织或者分类:

  • 按照软件功能模块组织:软件系统一般是根据软件的功能模块来进行工作任务分配的。因此,根据软件功能模块进行测试用例设计和执行等是很常用的一种方法。根据模块来组织测试用例,可以保证测试用例能够覆盖每个系统模块,达到较好的模块测试覆盖率。
  • 按照测试用例优先级组织:测试用例是有优先级的。对于任何软件,实现穷尽测试是不现实的。在有限的资源和时间内,首先应该执行优先级高的测试用例。

按照功能模块进行划分是最常用的,我们也可以结合起来使用,比如在按照功能模块划分的基础上,再进行不同优先级的划分。

2)测试用例跟踪

测试用例的跟踪主要是针对测试执行过程中测试用例的状态来进行的,通过测试状态的跟踪和管理,从而实现测试过程和测试有效性的管理和评估。

  • 测试用例执行的跟踪:在测试执行的过程中,对测试用例的状态进行跟踪,可以有效的将测试过程量化。比如,执行一轮测试过程中,测试的测试用例数目是多少,测试用例中通过、未通过、未测试的比例各是多少。这些数据可以提供一些信息来判断软件项目执行的质量和执行进度,并对测试进度、状态提供明确的数据,有利于测试进度和测试重点的控制。

3)测试用例维护

测试用例并不是一成不变的,当一个阶段测试过程结束后,会发现一些测试用例编写的不合理,或者需求发生了变化,这都需要对当前的一些测试用例进行修改和更新,从而使测试用例具有可复用性。

3 测试用例编写要素

  • 用例编号:用例的唯一标识
  • 测试模块:测试用例所属模块
  • 用例标题:测试用例的简要说明
  • 前提条件:用例执行的前提
  • 测试步骤:执行用例步骤
  • 预期结果:应该得到的结果
  • 优先级:用例重要程度

4 功能测试用例设计方法

4.1 等价类划分法

等价类划分法的定义

  • 输入具有代表性的数据子集

等价类划分法分类

  • 有效等价类:满足需求的
  • 无效等价类:不满足需求的

适用范围

  • 具有单个输入的功能

步骤

  • 明确需求
  • 确定有效和无效等价类
  • 编写测试用例

举例

需求:下单若是函速达,需要允许快递员修改,且限定包裹数必须为1,重量要<0.5kg。

4.2 边界值分析法

边界值的定义

  • 对于输入等价类和输出等价类而言稍高于其边界或者稍低于其边界的一些特定情况

边界值范围

  • 正好等于
  • 刚刚好大于
  • 刚刚好小于

边界值分析法中的三个点

  • 上点:边界上的点
  • 离点:距离边界最近的点
  • 内点:范围内的点

举例:1-100 ,上点:1 100 离点:0 99 2 101 内点:50

适用范围

  • 有输入参数,且输入类型或范围长度有边界时(适用于题目需求中有长度或者范围的情况)
  • 和等价类一起使用,适用于单个功能的输入的情况

步骤

  1. 明确需求
  2. 确定有效和无效等价类
  3. 明确题目条件中的边界值
  4. 编写测试用例

举例

4.3 判定表法

适用条件

  • 判定表表示的是有多个输入和多个输出,而且输入与输入之间相互的组合关系,输入和输出之间有相互的制约和依赖关系

组成部分

  • 条件桩:题目条件中的所有的测试输入
  • 动作桩:题目条件中的所有输出
  • 条件项:测试输入的取值
  • 动作项:测试输出的取值

步骤

  1. 明确条件桩
  2. 明确动作桩
  3. 对条件桩进行全组合
  4. 明确每个组合对应的动作桩
  5. 设计测试用例

举例

4.4 因果图法

因果图法定义

  • 理论中是通向判定表的一个中间过程

适用范围

  • 因果图是一种利用图解法来分析输入的各种组合情况,从而设计测试用例的方法,它适用于检查程序输入条件的各种组合情况

因果图法的核心

  • 所谓的原因就是输入,所谓的结果就是输出。
  • 因果图的因 —输入条件
  • 因果图的果 -输入结果

因果图基本符号

关系

  • 恒等:若Ci是1,则ei也是1;否则ei是0
  • 非:若ci是1,则ei是0;否则ei是1
  • 或:若c1或c2或c3是1,则ei是1;否则ei是0
  • 与:若c1和c2都是1,则ei是1;否则ei是0

步骤

  • 标识输入和输出
  • 画出因果图
  • 将因果图转换为判定表
  • 生成测试用例

举例

需求:某软件规格说明书包含这样的要求:第一列字符必须是A或B,第二列字符必须是一个数字,在此情况下进行文件的修改,但如果第一列字符不正确,则给出信息L;如果第二列字符不是数字,则给出信息M。

转化为判定表

最终转化为测试用例。

4.5 正交分析法

定义

  • 正交法又叫正交试验法,又叫正交排列法,使用最小的测试过程集合获得最大的测试覆盖率,(测试用例的条数写的少一点,而测出的bug多一点),正交试验设计法,是从大量的试验点中挑选出适量的,有代表性的点,应用依据伽罗瓦理论导出的“正交表”,合理安排试验的一种科学的试验设计方法。

正交表的概念:一种特制的表,一般的正交表标记为Ln(mk)

  • n表示行数,也就是需要测试组合的次数
  • k表示的列数,表示控件的个数(因素的个数,或是因子的个数)
  • m是每个控件包含的取值个数(各因素的水平数,即各因素的状态数)

如:L9( 34 )
有4个控件
每个控件有3个取值
9为需要测试的组合个数、有9条测试用例
叫4因素3水平

步骤

  1. 根据需求形成因子状态表—-因子:控件名称 状态:每个控件对应的取值
  2. 确定所采用的正交表
  3. 将正交表中的数字用文字代替
  4. 一行就是一条测试用例

举例

注意

如果各个因子的状态数是不统一的,几乎不可能出现均匀的情况时,选择正交表为 等于或略大于因子数,状态数,且试验次数最少

生成正交试验表的一些方法
在线生成:https://jaccz.github.io/pairwise/tools.html

输入每个控件和控件的取值

生成的表

正交试验的实例表可套用到用例中http://www.york.ac.uk/depts/maths/tables/orthogonal.htm
正交试验的实例表可套用到用例中http://support.sas.com/techsup/technote/ts723_Designs.txt

4.6 场景法-流程图法

定义

  • 模拟用户操作时的场景,主要用于测试多个功能之间的组合使用情况

为什么要用户场景法

  • 用户角度:用户平时使用的不是单个功能,而是多个功能组合起来进行使用
  • 测试人员角度:平时测试的都是单个功能点进行测试,为了保证测试的全面性,考虑多个功能之间组合测试的场景

场景法的适用范围

  • 多个功能之间的组合测试
  • 往往在冒烟测试时经常使用

场景法中两个重要的概念

  • 基本流:按照正确的业务流程操作的一种路径
  • 备选流:出现错误的操作流程

步骤

  1. 确定项目角色
  2. 明确角色的常用功能
  3. 根据需求构建测试场景
  4. 一个场景就是一条case

5 安全性测试设计

安全测试是在软件产品开发基本完成时,验证产品是否符合安全需求定义和产品质量标准的过程。安全测试是检查系统对非法侵入渗透的防范能力。

包含的测试点如下:

  • sql注入
  • 明文传输
  • 越权访问
  • 短信邮箱验证
  • 鉴权缺失
  • 密码安全
  • 数据健壮性等

与测试用例设计指南相似的内容:

测试用例设计指南

软件测试设计是测试过程中重要的测试活动,怎么样设计测试用例能提高我们测试的效率和质量,从以下几个方面做了简单的讲解。

Hive怎么调整优化Tez引擎的查询?在Tez上优化Hive查询的指南

在Tez上优化Hive查询无法采用一刀切的方法。查询性能取决于数据的大小、文件类型、查询设计和查询模式。在性能测试过程中,应评估和验证配置参数及任何SQL修改。建议在工作负载的性能测试过程中一次只进行一项更改,并最好在开发环境中评估调优更改的影响,然后再在生产环境中使用。

芯片产业管理和营销指北(4)—— 产品线经理的修行

本篇是系列最后一篇,本系统所有内容均来自 俞志宏 老师的 《我在硅谷管芯片:芯片产品线经理生存指南》一书的总结整理。 工程师 工作比较线性,需要深挖专业知识,但也仅需要专注于专业知识。通常的工作内容是::设计某个电路,测试某些参数,解决某个故障 产品市场分析人员 市场分析因为涉及很多商业和人的行为分

[转帖]Centos 7 部署 openGauss 3.1.0 级联备库集群及集群缩容删除节点-运维指南

https://www.yisu.com/zixun/kf/ 一、安装环境设置 1.1 硬件环境 名称最低配置建议配置测试配置 服务器数量 3 略 略 硬盘 * 至少1GB用于安装openGauss的应用程序。* 每个主机需大约300MB用于元数据存储。* 预留70%以上的磁盘剩余空间用于数据存储。

HC32L110(六) AS06-VTB07H V5.0测试板AT指令固件

这个测试板在前面介绍过, 使用的是 HC32L110C4 芯片. 测试功能很简单, 定时发送字符串`ashining`, 没有参数修改选项. 因此仅仅适用于两块测试底板之间的测试, 无法配合其它 NRF24L01 硬件设备进行收发测试. 一直想重写这个底板的功能, 增加更多的测试项, 但是太懒了一直...

机器学习策略篇:详解如何改善你的模型的表现(Improving your model performance)

如何改善模型的表现 学过正交化,如何设立开发集和测试集,用人类水平错误率来估计贝叶斯错误率以及如何估计可避免偏差和方差。现在把它们全部组合起来写成一套指导方针,如何提高学习算法性能的指导方针。 所以想要让一个监督学习算法达到实用,基本上希望或者假设可以完成两件事情。首先,的算法对训练集的拟合很好,这

使用 Linux dd 命令测试磁盘读写性能

使用 Linux dd 命令测试磁盘读写性能 从帮助手册中可以看出,dd命令可以复制文件,根据操作数进行转换和格式化。我这里记录一下dd命令用于测试磁盘I/O性能的过程。 dd 可从标准输入或文件中读取数据,根据指定的格式来转换数据,再输出到文件、设备或标准输出。 dd 命令用法: Usage: d

kafka学习之三_信创CPU下单节点kafka性能测试验证

# kafka学习之三_信创CPU下单节点kafka性能测试验证 ## 背景 ``` 前面学习了 3controller+5broker 的集群部署模式. 晚上想着能够验证一下国产机器的性能. 但是国产机器上面的设备有限. 所以想着进行单节点的安装与测试. 并且记录一下简单结果 希望对以后的工作有指

【pandas基础】--数据检索

pandas的数据检索功能是其最基础也是最重要的功能之一。 pandas中最常用的几种数据过滤方式如下: 行列过滤:选取指定的行或者列 条件过滤:对列的数据设置过滤条件 函数过滤:通过函数设置更加复杂的过滤条件 本篇所有示例所使用的测试数据如下: import pandas as pd import

(转载)正交试验测试用例设计及工具推荐

(转载)正交试验测试用例设计及工具推荐 原文链接: https://blog.csdn.net/crisschan/article/details/127881580?spm=1001.2014.3001.5501 陈磊: 写过好几本测试相关的书,CrissChan,原京东大佬 在科研和生产实践中,