分析软件应用的场景,从用户的角度出发,从场景的角度来设计测试用例,是一种面向用户的测试用例设计方法。php
关心用户作什么,而不是关心产品作什么数据库
优势:实用性强,有效,设计出来的用例有价值安全
缺点:可能使用的场景不必定能对事件系列进行全面的分析,设计出来的用例不完整。网络
场景分析是经过描述流经用例路径来肯定的过程,这个流通过程要从用例开始到结束遍历其中全部基本流 :直黑线表示基本流,是最基本、最简单的路径;(软件功能按照正确的事件流实现的一条正确流程无任何错,程序从开始直到结束) 测试
遵循上图中每一个通过用例的可能路径,能够肯定不一样的用例场景。从基本流开始,再将基本流和备选流结合起来,能够肯定如下用例场景:网站
场景1 | 基本流 | |||
---|---|---|---|---|
场景2 | 基本流 | 备选流1 | ||
场景3 | 基本流 | 备选流1 | 备选流2 | |
场景4 | 基本流 | 备选流3 | ||
场景5 | 基本流 | 备选流3 | 备选流1 | |
场景6 | 基本流 | 备选流3 | 备选流1 | 备选流2 |
场景7 | 基本流 | 备选流4 | ||
场景8 | 基本流 | 备选流3 | 备选流4 |
注:为方便起见,场景 五、6 和 8 只描述了备选流 3 指示的循环执行一次的状况。spa
1.根听说明,画出流程图,肯定基本流和备选流;设计
2.根据基本流和各项备选流肯定场景;3d
3.对每个场景生成测试用例;code
4.对生成的全部测试用例从新复审,去掉多余的测试用例,测试用例肯定后,对每个测试用例肯定测试数据值。
用户登陆到网站后,进行书籍的选择,当选好本身心仪的书籍后进行订购,这时把所需图书放进购物车,等进行结账的时候,用户须要登陆本身注册的账号,登陆成功后,进行付款交易,交易成功后,生成订购单,整个购物过程结束。
第一步:画出流程图,肯定基本流和备选流;
基本流:登陆在线网站→选择书籍→放入购物车→登陆帐号→付款→生成订单
备选流1:用户不存在→注册用户
备选流2:密码不正确
备选流3:帐户余额不足→充值
第二步:根据基本流和各项备选流肯定场景;
场景1(成功购物):基本流;
场景2(帐户不存在):基本流 备选流1
场景3(帐户密码错误):基本流 备选流2
场景4(帐户余额不足):基本流 备选流3
第三步:对每个场景生成测试用例;
第四步:对生成的全部测试用例从新复审,补充测试数据值;
基本流 | 本用例的开端是 ATM 处于准备就绪状态。 准备提款 - 客户将银行卡插入 ATM 机的读卡机。 验证银行卡 - ATM 机从银行卡的磁条中读取账户代码,并检查它是否属于能够接收的银行卡。 输入 PIN - ATM 要求客户输入 PIN 码(4 位) 验证账户代码和 PIN - 验证账户代码和 PIN 以肯定该账户是否有效以及所输入的 PIN 对该账户来讲是否正确。对于此事件流,账户是有效的并且 PIN 对此账户来讲正确无误。 ATM 选项 - ATM 显示在本机上可用的各类选项。在此事件流中,银行客户一般选择“提款”。 输入金额 - 要从 ATM 中提取的金额。对于此事件流,客户需选择预设的金额(10 美圆、20 美圆、50 美圆或 100 美圆) 。 受权-ATM 经过将卡 ID、PIN、金额以及账户信息做为一笔交易发送给银行系统来启动验证过程。对于此事件流,银行系统处于联机状态,并且对受权请求给予答复,批准完成提款过程,而且据此更新账户余额。 出钞 - 提供现金。 返回银行卡 - 银行卡被返还。 收据 - 打印收据并提供给客户。ATM 还相应地更新内部记录。 用例结束时 ATM 又回到准备就绪状态。 |
备选流 1 - 银行卡无效 | 在基本流步骤 2 中 - 验证银行卡,若是卡是无效的,则卡被退回,同时会通知相关消息。 |
备选流 2 - ATM 内没有现金 | 在基本流步骤 5 中 - ATM 选项,若是 ATM 内没有现金,则“提款”选项将没法使用。 |
备选流 3 - ATM 内现金不足 | 在基本流步骤 6 中- 输入金额,若是 ATM 机内金额少于请求提取的金额,则将显示一则适当的消息,而且在步骤 6 - 输入金额处从新加入基本流。 |
备选流 4 - PIN 有误 | 在基本流步骤 4 中- 验证账户和 PIN,客户有三次机会输入 PIN。 若是 PIN 输入有误,ATM 将显示适当的消息;若是还存在输入机会,则此事件流在步骤 3 - 输入 PIN 处从新加入基本流。 若是最后一次尝试输入的 PIN 码仍然错误,则该卡将被 ATM 机保留, 同时 ATM 返回到准备就绪状态,本用例终止。 |
备选流 5 - 账户不存在 | 在基本流步骤 4 中 - 验证账户和 PIN,若是银行系统返回的代码代表找不到该账户或禁止从该账户中提款,则 ATM 显示适当的消息而且在步骤 9 - 返回银行卡处从新加入基本流。 |
备选流 6 - 账面金额不足 | 在基本流步骤 7 - 受权中,银行系统返回代码代表账户余额少于在基本流步骤 6 - 输入金额内输入的金额,则 ATM 显示适当的消息而且在步骤 6 - 输入金额处从新加入基本流。 |
备选流 7 - 达到每日最大的提款 金额 |
在基本流步骤7- 受权中, 银行系统返回的代码代表包括本提款请求在内,客户已经或将超过在 24 小时内容许提取的最多金额,则 ATM 显示适当的消息并在步骤 6 - 输入金额上从新加入基本流。 |
备选流 x - 记录错误 | 若是在基本流步骤 10 - 收据中,记录没法更新,则 ATM 进入“安全模式”,在此模式下全部功能都将暂停使用。同时向银行系统发送一条适当的警报信息代表 ATM 已经暂停工做。 |
备选流 y - 退出 | 客户可随时决定终止交易(退出) 。交易终止,银行卡随之退出。 |
备选流 z - “翘起” | ATM 包含大量的传感器,用以监控各类功能,如电源检测器、不一样的门和出入口处的测压器以及动做检测器等。在任一时刻,若是某个传感器被激活,则警报信号将发送 给警方并且 ATM 进入“安全模式”,在此模式下全部功能都暂停使用,直到采起适当的重启/从新初始化的措施。 |
第一次迭代中,根据迭代计划,咱们须要核实提款用例已经正确地实施。此时还没有实施整个用例,只实 施了下面的事件流: 基本流 - 提取预设金额(10 美圆、20 美圆、50 美圆、100 美圆) 备选流 2 - ATM 内没有现金 备选流 3 - ATM 内现金不足 备选流 4 - PIN 有误 备选流 5 - 账户不存在/账户类型有误 备选流 6 - 账面金额不足 |
以从这个用例生成下列场景
场景1 - 成功的提款 |
基本流 |
|
场景2 - ATM 内没有现金 |
基本流 |
备选流2 |
场景3 - ATM 内现金不足 |
基本流 |
备选流3 |
场景4 - PIN 有误(还有输入机会) |
基本流 |
备选流4 |
场景5 - PIN 有误(再也不有输入机会) |
基本流 |
备选流4 |
场景 6 - 账户不存在/账户类型有误 |
基本流 |
备选流 5 |
场景 7 - 账户余额不足 |
基本流 |
备选流 6 |
表1-3 提款场景
注:为方便起见,备选流 3 和 6(场景 3 和 7)内的循环以及循环组合未归入上表。
对于这 7 个场景中的每个场景都须要肯定测试用例。能够采用矩阵或决策表来肯定和管理测试用例。下面显示了一种通用格式,其中各行表明各个测试用例,而各列则表明 测试用例的信息。本示例中,对于每一个测试用例,存在一个测试用例 ID、条件(或说明)、测试用例中涉及的全部数据元素(做为输入或已经存在于数据库中)以及预期结果。
经过从肯定执行用例场景所需的数据元素入手构建矩阵。而后,对于每一个场景,至少要肯定包含执行场景所需的适当条件的测试用例。例如,在下面的矩阵 中,V(有效)用于代表这个条件必须是 VALID(有效的)才可执行基本流,而 I(无效)用于代表这种条件下将激活所需备选流。下表中使用的“n/a”(不适用)代表这个条件不适用于测试用例。
表1-4 用例矩阵
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 |
警告消息,卡予保留,用例结束 |
在上面的矩阵中,六个测试用例执行了四个场景。对于基本流,上述测试用例 CW1 称为正面测试用例。它一直沿着用例的基本流路径执行,未发生任何误差。基本流的全面测试必须包括负面测试用例,以确保只有在符合条件的状况下才执行基本 流。这些负面测试用例由 CW2 至 6 表示(阴影单元格代表这种条件下须要执行备选流)。虽然 CW2 至 6 对于基本流而言都是负面测试用例,但它们相对于备选流 2 至 4 而言是正面测试用例。并且对于这些备选流中的每个而言,至少存在一个负面测试用例(CW1 - 基本流)。
每一个场景只具备一个正面测试用例和负面测试用例是不充分的,场景 4 正是这样的一个示例。要全面地测试场景 4 - PIN 有误,至少须要三个正面测试用例(以激活场景 4):
输入了错误的 PIN,但仍存在输入机会,此备选流从新加入基本流中的步骤 3 - 输入 PIN。
输入了错误的 PIN,并且再也不有输入机会,则此备选流将保留银行卡并终止用例。
最后一次输入时输入了“正确”的 PIN。备选流在步骤 5 - 输入金额处从新加入基本流。
注:在上面的矩阵中,无需为条件(数据)输入任何实际的值。以这种方式建立测试用例矩阵的一个优势在于容易看到测试的是什么条件。因为只须要查看 V 和 I(或此处采用的阴影单元格),这种方式还易于判断是否已经肯定了充足的测试用例。从上表中可发现存在几个条件不具有阴影单元格,这代表测试用例还不完 全,如场景 6 - 不存在的账户/账户类型有误和场景 7 - 账户余额不足就缺乏测试用例。
一旦肯定了全部的测试用例,则应对这些用例进行复审和验证以确保其准确且适度,并取消多余或等效的测试用例。
测试用例一经承认,就能够肯定实际数据值(在测试用例实施矩阵中)而且设定测试数据。
表1-5 实际用例
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 |
警告消息,卡予保留, 用例结束 |
以上测试用例只是在本次迭代中须要用来验证提款用例的一部分测试用例。须要的其余测试用例包括:
场景 6 - 账户不存在/账户类型有误:未找到账户或账户不可用
场景 6 - 账户不存在/账户类型有误:禁止从该账户中提款
场景 7 - 账户余额不足:请求的金额超出账面金额
在未来的迭代中,当实施其余事件流时,在下列状况下将须要测试用例:
无效卡(所持卡为挂失卡、被盗卡、非承兑银行发卡、磁条损坏等).
没法读卡(读卡机堵塞、脱机或出现故障).
账户已消户、冻结或因为其余方面缘由而没法使用.
ATM 内的现金不足或不能提供所请求的金额(与 CW3 不一样,在 CW3 中只是一种币值不足,而不是全部币值都不足).
没法联系银行系统以得到承认.
银行网络离线或交易过程当中断电.