热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

[原创]测试用例设计之场景法法

[原创]测试用例设计之场景法法场景法设计测试用例,主要用在于事件触发流程中,当某个事件触发然后就形成相应的场景流程,不同的事件触发&#
[原创]测试用例设计之"场景法"法 

     场景法设计测试用例,主要用在于事件触发流程中,当某个事件触发然后就形成相应的场景流程,不同的事件触发,不同顺序和不同的处理结果,就形成一系列的

事件流结果。所以此类方法在设计测试用例时,非常形象! 

     所以在RUP中场景的测试用例设计方法,非常重要!在实际的应用过程中,应按以下要求进行:

     应该为每个用例场景编制测试用例。

     用例场景要通过描述流经用例的路径来确定,这个流经过程要从用例开始到结束遍历其中所有基本流和备选流。

     下图中经过用例的每条不同路径都反映了基本流和备选流,都用箭头来表示。基本流用直黑线来表示,是经过用例的最简单的路径。每个备选流自基本流开始,之后,备选流会在某个特定条件下执行。备选流可能会重新加入基本流中(备选流 1 和 3),还可能起源于另一个备选流(备选流 2),或者终止用例而不再重新加入某个流(备选流 2 和 4)。


用例的事件流示例

遵循上图中每个经过用例的可能路径,可以确定不同的用例场景。从基本流开始,再将基本流和备选流结合起来,可以确定以下用例场景:

场景 1基本流
场景 2基本流备选流 1
场景 3基本流备选流 1备选流 2
场景 4基本流备选流 3
场景 5基本流备选流 3备选流 1
场景 6基本流备选流 3备选流 1备选流 2
场景 7基本流备选流 4
场景 8基本流备选流 3备选流 4

注:为方便起见,场景 5、6 和 8 只描述了备选流 3 指示的循环执行一次的情况。

        生成每个场景的测试用例是通过确定某个特定条件来完成的,这个特定条件将导致特定用例场景的执行。

例如,假定上图描述的用例对备选流 3 规定如下:

“如果在上述步骤 2‘输入提款金额’中输入的美元量超出当前帐户余额,则出现此事件流。系统将显示一则警告消息,之后重新加入基本流,再次执行上述步骤 2‘输入提款金额’,此时银行客户可以输入新的提款金额。”

据此,可以开始确定需要用来执行备选流 3 的测试用例:

测试用例 ID场景条件预期结果
TC x场景 4步骤 2 - 提款金额 > 帐户余额在步骤 2 处重新加入基本流
TC y场景 4步骤 2 - 提款金额 <帐户余额不执行备选流 3&#xff0c;执行基本流
TC z场景 4步骤 2 - 提款金额 &#61; 帐户余额不执行备选流 3&#xff0c;执行基本流

注&#xff1a;由于没有提供其他信息&#xff0c;以上显示的测试用例都非常简单。测试用例很少如此简单。

下面是一个由用例生成测试用例的更符合实际情况的示例。


示例&#xff1a;

一台 ATM 机器的主角和用例。

下表包含了上图中提款用例的基本流和某些备用流&#xff1a;

本用例的开端是 ATM 处于准备就绪状态。
  1. 准备提款 - 客户将银行卡插入 ATM 机的读卡机。
  2. 验证银行卡 - ATM 机从银行卡的磁条中读取帐户代码&#xff0c;并检查它是否属于可以接收的银行卡。
  3. 输入 PIN - ATM 要求客户输入 PIN 码&#xff08;4 位&#xff09;
  4. 验证帐户代码和 PIN - 验证帐户代码和 PIN 以确定该帐户是否有效以及所输入的 PIN 对该帐户来说是否正确。对于此事件流&#xff0c;帐户是有效的而且 PIN 对此帐户来说正确无误。
  5. ATM 选项 - ATM 显示在本机上可用的各种选项。在此事件流中&#xff0c;银行客户通常选择“提款”。
  6. 输入金额 - 要从 ATM 中提取的金额。对于此事件流&#xff0c;客户需选择预设的金额&#xff08;10 美元、20 美元、50 美元或 100 美元&#xff09;。
  7. 授权 - ATM 通过将卡 ID、PIN、金额以及帐户信息作为一笔交易发送给银行系统来启动验证过程。对于此事件流&#xff0c;银行系统处于联机状态&#xff0c;而且对授权请求给予答复&#xff0c;批准完成提款过程&#xff0c;并且据此更新帐户余额。
  8. 出钞 - 提供现金。
  9. 返回银行卡 - 银行卡被返还。
  10. 收据 - 打印收据并提供给客户。ATM 还相应地更新内部记录。

