FROM USE CASES TO TEST CASES

-Test note of “Essential Software Test Design”

2015-08-31

Content:

12.1 What are Use Cases?
12.2 Use cases
  12.2.1 Example: Use Case – Withdraw Money
12.3 The Model – Compiling the Flow Graph
12.4 Creating Base Test Cases
  12.4.1 List All Scenarios

TO DESCRIBE THE requirements on a system, a technique is often used which is called use cases.

12.1 What are Use Cases?


Top

Use cases are a step-by-step description of a flow, where an actor interact with a system. An actor may be one of a number of different user types, the system itself, or other external systems.

The commonest flow – normal use – is called the main flow (also called the normal flow or Happy Path) and variations of this are termed alternative flows.

The overarching work procedure is this:

  1. Compile an activity diagram. If this is already in place, the first step is to review it.
  2. List all scenarios
  3. Analyze and prioritize the scenarios according to risk – which are most important, commonest
  4. Identify the operational variables which can affect the expected result
  5. Write one or more test cases for each scenario

12.2 Use cases


Top

Let us go back to the example of an ATM machine. A simple use case may look like this:

12.2.1 Example: Use Case – Withdraw Money

Assumptions:

  • The customer’s bank is one which is connected to the ATM system.
  • The customer has a correct and functioning magnetic strip card.
  • The ATM is switched on and is in ready mode.
  • The ATM is situated in Sweden so all withdrawals will be in swedish crowns,
  • SEK, and bills that can be withdrawn are 100 or 500 only.

Actors

  • Customer
  • ATM (network)
Main Flow:

H-1. The use case begins when the customer inserts the card.

H-2. The ATM verifies the card and requests the PIN number.

H-3. The customer types in the correct PIN (4 digits).

H-4. The ATM verifies the PIN and asks the customer to type in an amount.

H-5. The customer types in the amount (100-2000 SEK manually or by using the multiple choice keys).

H-6. The ATM verifies that the amount is available in the customer’s account and ejects the card, the money and the receipt, and registers the transaction in the customer’s account.

H-7. The customer takes the card, the money and the receipt.

H-8. The ATM returns to standby mode.

H-9. End of use case.

Results

The customer has carried out a successful withdrawal of money.

The customer’s account is updated with the transaction.

Alternative Flows

Alternative flow – A1 Invalid card

A1-1. At step H-1, the customer inserts an invalid card.

A1-2. The ATM aborts the transaction and the card is ejected.

Alternative flow – A2 Wrong PIN

A2-1. At step H-3, the customer types in the wrong PIN.

A2-2. The ATM registers an incorrect PIN and asks the user to try again.

A2-3. The use case continues with step H-3.

Alternative flow – A3 Wrong PIN, 3 times

A3-1. At step H-3, the customer types in the wrong PIN three times in a row.

A3-2. The ATM swallows the card and the transaction is aborted.

A3-3. End of use case.

Alternative flow – A4 Incorrect input of amount

A4-1. At step H-5, the customer makes an incorrect entry (not divisible by a hundred, funds are not in the account, exceeds permitted maximum withdrawal…)

A4-2. The ATM disallows the entered amount and asks the user to try again.

A4-3. The use case continues with step H-5.

Alternative flow – A5 Customer does not take the money

A5-1. At step H-7, the customer takes the card, but not the money or the receipt within 20 seconds.

A5-2. The ATM leaves the receipt hanging out of the machine and retracts the money, places it in a separate container and writes the amount, account number and cause of defect into a defect log.

A5-3. The use case continues with step H-8.

Alternative flow – A6 The customer’s bank is not on-line (other than Handelsbanken)

A6-1. At step H-6, the ATM cannot verify whether the amount is available in the customer’s account. A message shows that contact with the customer’s bank is being established and the card is ejected.

A6-2. The use case continues with step H-8.

Alternative flow – A7 Customer aborts the withdrawal

A7-1. At all times in the Main flow, apart from steps H-6 and H-7, the customer can choose to abort the transaction

A7-2. The ATM aborts the transaction and ejects the card, and no withdrawal is recorded on the customer’s account.

A7-3. The use case continues with step H-8.

12.3 The Model – Compiling the Flow Graph


Top

If there is not one already, you compile a flow diagram based on the use case.

Figure 12.1: Activity diagram of the flow in the use case «Withdraw Money». We have a starting point but several different end points, with different results.

12.4 Creating Base Test Cases


Top

12.4.1 List All Scenarios

To cover the graph, we generate base test cases for the different flows at hand

  1. Start with the Main flow, which you use for the Happy Day test.
  2. Continue with the alternative flows – one at a time.
  3. There are different combinations of alternative flows. It is not always possible to draw up all the combinations: there may be infinite loops.

