在我们的日常工作中,我们通常接触到的都是比较复杂的系统。而复杂的系统就意味着比较复杂的测试程序。首先,对于复杂的系统来说,如果想要做功能测试,一般需要考虑到测试数据的问题,还要考虑如何从全局出发,既要把整个业务流程需要测试的内容充分覆盖到。保证即使是多个功能点交叉、存在复杂约束的条件下,也不会出现漏测或者新bug的问题。

其次,即使是单一功能点,也需要足够熟悉,才能确保功能能在操作流程中顺利实现。

因此,作为软件测试工程师,我们需要在日常工作中不断积累经验,精进技术,确保自己能够应对不同场景完成测试任务。那么针对这些复杂的系统,我们应该如何进行测试呢?今天我们就来回顾一下。

1、基于场景的测试

为了解决复杂的测试任务,我们提出了基于场景的测试这一概念。这一概念主要以事件流为核心。当然,这一概念,也是为我们后期做高层次的功能测试设计打基础。那么,这一概念的基本思想是什么呢?

它是通过分析不同事件的触发顺序和处理结果,从而构建各个事件流。并且,基于这些事件的触发控制业务流程,形成多个不同场景,最终基于场景设计测试用例。

上图是这一概念的原理。我们不难看出,该图是一条自上而下、贯穿始终的基本事件流(简称基本流)。而其中,每个基本流代表一个被测的典型功能点或主业务。在基本流上,又存在多个触发点,不同触发点又会产生不同事件,从而触发业务流程分流,形成多个备选事件流(简称备选流)。由此,由基本流和备选流形成的不同业务流程(简称场景)诞生了。

2、测试用例设计

由于在不同的场景中,每个场景至少对应一组输入和一个预期输出结果(简称测试用例)。因此,基于场景的测试用例将是一个既庞大,又复杂的工程。那么,对于这样复杂的工程,测试难点有哪些呢?我们又应该如何设置基本流与备选流呢?下面,我们来一一回答。

1)测试难点

主要有以下几个难点:

l 如何根据业务,来构建测试的基本流和备选流;

l 如何基于事件流构建场景,从而满足测试的完整性和无冗余性;

l 如何根据场景,合理设计测试用例。

2)基本流和备选流的设置

针对我们要重点测试的业务,我们需要构建一个基本流和和若干备选流。

(1)基本流

先来回顾一下概念:基本流是指。从系统的某个初始状态开始,经一系列状态变化后,到达终止状态的过程中,最主要的一个业务流程。简言之,就是说整个业务流程中最基本的一个流程。它不需要很复杂,但却是一条高风险的业务流程。

(2)备选流

备选流是以基本流为基础,在经过基本流上每个判定节点(包括条件判定和循环判定),满足不同的触发条件,而导致的其他事件流。

与基本流不同的是,基本流是一条完整的业务流程,而备选流仅是业务流程中的一个执行片段。对比图如下:

对于我们来说,备选流数目决定了我们的工作量有多大。一般情况下,备选流的数目,取决于判定节点的数目与事务分析的颗粒度。简言之,颗粒度越细,考虑得越周全,得到的数目就越多,测试工作量也就越大。

总之,如果你还是记不太清这两者的关系,可以通过下图回忆一下:

3、构建场景

我们都知道,场景是基本流与备选流的有序集合。场景实际用途是用来描述流经用例的路径,即,整个测试过程经历哪些步骤(基本流和备选流)。这也就不难理解,为什么一个测试用例只能对应唯一一个场景了。

那么,我们的场景应该是什么样的呢?下面我们来回忆一下:

l 场景1:基本流;

l 场景2:基本流+备选流1;

l 场景3:基本流+备选流2;

l 场景4:基本流+备选流2+备选流3;

l 场景5:基本流+备选流2+备选流4;

l 场景6:基本流+备选流5;

l 场景7:基本流+备选流1+备选流2+备选流5;

l 场景8:基本流+备选流1+备选流2+备选流3;

l 场景9:基本流+备选流1+备选流2+备选流4。

除了以上的几种场景外,我们还可以通过增加更多备选流,从而构建更多的场景。但是,在这个过程中,我们就会发现,工作量变得异常庞大了。

那么,我们要如何做才能既给自己“减负”,同时又能合理的完成工作呢?我认为,你至少需要考虑这3点:

(1)最少的场景数等于事件流的总数,即基本流与备选流的总数;

(2)有且唯一有一个场景仅包含基本流;

(3)对应某个备选流,至少应有一个场景覆盖该备选流,且在该场景中应尽量避免覆盖其他的备选流。

4、如何设计测试用例呢?

基于场景,我们可以按照如下步骤,来设计测试用例:

(1)分析被测业务,基于风险的思想找到基本流和所有备选流;

(2)根据基本流和备选流构造适当规模的场景;

(3)根据场景设计测试用例;

(4)对每个测试用例补充测试数据,并实施测试。

不知道看完上述内容,大家有没有回忆起在不同应用场景中,我们该如何进行测试呢?希望印象不太深刻的小伙伴可以去翻翻以前的笔记。后面我们还将为大家提供一个实战案例,希望对大家的工作有所帮助。

喜欢软件测试的小伙伴们,如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一键三连哦!


好文推荐

转行面试,跳槽面试,软件测试人员都必须知道的这几种面试技巧!

面试经:一线城市搬砖!又面软件测试岗,5000就知足了…

