热门标签 | 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



推荐阅读
  • IT方面的论坛太多了,有综合,有专业,有行业,在各个论坛里混了几年,体会颇深,以前是论坛哪里人多 ... [详细]
  • EPICS Archiver Appliance存储waveform记录的尝试及资源需求分析
    本文介绍了EPICS Archiver Appliance存储waveform记录的尝试过程,并分析了其所需的资源容量。通过解决错误提示和调整内存大小,成功存储了波形数据。然后,讨论了储存环逐束团信号的意义,以及通过记录多圈的束团信号进行参数分析的可能性。波形数据的存储需求巨大,每天需要近250G,一年需要90T。然而,储存环逐束团信号具有重要意义,可以揭示出每个束团的纵向振荡频率和模式。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • 禁止程序接收鼠标事件的工具_VNC Viewer for Mac(远程桌面工具)免费版
    VNCViewerforMac是一款运行在Mac平台上的远程桌面工具,vncviewermac版可以帮助您使用Mac的键盘和鼠标来控制远程计算机,操作简 ... [详细]
  • 使用在线工具jsonschema2pojo根据json生成java对象
    本文介绍了使用在线工具jsonschema2pojo根据json生成java对象的方法。通过该工具,用户只需将json字符串复制到输入框中,即可自动将其转换成java对象。该工具还能解析列表式的json数据,并将嵌套在内层的对象也解析出来。本文以请求github的api为例,展示了使用该工具的步骤和效果。 ... [详细]
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • CentOS 7部署KVM虚拟化环境之一架构介绍
    本文介绍了CentOS 7部署KVM虚拟化环境的架构,详细解释了虚拟化技术的概念和原理,包括全虚拟化和半虚拟化。同时介绍了虚拟机的概念和虚拟化软件的作用。 ... [详细]
  • SAP羞辱国产软件商:技术停在10年前
    SAP中国研究院总裁芮祥麟表示,国产软件厂商过于热衷概念炒作,技术水平停留在10年前的客户端架构水平。他认为,国内厂商推出基于SOA的产品或转型SAAS模式是不可能的,研发新架构需要时间。当前最热门的概念是云计算,芮祥麟呼吁国产厂商应该潜心研发底层架构。 ... [详细]
  • CEPH LIO iSCSI Gateway及其使用参考文档
    本文介绍了CEPH LIO iSCSI Gateway以及使用该网关的参考文档,包括Ceph Block Device、CEPH ISCSI GATEWAY、USING AN ISCSI GATEWAY等。同时提供了多个参考链接,详细介绍了CEPH LIO iSCSI Gateway的配置和使用方法。 ... [详细]
  • 本文讲述了孙悟空写给白骨精的信件引发的思考和反省。孙悟空在信中对自己的行为进行了反思,认识到自己胡闹的行为并没有给他带来实际的收获。他也揭示了西天取经的真相,认为这是玉皇、菩萨设下的一场陷阱。他还提到了师傅的虚伪和对自己的实心话,以及自己作为师傅准备提拔的对象而被派下来锻炼的经历。他认为路上的九九八十一难也都是菩萨算计好的,唐僧并没有真正的危险。最后,他提到了观音菩萨在关键时刻的指导。这封信件引发了孙悟空对自己行为的思考和反省,对西天取经的目的和自己的角色有了更深入的认识。 ... [详细]
  • Windows2003 IIS上设置301定向,实现不带www域名跳转带www域名的方法
    打开IIS,建一个网站,主机头用不带www的域名,随便指向一个目录。然后在这个网站上点右键,属性--主目录--重定向到URL如图ÿ ... [详细]
  • 本文介绍了在Ubuntu下制作deb安装包及离线安装包的方法,通过备份/var/cache/apt/archives文件夹中的安装包,并建立包列表及依赖信息文件,添加本地源,更新源列表,可以在没有网络的情况下更新系统。同时提供了命令示例和资源下载链接。 ... [详细]
  • REVERT权限切换的操作步骤和注意事项
    本文介绍了在SQL Server中进行REVERT权限切换的操作步骤和注意事项。首先登录到SQL Server,其中包括一个具有很小权限的普通用户和一个系统管理员角色中的成员。然后通过添加Windows登录到SQL Server,并将其添加到AdventureWorks数据库中的用户列表中。最后通过REVERT命令切换权限。在操作过程中需要注意的是,确保登录名和数据库名的正确性,并遵循安全措施,以防止权限泄露和数据损坏。 ... [详细]
  • 本文详细介绍了使用 SQL Load 和 Excel 的 Concatenate 功能将数据导入 ORACLE 数据库的方法和步骤,同时介绍了使用 PL/SQL tools 将数据导入临时表的方法。此外,还提供了一个转链接,可参考更多相关内容。摘要共计XXX字。 ... [详细]
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社区 版权所有