测试用例设计白皮书--场景设计方法

方法简介

现在的软件几乎都是用事件触发来控制流程的,事件触发时的情景便形成了场景,而同一事件不同的触发顺序和处理结果就形成事件流。这种在软件设计方面的思想也可以引入到软件测试中,可以比较生动地描绘出事件触发时的情景,有利于测试设计者设计测试用例,同时使测试用例更容易理解和执行。

基本流和备选流:如下图所示,图中经过用例的每条路径都用基本流和备选流来表示,直黑线表示基本流,是经过用例的最简单的路径。备选流用不同的色彩表示,一个备选流可能从基本流开始,在某个特定条件下执行,然后重新加入基本流中(如备选流 1 和 3);也可能起源于另一个备选流(如备选流 2),或者终止用例而不再重新加入到某个流(如备选流 2 和 4)。

实战演习

例子描述

下图所示是 ATM 例子的流程示意图。

 

场景设计

下表所示是生成的场景。

表 3-8 场景设计

场景 1——成功提款

基本流

 

场景 2——ATM 内没有现金

基本流

备选流 2

场景 3——ATM 内现金不足

基本流

备选流 3

场景 4——PIN 有误(还有输入机会)

基本流

备选流 4

场景 5——PIN 有误(不再有输入机会)

基本流

备选流 4

场景 6——账户不存在/账户类型有误

基本流

备选流 5

场景 7——账户余额不足

基本流

备选流 6

注:为方便起见,备选流 3 和 6(场景 3 和 7)内的循环以及循环组合未纳入上表。

用例设计

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

表 3-9 测试用例表

TC(测试用例)ID 号

场景/条件

PIN

账号

输入(或选择)的金额

账面金额

ATM 内的金额

预期结果

CW1

场景 1:成功提款

V

V

V

V

V

成功提款

CW2

场景 2:ATM内没有现金

V

V

V

V

I

提款选项不可用,用例结束

CW3

场景 3:ATM内现金不足

V

V

V

V

I

警告消息,返回基本流步骤 6,输入金额

CW4

场景 4:PIN有误

(还有不止一次输入机会)

I

V

n/a

V

V

警告消息,返回基本流步骤

4,输入 PIN

CW5

场景 4:PIN有误

(还有一次输入机会)

I

V

n/a

V

V

警告消息,返回基本流步骤

4,输入 PIN

CW6

场景 4:PIN有误

(不再有输入机会)

I

V

n/a

V

V

警告消息,卡予保留,用例结束

 

数据设计

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

测试用例一经认可,就可以确定实际数据值(在测试用例实施矩阵中)并且设定测试数据,如表 3-10 所示。

表 3-10 测试用例表

TC(测试用例)

ID 号

场景/条件

PIN

账号

输入(或选择)的金额

(元)

账面金额

(元)

ATM 内的金

额(元)

预期结果

CW1

场景 1:成功提款

4987

809-498

50.00

500.00

2 000

成功提款。账户余额被更新为 450.00

CW2

场景 2:ATM 内没有现金

4987

809-498

100.00

500.00

0.00

提款选项不可用,用例结束

CW3

场景 3:ATM 内现金不足

4987

809-498

100.00

500.00

70.00

警告消息,返回基本流步骤

6,输入金额

CW4

场景 4:PIN 有误(还有不止一次输入机会)

4978

809-498

n/a

500.00

2 000

警告消息,返回基本流步骤

4,输入 PIN

CW5

场景 4:PIN 有误(还有一次输入机会)

4978

809-498

n/a

500.00

2 000

警告消息,返回基本流步骤

4,输入 PIN

CW6

场景 4:PIN 有误(不再有输入机会)

4978

809-498

n/a

500.00

2 000

警告消息,卡予保留,用例结束

发表评论

电子邮件地址不会被公开。 必填项已用*标注