面试官:工作三年,还来面初级测试?恐怕你的软件测试工程师的头衔要加双引号…

什么样的人适合从事软件测试工作?

那个准点下班的人,比我先升职了…

测试岗反复跳槽,跳着跳着就跳没了…

包装成1年工作经验的测试工程师,我给他的面试前的建议如下

“入职一年,那个被高薪挖来的自动化软件测试被劝退了。”

4个月自学软件测试面进阿里!如何从功能测试转成自动化…我经历了什么

6000元报了培训班,3个月后我成功“骗”进了腾讯大厂,月薪15000

在不同应用场景中,我们该如何进行测试呢?相关推荐

  1. 基于matlab城市空中交通场景中的激光雷达与雷达融合仿真(附源码)

    目录 一.创建城市空中交通方案 二.定义无人机传感器套件 三.定义跟踪系统 3.1 激光雷达点云处理 3.2 激光雷达跟踪器 3.3 雷达跟踪器 3.4 轨道融合 四.可视化 五.模拟场景 六.跟踪指 ...

  2. 拥挤场景中的目标检测

    拥挤场景中的目标检测 Detection in Crowded Scenes: One Proposal, Multiple Predictions 论文链接: https://arxiv.org/a ...

  3. 结构化场景中的RGB-D SLAM

    点云PCL免费知识星球,点云论文速读. 文章:RGB-D SLAM with Structural Regularities 作者:Yanyan Li , Raza Yunus , Nikolas B ...

  4. 自动驾驶车辆在结构化场景中基于HD-Map由粗到精语义定位

    点云PCL免费知识星球,点云论文速读. 文章:Coarse-to-fine Semantic Localization with HD Map for Autonomous Driving in St ...

  5. 在结构化场景中基于单目的物体与平面SLAM方案

    点云PCL免费知识星球,点云论文速读. 文章:Monocular Object and Plane SLAM in Structured Environments 作者:Shichao Yang, S ...

  6. 线上分享会预告之深度学习在3D场景中的应用

    大家好.上周我们迎来了第一期的线上分享,三维模型检索技术介绍,此次分享是一次接力形式的分享,每周都将有一位主讲人分享,希望更多的小伙伴加入我们一起分享,也是给自己一个机会锻炼.这里先预告一下,线上直播 ...

  7. js添加网页水印和three.js场景中加水印

    我们在日常网页开发的时候,可能想给自己的网页或者canvas里面添加水印,增添个人标记,我这里分为普通静态html页面和threejs中3d场景里面添加水印功能. 一 静态html页面添加水印 你只需 ...

  8. 多模态人物识别技术及其在爱奇艺视频场景中的应用 | 公开课笔记

    [12月公开课预告],入群直接获取报名地址 12月11日晚8点直播主题:人工智能消化道病理辅助诊断平台--从方法到落地 12月12日晚8点直播:利用容器技术打造AI公司技术中台 12月17日晚8点直播 ...

  9. 多模态人物识别技术及其在视频场景中的应用 | CSDN技术公开课

    不用倍速播放,还有什么功能可以让你高效追剧? 爱奇艺的「只看TA」了解一下?而这个功能背后离不开多模态人物识别技术的支撑. 识别视频中的人物涉及哪些信息?只有人脸识别就足够了吗?其实不然,这样一个看似 ...

  10. 【转】在OpenGL场景中实现小地图功能

    http://www.c3dn.net/archiver/?tid-48.html 想象一下,我们在原始森林里寻找宝藏,没有地图,没有GPS,那结果应该只有一种:不但找不到目标地点,而且很容易迷失方向 ...

最新文章

  1. NIOS2 DMA 传输模式
  2. linux系统 硬链接和软链接
  3. python 分位数计算代码_Python数据分析第十一节 数据运算
  4. Js 通过点击改变css样式
  5. firefox如何载入json文件_Firefox在书签工具栏中推隐藏“其他书签”文件夹功能
  6. Windows Terminal 窗口/控制台切换快捷键总结
  7. 卷积神经网络的参数量和计算量
  8. 使用Scylla进行OSINT信息收集
  9. 校对双层PDF中的隐藏文本
  10. 串级控制MATLAB实验报告,串级控制系统实验报告.docx
  11. 使用批处理进行批量重命名
  12. Sql Server Update 更新数据
  13. windows系统下进入jupyter本地服务器(localhost)的步骤
  14. Lambert (兰伯特)光照模型
  15. java选填_java-选择填空题库
  16. matlab零序五次谐波,基于MATLAB的高次谐波接地选线保护仿真设计
  17. 洛谷 P1462 通往奥格瑞玛的道路
  18. 文佳夹操作之获取指定目录下的所有文件及文件夹
  19. python语言语句单词大全及读音_python单词怎么读
  20. 为什么post请求前先发一个options 请求?

热门文章

  1. 关于DotNetNuke(DNN)的语言问题
  2. 1631. 最小体力消耗路径
  3. php 添加表,关于php:如何向MYSQL表添加新列
  4. C++/C代码审查表
  5. key php 转小写_PHP开发常识
  6. java流程图什么代表活动_举例分析流程图与活动图的区别与联系
  7. 分析:云存储和电子发现的结合
  8. 用YAML构建数据测试DAO层
  9. Runtime.getRuntime().exec()----记录日志案例
  10. 搜索引擎网站登陆入口,提交入口