用例结束时 ATM 又回到准备就绪状态。

备选流 1 - 银行卡无效在基本流步骤 2 中 - 验证银行卡&#xff0c;如果卡是无效的&#xff0c;则卡被退回&#xff0c;同时会通知相关消息。
备选流 2 - ATM 内没有现金在基本流步骤 5 中 - ATM 选项&#xff0c;如果 ATM 内没有现金&#xff0c;则“提款”选项将无法使用。
备选流 3 - ATM 内现金不足在基本流步骤 6 中- 输入金额&#xff0c;如果 ATM 机内金额少于请求提取的金额&#xff0c;则将显示一则适当的消息&#xff0c;并且在步骤 6 - 输入金额处重新加入基本流。
备选流 4 - PIN 有误在基本流步骤 4 中- 验证帐户和 PIN&#xff0c;客户有三次机会输入 PIN。

如果 PIN 输入有误&#xff0c;ATM 将显示适当的消息&#xff1b;如果还存在输入机会&#xff0c;则此事件流在步骤 3 - 输入 PIN 处重新加入基本流。

如果最后一次尝试输入的 PIN 码仍然错误&#xff0c;则该卡将被 ATM 机保留&#xff0c;同时 ATM 返回到准备就绪状态&#xff0c;本用例终止。
备选流 5 - 帐户不存在在基本流步骤 4 中 - 验证帐户和 PIN&#xff0c;如果银行系统返回的代码表明找不到该帐户或禁止从该帐户中提款&#xff0c;则 ATM 显示适当的消息并且在步骤 9 - 返回银行卡处重新加入基本流。
备选流 6 - 帐面金额不足在基本流步骤 7 - 授权中&#xff0c;银行系统返回代码表明帐户余额少于在基本流步骤 6 - 输入金额内输入的金额&#xff0c;则 ATM 显示适当的消息并且在步骤 6 - 输入金额处重新加入基本流。
备选流 7 - 达到每日最大的提款金额在基本流步骤 7 - 授权中&#xff0c;银行系统返回的代码表明包括本提款请求在内&#xff0c;客户已经或将超过在 24 小时内允许提取的最多金额&#xff0c;则 ATM 显示适当的消息并在步骤 6 - 输入金额上重新加入基本流。
备选流 x - 记录错误如果在基本流步骤 10 - 收据中&#xff0c;记录无法更新&#xff0c;则 ATM 进入“安全模式”&#xff0c;在此模式下所有功能都将暂停使用。同时向银行系统发送一条适当的警报信息表明 ATM 已经暂停工作。
备选流 y - 退出客户可随时决定终止交易&#xff08;退出&#xff09;。交易终止&#xff0c;银行卡随之退出。
备选流 z - “翘起”ATM 包含大量的传感器&#xff0c;用以监控各种功能&#xff0c;如电源检测器、不同的门和出入口处的测压器以及动作检测器等。在任一时刻&#xff0c;如果某个传感器被激活&#xff0c;则警报信号将发送给警方而且 ATM 进入“安全模式”&#xff0c;在此模式下所有功能都暂停使用&#xff0c;直到采取适当的重启/重新初始化的措施。


在第一次迭代中&#xff0c;根据迭代计划&#xff0c;我们需要核实提款用例已经正确地实施。此时尚未实施整个用例&#xff0c;只实施了下面的事件流&#xff1a;

  • 基本流 - 提取预设金额&#xff08;10 美元、20 美元、50 美元、100 美元&#xff09;
  • 备选流 2 - ATM 内没有现金
  • 备选流 3 - ATM 内现金不足
  • 备选流 4 - PIN 有误
  • 备选流 5 - 帐户不存在/帐户类型有误
  • 备选流 6 - 帐面金额不足

 

可以从这个用例生成下列场景

场景 1 - 成功的提款基本流
场景 2 - ATM 内没有现金基本流备选流 2
场景 3 - ATM 内现金不足基本流备选流 3
场景 4 - PIN 有误&#xff08;还有输入机会&#xff09;基本流备选流 4
场景 5 - PIN 有误&#xff08;不再有输入机会&#xff09;基本流备选流 4
场景 6 - 帐户不存在/帐户类型有误基本流备选流 5
场景 7 - 帐户余额不足基本流备选流 6

