指南: 测试用例主题解释
| |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| 场景 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,执行基本流 |
| TC z | 场景 4 | 步骤 2 - 提款金额 = 帐户余额 | 不执行备选流 3,执行基本流 |
注:由于没有提供其他信息,以上显示的测试用例都非常简单。测试用例很少如此简单。
下面是一个由用例生成测试用例的更符合实际情况的示例。
示例:

一台 ATM 机器的主角和用例。
下表包含了上图中提款用例的基本流和某些备用流:
| 基本流 | 本用例的开端是 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 进入“安全模式”,在此模式下所有功能都暂停使用,直到采取适当的重启/重新初始化的措施。 |
|
|
|
可以从这个用例生成下列场景
| 场景 1 - 成功的提款 | 基本流 | |
| 场景 2 - ATM 内没有现金 | 基本流 | 备选流 2 |
| 场景 3 - ATM 内现金不足 | 基本流 | 备选流 3 |
| 场景 4 - PIN 有误(还有输入机会) | 基本流 | 备选流 4 |
| 场景 5 - PIN 有误(不再有输入机会) | 基本流 | 备选流 4 |
| 场景 6 - 帐户不存在/帐户类型有误 | 基本流 | 备选流 5 |
| 场景 7 - 帐户余额不足 | 基本流 | 备选流 6 |
注:为方便起见,备选流 3 和 6(场景 3 和 7)内的循环以及循环组合未纳入上表。
对于这 7 个场景中的每一个场景都需要确定测试用例。可以采用矩阵或决策表来确定和管理测试用例。下面显示了一种通用格式,其中各行代表各个测试用例,而各列则代表测试用例的信息。本示例中,对于每个测试用例,存在一个测试用例 ID、条件(或说明)、测试用例中涉及的所有数据元素(作为输入或已经存在于数据库中)以及预期结果。
通过从确定执行用例场景所需的数据元素入手构建矩阵。然后,对于每个场景,至少要确定包含执行场景所需的适当条件的测试用例。 例如,在下面的矩阵中,V(有效)用于表明这个条件必须是 VALID(有效的)才可执行基本流,而 I(无效)用于表明这种条件下将激活所需备选流。下表中使用的“n/a”(不适用)表明这个条件不适用于测试用例。
| 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):
注:在上面的矩阵中,无需为条件(数据)输入任何实际的值。以这种方式创建测试用例矩阵的一个优点在于容易看到测试的是什么条件。由于只需要查看 V 和 I(或此处采用的阴影单元格),这种方式还易于判断是否已经确定了充足的测试用例。从上表中可发现存在几个条件不具备阴影单元格,这表明测试用例还不完全,如场景 6 - 不存在的帐户/帐户类型有误和场景 7 - 帐户余额不足就缺少测试用例。
一旦确定了所有的测试用例,则应对这些用例进行复审和验证以确保其准确且适度,并取消多余或等效的测试用例。有关详细信息,请参见检查点: 测试用例。
测试用例一经认可,就可以确定实际数据值(在测试用例实施矩阵中)并且设定测试数据(关于测试数据的详细信息,请参见指南: 测试数据)。
| 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 | 警告消息,卡予保留,用例结束 |
以上测试用例只是在本次迭代中需要用来验证提款用例的一部分测试用例。需要的其他测试用例包括:
在将来的迭代中,当实施其他事件流时,在下列情况下将需要测试用例:
在确定功能性测试用例时,确保满足下列条件:
关于测试数据的其他信息,另请参见指南:测试数据。
并不是所有的测试目标需求都将在用例中有所反映。 非功能性需求(如性能、安全性和访问控制)以及配置要求等将会说明测试目标的其他行为或特征。补充规约是为其他行为生成测试用例的主要来源。
关于如何生成这些其他测试用例的指南说明如下:
性能测试用例的主要输入是补充规约,补充规约中包含了非功能性需求(请参见工件: 补充规约)。为性能测试生成测试用例时,请使用下列指南:
与功能性测试的测试用例类似,通常对于每个用例/需求都会存在不止一个测试用例。常见的情况是:存在一个低于性能阈值的测试用例、一个处于阈值上的测试用例,还有一个测试用例高于阈值。
除了以上性能标准以外,确保已确定影响响应时间的特定条件,包括:
将用于性能测试的测试用例记录在类似于功能测试所使用的矩阵中。
关于测试数据的其他信息,另请参见指南:测试数据。
以下是各种性能测试的一些示例:
对于负载测试:
| TC(测试用例)ID 号 | 工作量 | 条件
|
预期结果 |
| PCW1. |
1 (单个 ATM) |
完成提款交易 |
全部交易(不依赖于主角的时间)在 20 秒之内完成 |
| PCW2. |
2 (1,000 个同时运行的 ATM) |
完成提款交易 |
全部交易(不依赖于主角的时间)在 30 秒之内完成 |
| PCW3. |
3 (10.000 个同时运行的 ATM) |
完成提款交易 |
全部交易(不依赖于主角的时间)在 50 秒之内完成 |
对于强度测试:
| TC(测试用例)ID 号 | 工作量 | 条件
|
预期结果 |
| SCW1. |
2 (1,000 个同时运行的 ATM) |
数据库锁定 - 2 个 ATM 请求同一帐户 |
ATM 请求排成队列 |
| SCW2. |
2 (1,000 个同时运行的 ATM) |
无法实现银行系统的通信 |
交易排成队列或超时 |
| SCW3. |
2 (1,000 个同时运行的 ATM) |
在交易过程中,银行系统通信被终止 |
显示警告消息 |
主角和用例一同说明系统外部用户与系统所执行的动作之间的交互,以便为特定主角生成测试结果。复杂系统包含许多主角,所以我们编制测试用例时必须确保只有指定执行用例的主角可以进行此操作,这一点非常关键。在基于主角类型的用例事件流存在差别时,尤其如此。
例如,在 ATM 用例中,如果主角“银行客户”的卡和帐户有的属于拥有这个 ATM 机的银行,有的是竞争银行的银行卡(和帐户),或是企图使用该 ATM 不支持的银行卡,则将对该主角“银行客户”执行不同的用例事件流。
对于功能性测试用例,请同样遵循上面列举的指南。
关于测试数据的其他信息,另请参见指南:测试数据。
关于安全性和访问控制测试用例的示例:
| TC(测试用例)ID 号 | 条件 | 卡
(V 表明卡有效) |
读卡机
(V 表明读卡机工作正常) |
银行的网络 | 预期结果 |
| ACW1. | 在银行网络之内 | V | V | V | 所有用例都可用 |
| ACW2. | 银行网络之外 | V | V | I | 只有提款用例可用 |
| ACW3. | 无法读卡 | I | V | V | 警告消息,卡被退出 |
| ACW4. | 因被盗,卡已挂失 | I | V | V | 警告消息,卡予保留 |
| ACW5. | 卡已过期 | I | V | V | 警告消息,卡予保留 |
在典型的分布式系统中,允许存在许多种受支持的硬件和软件组合。为了核实测试目标在不同的配置情况下(如不同的操作系统、浏览器或 CPU 的速度)能否正常工作或执行,应该对此进行测试。此外,测试还应涵盖构件的组合,以便检测在不同构件的交互中产生的缺陷。例如,确保由应用程序安装的 DDL 版本不会与另一个应用程序需要的相同 DDL 的版本发生冲突。
采用下列指南来生成用于配置测试的测试用例:
安装测试需要核实测试目标可以在所有可能的安装情况下安装。安装情况可以指首次安装测试目标,或是在装有较早版本的机器上安装测试目标的某个较新的版本或工作版本。 安装测试还应确保在遇到异常情况时(如磁盘空间不足),测试目标的执行情况仍可接受。
测试用例应包含以下各种软件的安装情况:
客户机服务器软件的安装程序具备一组特定的测试用例。不同于基于主机的系统,服务器和客户机上的安装程序是有所不同的。因而,安装测试应执行构成测试目标的所有构件的安装,包括客户机、中间层以及服务器,这一点至关重要。
理论上,应找到所有必需的输入来生成测试用例模型、设计模型以及补充规约工件的测试用例。 不过,如果此时您需要补充已有的输入,那也不足为奇。
示例如下:
大多数情况下,您可以通过先前所确定的测试用例生成的某些测试用例来构建其变体或聚合关系体,借此来查找测试用例。
单元测试要求既测试单元的内部结构同时还要测试其行为特征。测试内部结构要求了解实施单元的方式,基于这种了解的测试被称为白盒测试。对单元行为特征的测试侧重于从外部可观察的单元行为,而不需要了解或考虑其实施方式。基于这种方法的测试称为黑盒测试。基于这两种方法所生成的测试用例的说明如下。
理论上,应通过代码测试每一条可能的路径。 在所有这些非常简单的单元内实现这样的目标是不切实际或几乎是不可能的。作为最基本的测试,应将每个决定到决定路径(DD 路径)测试至少一次,这样可确保将所有语句至少执行一次。决定通常是指 if 语句,而 DD 路径是两个决定之间的路径。
要达到这种程度的测试覆盖,建议您在选择测试数据时应使每个决定都可以用每种可能的方法来评估。为达到上述目标,测试用例应确保:
可使用代码覆盖工具来确定白盒测试未测试到的代码。在进行白盒测试的同时应进行可靠性测试。
示例:
假设您对类 Set of Integers 中的 member 函数执行结构测试。该测试在二进制搜索的帮助下,将检查该集合是否包含了某个指定的整数。

