测试用例的设计方法_场景设计法

场景设计法

通过运用场景来对系统的功能点或业务流程的描述,从而提高测试效果。场景法一般包含基本流和备用流,从一个流程开始,通过描述经过的路径来确定的过程,经过遍历所有的基本流和备用流来完成整个场景。

每个事件触发时的情景便形成了场景。而同一事件不同的触发顺序和处理结果形成事件流。这一系列的过程我们利用场景法可以清晰的描述清楚。

下图来展示一下网上最长见的场景法基本情况的一个实例图:
测试用例的设计方法_场景设计法
在这个图中,有一个基本流和四个备选流。

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

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

从上面的实例我们就可以了解场景是如何利用基本流和备用流来确定的。

基本流:采用直黑线表示,是经过用例的最简单的路径(无任何差错,程序从开始直接执行到结束)
备选流:采用不同颜色表示,一个备选流可能从基本流开始,在某个特定条件下执行,然后重新加入基本流中,也可以起源于另一个备选流,或终止用例,不在加入到基本流中;(各种错误情况)

下面是场景法的基本设计步骤:
1.根据说明,描述出程序的基本流及各项备选流
2.根据基本流和各项备选流生成不同的场景
3.对每一个场景生成相应的测试用例
4.对生成的所有测试用例重新复审,去掉多余的测试用例,测试用例确定后,对每一个测试用例确定测试数据值

案例:
1、以注册为例:
测试用例的设计方法_场景设计法
2、有一个在线购物的实例,用户进入一个在线购物网站进行购物,选购物品后,进行在线购买,这时需要使用帐号登录,登录成功后,进行付钱交易,交易成功后,生成订购单,完成整个购物过程。

第一步:确定基本流和备选流

基本流 登录在线购物网站,选择物品,登录帐号,付钱交易,生成订购单
备选流1 帐号不存在
备选流2 帐号或密码错误
备选流3 用户帐号余额不足
备选流4 用户帐号没有钱
备选流x 用户退出系统

第二步:根据基本流和备选流来确定场景

场景1-成功购物 基本流
场景2-帐号不存在 基本流 备选流1
场景3-帐号或密码错误 基本流 备选流2
场景4-用户帐号余额不足 基本流 备选流3
场景5-用户帐号没有钱 基本流 备选流4

第三步:设计用例
对于每一个场景都需要确定测试用例。可以采用矩阵或决策表来确定和管理测试用例。

本例中,对于每个测试用例,存在一个测试用例ID、条件(或说明)、测试用例中涉及的所有数据元素(作为输入或已经存在于数据库中)以及预期结果。

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

测试用例ID 场景/条件 帐号 密码 用户帐号余额 预期结果
1 场景1:成功购物 V V V 成功购物
2 场景2:帐号不存在 I n/a n/a 提示帐号不存在
3 场景3:帐号或密码错误(帐号正确,密码错误) V I n/a 提示帐号或密码错误,返回基本流步骤3
4 场景3:帐号或密码错误(帐号错误,密码正确) V I n/a 提示帐号或密码错误,返回基本流步骤3
5 场景4:用户帐号余额不足 V V I 提示帐号余额不足请充值
6 场景5:用户帐号没有钱 V V I 提示帐号余额请充值

第四步:设计数据,把数据填入上面的用例表中

测试用例ID 场景/条件 帐号 密码 用户帐号余额 预期结果
1 场景1:成功购物 Sue 1s2 200 成功购物,帐号余额减少200元
2 场景2:帐号不存在 Jim n/a n/a 提示帐号不存在
3 场景3:帐号或密码错误(帐号正确,密码错误) Sun 1234zxc n/a 提示帐号或密码错误,返回基本流步骤3
4 场景3:帐号或密码错误(帐号错误,密码正确) Suns 123456 n/a 提示帐号或密码错误,返回基本流步骤3
5 场景4:用户帐号余额不足 Van 1v2 1 提示帐号余额不足请充值
6 场景5:用户帐号没有钱 Tom 12zxcdd 0 提示帐号余额请充值

以上写到的测试用例只是购物的一部分测试用例。需要的其他测试用例,我们可以在写完后再进行补充和扩展,达到比较好的覆盖。