注&#xff1a;为方便起见&#xff0c;备选流 3 和 6&#xff08;场景 3 和 7&#xff09;内的循环以及循环组合未纳入上表。

对于这 7 个场景中的每一个场景都需要确定测试用例。可以采用矩阵或决策表来确定和管理测试用例。下面显示了一种通用格式&#xff0c;其中各行代表各个测试用例&#xff0c;而各列则代表测试用例的信息。本示例中&#xff0c;对于每个测试用例&#xff0c;存在一个测试用例 ID、条件&#xff08;或说明&#xff09;、测试用例中涉及的所有数据元素&#xff08;作为输入或已经存在于数据库中&#xff09;以及预期结果。

通过从确定执行用例场景所需的数据元素入手构建矩阵。然后&#xff0c;对于每个场景&#xff0c;至少要确定包含执行场景所需的适当条件的测试用例。例如&#xff0c;在下面的矩阵中&#xff0c;V&#xff08;有效&#xff09;用于表明这个条件必须是 VALID&#xff08;有效的&#xff09;才可执行基本流&#xff0c;而 I&#xff08;无效&#xff09;用于表明这种条件下将激活所需备选流。下表中使用的“n/a”&#xff08;不适用&#xff09;表明这个条件不适用于测试用例。

TC&#xff08;测试用例&#xff09;ID 号场景/条件PIN

 

帐号

 

输入的金额

&#xff08;或选择的金额&#xff09;

 

帐面金额

 

ATM 内的金额

 

预期结果
CW1.场景 1 - 成功的提款VVVVV成功的提款。
CW2.场景 2 - ATM 内没有现金VVVVI提款选项不可用&#xff0c;用例结束
CW3.场景 3 - ATM 内现金不足VVVVI警告消息&#xff0c;返回基本流步骤 6 - 输入金额
CW4.场景 4 - PIN 有误&#xff08;还有不止一次输入机会&#xff09;

 

Vn/aVV警告消息&#xff0c;返回基本流步骤 4&#xff0c;输入 PIN
CW5.场景 4 - PIN 有误&#xff08;还有一次输入机会&#xff09;

 

Vn/aVV警告消息&#xff0c;返回基本流步骤 4&#xff0c;输入 PIN
CW6.场景 4 - PIN 有误&#xff08;不再有输入机会&#xff09;

 

Vn/aVV警告消息&#xff0c;卡予保留&#xff0c;用例结束

在上面的矩阵中&#xff0c;六个测试用例执行了四个场景。对于基本流&#xff0c;上述测试用例 CW1 称为正面测试用例。它一直沿着用例的基本流路径执行&#xff0c;未发生任何偏差。基本流的全面测试必须包括负面测试用例&#xff0c;以确保只有在符合条件的情况下才执行基本流。这些负面测试用例由 CW2 至 6 表示&#xff08;阴影单元格表明这种条件下需要执行备选流&#xff09;。虽然 CW2 至 6 对于基本流而言都是负面测试用例&#xff0c;但它们相对于备选流 2 至 4 而言是正面测试用例。而且对于这些备选流中的每一个而言&#xff0c;至少存在一个负面测试用例&#xff08;CW1 - 基本流&#xff09;。   

每个场景只具有一个正面测试用例和负面测试用例是不充分的&#xff0c;场景 4 正是这样的一个示例。要全面地测试场景 4 - PIN 有误&#xff0c;至少需要三个正面测试用例&#xff08;以激活场景 4&#xff09;&#xff1a;

  • 输入了错误的 PIN&#xff0c;但仍存在输入机会&#xff0c;此备选流重新加入基本流中的步骤 3 - 输入 PIN。
  • 输入了错误的 PIN&#xff0c;而且不再有输入机会&#xff0c;则此备选流将保留银行卡并终止用例。
  • 最后一次输入时输入了“正确”的 PIN。备选流在步骤 5 - 输入金额处重新加入基本流。

