1.基本信息

场景法是一种通过使用“场景”对软件系统的功能点或业务流程进行描述,即针对需求模拟出不同的场景进行所有功能点及业务流程的覆盖,从而提高测试效率并达到良好效果的方法。

2.分类

  • 基本流:也叫有效流或正确流,模拟用户正确的业务操作流程
  • 备选流:也叫无效流或错误流,模拟用户错误的业务操作流程

    3.业务流组成、场景组合、覆盖原则及识别原则

    (1)场景业务流组成:基本流 + 备选流
    image.png
    (2)场景组合
    按上图组合多个不同的场景:

  • 场景1:基本流

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

(3)备选流覆盖准则

  • 覆盖每个备选流;
  • 覆盖一个循环;
  • 这两种方法可以看情况选择,到这一步基本的测试用例就出来了,每个场景对应一个测试用例,对每个用例进行评审,删掉重复的。

(4)基本流和备选流的识别原则

  • 基本流只有一个起点,一个终点;
  • 基本流是主流,备选流是支流;
  • 备选流可以始于基本流,也可以始于其它备选流;
  • 备选流的终点,可以是一个流程的出口,也可以是回到基本流,还可以是汇入其它的备选流;
  • 备选流汇合时,谁汇合到谁,取决于流量大小也即该流程出现的可能性大小,小的汇入大的;
  • 如果在流程图中出现了两个不相上下的基本流,一般需要把它们分别当做一个业务看待。

    4.优缺点

  • 优点:涉及到业务流程的适合用场景法

  • 缺点:只验证业务流程,不验证单点功能。一般先采用等价类划分、边界值分析、错误推断法、判定表等方法对单点功能进行验证,验证通过后再采用场景法进行业务流程的验证。

    5.举例

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

用例结束时 ATM 又回到准备就绪状态。
Step3.备选流如下:
04.场景设计法介绍 - 图4
Step4.生成的场景如下:
04.场景设计法介绍 - 图5
对于这 7 个场景中的每一个场景都需要确定测试用例。可以采用矩阵或决策表来确定和管理测试用例。下面显示了一种通用格式,其中各行代表各个测试用例,而各列则代表测试用例的信息。本示例中,对于每个测试用例,存在一个测试用例 ID、条件(或说明)、测试用例中涉及的所有数据元素(作为输入或已经存在于数据库中)以及预期结果。
通过从确定执行用例场景所需的数据元素入手构建矩阵。然后,对于每个场景,至少要确定包含执行场景所需的适当条件的测试用例。例如,在下面的矩阵中,V(有效)用于表明这个条件必须是 VALID(有效的)才可执行基本流,而 I(无效)用于表明这种条件下将激活所需备选流。下表中使用的“n/a”(不适用)表明这个条件不适用于测试用例。
Step5.测试用例矩阵如下:
04.场景设计法介绍 - 图6
在上面的矩阵中,六个测试用例执行了四个场景。对于基本流,上述测试用例 CW1 称为正面测试用例。它一直沿着用例的基本流路径执行,未发生任何偏差。基本流的全面测试必须包括负面测试用例,以确保只有在符合条件的情况下才执行基本流。这些负面测试用例由 CW2 至 6 表示(阴影单元格表明这种条件下需要执行备选流)。虽然 CW2 至 6 对于基本流而言都是负面测试用例,但它们相对于备选流 2 至 4 而言是正面测试用例。而且对于这些备选流中的每一个而言,至少存在一个负面测试用例(CW1 - 基本流)。
每个场景只具有一个正面测试用例和负面测试用例是不充分的,场景 4 正是这样的一个示例。要全面地测试场景 4 - PIN 有误,至少需要三个正面测试用例(以激活场景 4):

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

注:在上面的矩阵中,无需为条件(数据)输入任何实际的值。以这种方式创建测试用例矩阵的一个优点在于容易看到测试的是什么条件。由于只需要查看 V 和 I(或此处采用的阴影单元格),这种方式还易于判断是否已经确定了充足的测试用例。从上表中可发现存在几个条件不具备阴影单元格,这表明测试用例还不完全,如场景 6 - 不存在的帐户/帐户类型有误和场景 7 - 帐户余额不足就缺少测试用例。
一旦确定了所有的测试用例,则应对这些用例进行复审和验证以确保其准确且适度,并取消多余或等效的测试用例。
测试用例一经认可,就可以确定实际数据值(在测试用例实施矩阵中)并且设定测试数据
Step6.测试用例及测试数据如下:
04.场景设计法介绍 - 图7
以上测试用例只是在本次迭代中需要用来验证提款用例的一部分测试用例。需要的其他测试用例包括:

  • 场景 5 – 帐户不存在/帐户类型有误:未找到帐户或帐户不可用
  • 场景 5 – 帐户不存在/帐户类型有误:禁止从该帐户中提款
  • 场景 6 – 帐户余额不足:请求的金额超出帐面金额
  • 在将来的迭代中,当实施其他事件流时,在下列情况下将需要测试用例:
  • 无效卡(所持卡为挂失卡、被盗卡、非承兑银行发卡、磁条损坏等)
  • 无法读卡(读卡机堵塞、脱机或出现故障)
  • 帐户已消户、冻结或由于其他方面原因而无法使用
  • ATM 内的现金不足或不能提供所请求的金额(与 CW3 不同,在 CW3 中只是一种币值不足,而不是所有币值都不足)
  • 无法联系银行系统以获得认可
  • 银行网络离线或交易过程中断电

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

https://zhuanlan.zhihu.com/p/127787256