FROM USE CASES TO TEST CASES的更多相关文章

  1. USER STORIES AND USE CASES - DON’T USE BOTH

    We’re in Orlando for a working session as part of the Core Team building BABOK V3 and over dinner th ...

  2. 深入理解openstack网络架构(2)----Basic Use Cases

    原文地址: https://blogs.oracle.com/ronen/entry/diving_into_openstack_network_architecture1 译文转自: http:// ...

  3. Security Test Cases

    https://www.owasp.org/index.php/OWASP_Testing_Guide_v4_Table_of_Contents Username Enumeration Vulner ...

  4. SSAS CUBE TEST CASES

    经过周末两天和今天的努力,基本上完成并修复了一些bug并且集成到我的MSBIHelper项目中去,可以进行数据测试了.效果图如下: 可以帮助开发人员快速生成等值的Tsql和mdx查询,辅助测试人员快速 ...

  5. 算法最坏,平均和最佳情况(Worst, Average and Best Cases)-------geeksforgeeks 翻译

    最坏,平均和最佳运行时间(Worst, Average and Best Cases) 在上一篇文章中,我们讨论到了渐进分析可以解决分析算法的问题,那么在这一篇中,我们用线性搜索来举例说明一下如何用渐 ...

  6. As of ADT 14, resource fields cannot be used as switch cases

        在导入Android Sample的ApiDemos的时候,发现R.id.xx的文件不能够在 switch cases 中使用 在google查询了下,找到以下答案: As of ADT 14 ...

  7. Unsupervised Learning: Use Cases

    Unsupervised Learning: Use Cases Contents Visualization K-Means Clustering Transfer Learning K-Neare ...

  8. MapReduce 模式、算法和用例(MapReduce Patterns, Algorithms, and Use Cases)

    在新文章“MapReduce模式.算法和用例”中,Ilya Katsov提供了一个系统化的综述,阐述了能够应用MapReduce框架解决的问题. 文章开始描述了一个非常简单的.作为通用的并行计算框架的 ...

  9. Cannot declare class app\home\controller\Cases because the name is already in use

    Cannot declare class app\home\controller\Cases because the name is already in use 命名空间冲突了 use 模型类的时候 ...

随机推荐

  1. windows server 2003 安全加固(一)

    windows server 2003 安全加固 加固主要在如下方面 A 升级系统补丁 B NTFS权限合理设置 C 关闭不需要的服务 D 关闭不需要的端口 E 帐号和密码管理 F 开启安全策略 G ...

  2. 【java并发核心二】Exchanger的使用

    类 Exchanger 的功能可以使2个线程之间传输数据,比生产者/消费者模式方便. Exchanger类的结构很简单,重点就是exchange()方法. exchange()方法是阻塞执行的,可以设 ...

  3. 13,EasyNetQ-错误条件

    在本节中,我们将看看任何消息系统中可能出现的各种错误情况,并查看EasyNetQ如何处理它们. 1,我的订阅服务死亡 你已经写了一个订阅了我的NewCustomerMessage的windows服务. ...

  4. L1 与 L2 正则化

    参考这篇文章: https://baijiahao.baidu.com/s?id=1621054167310242353&wfr=spider&for=pc https://blog. ...

  5. 51Nod.1237.最大公约数之和 V3(莫比乌斯反演 杜教筛 欧拉函数)

    题目链接 \(Description\) \(n\leq 10^{10}\),求 \[\sum_{i=1}^n\sum_{j=1}^ngcd(i,j)\ mod\ (1e9+7)\] \(Soluti ...

  6. Putty 工具使用

    如何使用Putty远程(SSH)管理Linux VPS Putty是一个免费的.Windows 32平台下的telnet.rlogin和ssh客户端,但是功能丝毫不逊色于商业的telnet类工具.用它 ...

  7. android studio 中去除应用标题栏

    android studio 中去除应用标题栏 ㈠ ⒈ mainifests中设置: android:theme="@style/AppTheme"(即默认设置). ⒉ value ...

  8. STL——配接器、常用算法使用

    学习STL,必然会用到它里面的适配器和一些常用的算法.它们都是STL中的重要组成部分. 适配器 在STL里可以用一些容器适配得到适配器.例如其中的stack和queue就是由双端队列deque容器适配 ...

  9. Redis 中 5 种数据结构的使用场景介绍

    这篇文章主要介绍了Redis中5种数据结构的使用场景介绍,本文对Redis中的5种数据类型String.Hash.List.Set.Sorted Set做了讲解,需要的朋友可以参考下 一.redis ...

  10. 8-06. 畅通project之局部最小花费问题(35)(最小生成树_Prim)(ZJU_PAT)

    题目链接:http://pat.zju.edu.cn/contests/ds/8-06 某地区经过对城镇交通状况的调查.得到现有城镇间高速道路的统计数据,并提出"畅通project" ...