注&#xff1a;在上面的矩阵中&#xff0c;无需为条件&#xff08;数据&#xff09;输入任何实际的值。以这种方式创建测试用例矩阵的一个优点在于容易看到测试的是什么条件。由于只需要查看 V 和 I&#xff08;或此处采用的阴影单元格&#xff09;&#xff0c;这种方式还易于判断是否已经确定了充足的测试用例。从上表中可发现存在几个条件不具备阴影单元格&#xff0c;这表明测试用例还不完全&#xff0c;如场景 6 - 不存在的帐户/帐户类型有误和场景 7 - 帐户余额不足就缺少测试用例。

一旦确定了所有的测试用例&#xff0c;则应对这些用例进行复审和验证以确保其准确且适度&#xff0c;并取消多余或等效的测试用例。

测试用例一经认可&#xff0c;就可以确定实际数据值&#xff08;在测试用例实施矩阵中&#xff09;并且设定测试数据

TC&#xff08;测试用例&#xff09;ID 号场景/条件PIN

 

帐号

 

输入的金额

&#xff08;或选择的金额&#xff09;

 

帐面金额

 

ATM 内的金额

 

预期结果
CW1.场景 1 - 成功的提款4987809 - 49850.00500.002,000成功的提款。帐户余额被更新为 450.00
CW2.场景 2 - ATM 内没有现金4987809 - 498100.00500.000.00提款选项不可用&#xff0c;用例结束
CW3.场景 3 - ATM 内现金不足4987809 - 498100.00500.0070.00警告消息&#xff0c;返回基本流步骤 6 - 输入金额
CW4.场景 4 - PIN 有误&#xff08;还有不止一次输入机会&#xff09;4978 

 

809 - 498n/a500.002,000警告消息&#xff0c;返回基本流步骤 4&#xff0c;输入 PIN
CW5.场景 4 - PIN 有误&#xff08;还有一次输入机会&#xff09;4978

 

809 - 498n/a500.002,000警告消息&#xff0c;返回基本流步骤 4&#xff0c;输入 PIN
CW6.场景 4 - PIN 有误&#xff08;不再有输入机会&#xff09;4978 

 

809 - 498n/a500.002,000警告消息&#xff0c;卡予保留&#xff0c;用例结束

 

以上测试用例只是在本次迭代中需要用来验证提款用例的一部分测试用例。当然在实际的取款过程中&#xff0c;还需要从功能&#xff0c;性能&#xff0c;安全等角度去完善测试用例&#xff01;

转:https://www.cnblogs.com/mayingbao/archive/2006/09/06/496025.html



推荐阅读
  • 使用Python在SAE上开发新浪微博应用的初步探索
    最近重新审视了新浪云平台(SAE)提供的服务,发现其已支持Python开发。本文将详细介绍如何利用Django框架构建一个简单的新浪微博应用,并分享开发过程中的关键步骤。 ... [详细]
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • 本文详细分析了JSP(JavaServer Pages)技术的主要优点和缺点,帮助开发者更好地理解其适用场景及潜在挑战。JSP作为一种服务器端技术,广泛应用于Web开发中。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 构建基于BERT的中文NL2SQL模型:一个简明的基准
    本文探讨了将自然语言转换为SQL语句(NL2SQL)的任务,这是人工智能领域中一项非常实用的研究方向。文章介绍了笔者在公司举办的首届中文NL2SQL挑战赛中的实践,该比赛提供了金融和通用领域的表格数据,并标注了对应的自然语言与SQL语句对,旨在训练准确的NL2SQL模型。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • XNA 3.0 游戏编程:从 XML 文件加载数据
    本文介绍如何在 XNA 3.0 游戏项目中从 XML 文件加载数据。我们将探讨如何将 XML 数据序列化为二进制文件,并通过内容管道加载到游戏中。此外,还会涉及自定义类型读取器和写入器的实现。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文详细介绍了如何使用ActionScript 3.0 (AS3) 连接并操作MySQL数据库。通过具体的代码示例和步骤说明,帮助开发者理解并实现这一过程。 ... [详细]
  • 在即将迎来26岁生日之际,作者的人生陷入了低谷。经过近三年的硕士学习后,最终决定退学,并且面临没有工作经验的困境。尽管如此,作者依然坚定地选择为自己的人生负责。 ... [详细]
  • 本文详细介绍了美国最具影响力的十大财团,包括洛克菲勒、摩根、花旗银行等。这些财团在历史发展过程中逐渐形成,并对美国的经济、政治和社会产生深远影响。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
author-avatar
手机用户2502885633
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有