成员 (member) 函数以及相应的流程图。 虚线箭头指示出如何通过采用两个测试用例将所有语句至少执行一次。
理论上,对于彻底测试的某个操作,测试用例应遍历代码内路径的所有组合情况。在 member 函数的 while-loop 中存在三个可选择的路径。测试用例可以多次遍历该循环,或是根本就不遍历。如果测试用例根本就没有遍历循环,则在代码中只能找到一条路径。如果遍历循环一次,您将发现有三条路径。如果遍历两次,则您将发现存在六条路径,如此类推。因而,路径的总数应该是:1+3+6+12+24+48+...,在实际情况中,这个路径组合总数根本无法无法处理。这就是为什么必须选择所有这些路径的子集的原因。本示例中,可以采用两个测试用例来执行所有的语句。其中一个测试用例中,您可以选择 Set of Integers = {1,5,7,8,11},而且测试数据 t = 3。在另一个测试用例中,您可以选择 Set of Integers = {1,5,7,8,11},且 t = 8。
有关其他信息,请参见指南:单元测试。
黑盒测试的目的是为了在不了解单元将如何实施指定行为的情况下,对指定行为进行验证。 黑盒测试侧重并依赖于单元的输入和输出。
等价类划分是一种用来减少所需测试数量的技术。对于每一个操作都应确定参数和对象状态的等价类。等价类是一组值的集合,对这组值来说,对象的行为应类似。例如,一个集合可有三个等价类:空、若干元素以及满。
可使用代码覆盖工具来确定白盒测试未测试到的代码。在进行黑盒测试的同时应进行可靠性测试。
接下来的两个小节说明了如何通过选择特定参数的测试数据来确定测试用例。
输入参数是由某个操作使用的参数。对于以下每个输入条件,都应通过使用每个操作的输入参数来编制测试用例:
请记住要将对象状态视作输入参数。例如:如果在对集合这个对象测试添加操作,您必须使用集合内所有等价类的值来测试添加操作。所有等价类的值指的是:充满元素的集合、有若干元素的集合、以及空集合。
输出参数是某个操作所改变的参数。 某个参数既可以是输入参数也可以是输出参数。根据以下每个条件选择输入,以便获得输出。
请记住将对象状态视为输出参数。例如,假设您对某个列表测试删除操作,您必须选择输入值以便执行操作之后,列表为充满状态、具有若干元素或为空(采用它的所有等价类的值进行测试)。
如果对象受状态控制(根据对象的状态产生不同的反应),您应利用状态矩阵,如下图所示:

用于测试的状态矩阵。您可以在此矩阵的基础上测试激励和状态的所有组合。
有关其他信息,请参见指南:单元测试。
产品验收测试是部署软件前的最后测试操作。验收测试的目标在于核实软件是否已经准备就绪,而且可以由最终用户按软件设计来执行功能和任务。产品验收测试通常不仅涉及执行软件以确认其是否准备就绪,还涉及交付给客户的所有产品工件,如培训、文档和包装。
为软件工件生成测试用例是按上文中说明的方式实现的。测试用例可与上面确定的测试用例(正式)或某个子集(非正式)相同或类似,这取决于产品验收测试的正式程度。不管测试用例的深度如何,应该在实施和执行产品测试之前对测试用例和产品验收计划达成共识。
对非软件工件的评估将随着被评估工件的不同而相去甚远。请参见每个特定非软件工件的指南以及核对清单,查看这些工件的评估内容和评估方式。
回归测试比较同一测试目标的两个工作版本或版本,并将差异确定为潜在缺陷。据此可假定:新版本应该象早先版本一样操作,并确保并未因为版本的变化而带来缺陷。
理想状态下,您可能希望一次迭代内的所有测试用例都能在后续迭代内使用。应遵照下列指导原则来确定、设计并实施测试用例,这些测试用例可以最大限度地发挥回归测试和复用的价值,同时将维护的成本减至最低:
© 1987 - 2001 Rational Software Corporation。版权所有。
![]()
|
Rational Unified Process |