Use Cases - PowerPoint PPT Presentation

About This Presentation
Title:

Use Cases

Description:

Use cases address 'how to make functional requirements ... Jacobson invented 'uses' and 'extends' relations: when do you use each, how do you type it in? ... – PowerPoint PPT presentation

Number of Views:120
Avg rating:3.0/5.0
Slides: 46
Provided by: alistair67
Learn more at: https://ics.uci.edu
Category:
Tags: cases | use

less

Transcript and Presenter's Notes

Title: Use Cases


1
  • Use Cases
  • in Theory Practice

Alistair Cockburn Humans and Technology Salt Lake
City, UT arc_at_acm.org http//members.aol.com 801.9
47-9275
2
A use case tells a story of reaching a goal,or a
set of stories of both getting and failing.
  • UC 4 Place an order
  • 1. The clerk identifies the customer, each item
    and quantity.
  • 2. System accepts and queues the order.
  • Extensions
  • 1a. Low credit Clerk takes prepayment
  • 2a. Low on stock Customer accepts reduced...

3
Use cases address how to make functional
requirements readable, reviewable.
  • 1. Use cases hold functional requirements in an
    easy-to-read, easy-to-track, text format.
  • 2. A use case collects how a goal succeeds /
    fails a scenario shows one specific
    condition scenarios use cases nest.
  • 3. Use cases show only the Functional reqts.
  • 4. They make a framework for non-functional
    requirements project details.
  • 5. Design is not done only in use case
    increments.

4
The IT industry now loves use cases, but... how
do you write large volumes of them?
  • Common agreement that use cases are useful.
  • Adopted by every OO methodology
  • Repeated commendation from developers, users
  • But what are they really?
  • How do you structure 180 of them?
  • what is their format? level of detail?
  • Jacobson invented uses and extends relations
  • when do you use each, how do you type it in?

5
Many meanings of Use Case are around. This
model has both theory practice.
  • A workshop of 14 leading OO consultants had 14
    definitions of use case
  • Value user story / requirements
  • Structure none / semi-formal / formal
  • Content contradictory / consistent / formal
  • Scenario ? Use case same / different
  • Common agreement no standard form valuable

6
The model an interaction is a sequence or set of
possible sequences of interactions.
Actor 1
Actor 2
Interaction
Goal
Responsibility
Set of sequences
Sequence of Interactions
Single Message
Condition
Result
7
An actors action triggers an interaction,
calling upon another actors responsibility.
Actor
Internal
External
System in Design
Person
Group
Subsystem
System
Object
Interaction
Set of sequences
Sequence of Interactions
Single Message
Behavior
calls upon
Responsibility
Goal
Condition
Result
triggers
Action
8
The basic model of use cases is that Actors
interact to achieve their goals
Primary Actor person or system with goal for
s.u.d.
System under design could be any system
Secondary Actor other system against which
s.u.d. has a goal
Responsibility - Goal 1 - Goal 2 ...
action 1 . - backup
goal for Goal 2
(Interaction 1)
Responsibility - Goal 1 ...action 1
(Interaction 2)
Responsibility
9
Examing the Goals the system supports makes good
functional requirements.
  • Place an order.
  • Get money from my bank account.
  • Get a quote.
  • Find the most attractive alternative.
  • Set up an advertising program.
  • Goals summarize system function in
    understandable, verifiable terms of use.

10
Users, executives and developers appreciate
seeing requirements in the form of goals.
  • Users
  • We can understand what these mean
  • You mean we are going to have to ...?
  • Executives
  • You left out one thing here ...
  • Developers
  • These are not just a pile of paragraphs!

11
Structured narrative keeps the context visible,
the value to the user clear.
  • Compare just paragraphs
  • The order entry system has an interface to
    system EBMS and to a terminal.
  • It computes and displays the sum of the order
    items cost.
  • ...
  • With structured narrative
  • The orderer (EBMS or an entry person) identifies
    the name of the customer the items on the
    order.
  • The system displays the cost of the total order.
  • If the items are in stock and the client has
    sufficient credit, ...

When? How?
12
The use case pulls goal scenarios together,
Each scenario says how 1 condition unfolds.
  • The use case name is the goal statement
  • Order product from catalog
  • Scenario (1) Everything works out well ...
  • Scenario (2) Insufficient credit ...
  • Scenario (3) Product out of stock ...
  • Use case is goal statement plus the scenarios.
  • (Note the grammar active verb first)

13
The collected scenarios are like stripes on
trousers, with success and failure legs.
Goal Place order
Subgoal
...
sc1
sc2
sc6
sc7
sc3
sc4
sc5
Establish ... credit
S
S
F
S
F
S
F
S
F
F
... stock
S
F
(Success scenarios)
(Failure sc.)
14
How to do it(1). Identify the actors and their
goals.
  • What computers, subsystems and people will
    drive our system?
  • An actor is anything with behavior.
  • What does each actor need our system to do?
  • Each need shows up as a trigger to our system.
  • Result a list of use cases, a sketch of the
    system.
  • Short, fairly complete list of usable system
    function.

15
How to do it For each use case...(2). Write
the simple case goal delivers.
  • The main success scenario, the happy day case.
  • Easiest to read and understand.
  • Everything else is a complication on this.
  • Capture each actors intent and responsibility,
    from trigger to goal delivery.
  • Say what information passes between them.
  • Number each line.
  • Result readable description of systems function.

16
How to do it(3). Write failure conditions as
extensions.
  • Usually, each step can fail.
  • Note the failure condition separately, after the
    main success scenario.
  • Result list of alternate scenarios.

17
How to do it For each failure condition,(4).
Follow the failure till it ends or rejoins.
  • Recoverable extensions rejoin main course.
  • Non-recoverable extensions fail directly.
  • Each scenario goes from trigger to completion.
  • Extensions are merely a writing shorthand.
  • Can write if statements.
  • Can write each scenario from beginning to end.
  • Result Complete use case

18
How to do it(5). Note the data variations.
  • Some extensions are too low-level to cover
    here.
  • e.g. Reimburse customer
  • Reimburse by cash, check, EFT, or purchase
    credit?
  • Deferred variations note cases that must be
    handled eventually, by lower-level use cases.
  • Useful for tracking requirements at high level.
  • Result Feed-forward information, rolled up into
    an easy-to-track format.

19
An actor has goals goals name use cases a use
case has scenarios naming sub-use cases.
20
Review Make scenarios run from trigger event to
goal completion or abandonment.
  • UC 4 Place an order
  • Trigger the request (phone call, EDI, ...).
  • End order started or canceled.
  • Scenario Scenario Scenario all ok
    Insufficient No product
  • Start order. Refuse order Issue raincheck
    and forget. and forget.

(Use case in decision-table format)
21
The value of failure scenarios is detecting
unusual situations, completeness
  • What if their credit is too low?
  • What if they run over the extended credit
    limit?
  • What if we cannot deliver the quantity?
  • What if data is corrupt in the database?
  • (These are commonly overlooked situations)

22
Both recoverable and non-recoverable failures are
part of requirements.
  • Ideal situation (s1)
  • Good credit, items in stock -gt accept order.
  • Recoverable situation (s2, s3)
  • Low credit -gt valued customer? -gt accept.
  • Low stock -gt reduce quantity? -gt accept.
  • Unrecoverable situations (s4, s5)
  • Not a valued customer -gt decline order
  • Out of stock -gt decline order

23
Write the recoverable and failure scenarios as
extensions to the ideal one.
  • UC 4 Place an order
  • 1. Clerk identifies the customer, each item and
    quantity.
  • 2. System accepts and queues the order.
  • Extensions
  • 1a. Low credit Customer is Preferred...
  • 1b. Low credit not Preferred customer ...
  • 2a. Low on stock Customer accepts reduced...

24
A scenario refers to lower-level goals
subordinate use cases or common functions.
  • UC 4 Place an Order
  • 1. Identify customer (UC 41)
  • 2. ...
  • UC 41 Identify Customer
  • 1. Operator enters name.
  • 2. System finds near matches.
  • Extensions
  • 2a. No match found ...

Note the active verbs!
25
The outer use case only cares if the inner one
succeeds, avoiding proliferation.
UC 4 Place an Order 1. Identify customer
lt- (assumes success) 2. ... Extensions
1a. Customer not found lt- (does not care
why it failed, only if it is
recoverable)
26
Each scenario step is a sub-goal, hiding a nested
use case (striped trousers image).
Goal Place order
Subgoal
...
s1
s2
s6
s7
s3
s4
s5
Establish ... credit
S
S
F
S
F
S
F
..?S
F
F
... stock
S
F
(Success scenarios)
(Failure sc.)
27
Every sentence at every level is a goal.Use
cases are one sentence style repeated.
  • Goal Customer places an order.
  • how why
  • Step Customer prepays for the order.
  • how why
  • Substep Customer gives credit card number.

28
Strategic use cases, tasks, and subfunctions link
together as a graph.
  • Sailboat image User goals are at sea level.

project goal
Strategic Goals
white
advertise
order
invoice
blue
User Goals
place order
set up promotion
reference promotion
monitor promotion
create invoice
send invoice
indigo
Subfunctions
register user
identify promotion
identify customer
identify product
29
The use case goal level is higher than the
steps. They white to blue, indigo, black
Goal of use case
(white)
Goal of steps
Goal of use case
Why?
(blueuser goal)
Goal of steps
How?
(indigo)
(black)
30
Use cases nest by (level, scope, detail).Which
should you write in?
  • Level Why do we want this goal?
  • enter amount, to get , to buy lunch
  • (subfunction vs. task vs. strategic goal)
  • Scope Which system boundary do we mean?
  • The panel is part of the ATM, is part of the
    bank.
  • (internal vs. system vs. organization/corpora
    tion)
  • Detail Do we describe intent, or action detail?
  • hit number buttons to enter amount
  • (dialog description vs. semantic / intent)

31
Systems are recursive in nature, from enterprise
down to program modules.
32
Capture strategic task goals system
corporate scope capture intent (semantics).
(strategic, corp., semantic)
(task, system, dialog)
corp.
cust.
Trade money for goods.
Program subsystem
Go to next entry field
(task, system, semantic)
(task, internal, semantics)
Program subsystem
order (p1, p2)
Enter order
33
Goals make a good structure on which to hang
requirements project details.
  • Some requirements are not in the use cases
  • Performance, delivery time window.
  • Interface and business rule usage
  • Project planning capitalizes on goal structure
  • (Useable) Releases.
  • Priorities, schedule, staffing.
  • Growth of the somponent base.

34
Unresolved scheduling problem system features
slice and cross use cases
  • Example
  • 1. Place an order - using standard pricing.
  • 2. Place an order - using Preferred pricing.
  • 3. Place an order - do not check credit limit.
  • With full use case / feature -gt use case
    explosion.
  • Use case for many features -gt scheduling
    difficulty.
  • ( Still looking for a way to avoid use case
    duplication. )

35
Use cases do not show interface requirements.
Collect them by use case.
Use case
Form
Out
In
set up promotion
new promotion
on-line
products, dates
promotion value
reference promotion
on-line
promotion
customer, products, ...
enter an order
on-line
new order
create an invoice
database
order number
new invoice
paper or EDI
send an invoice
tape
invoice
36
Use cases do not capture performance
requirements. Connect them to use cases.
...
Use case
Frequency
Performance
set up promotion
10 / mo
interactive
reference promotion
500 / day
sub-second
enter an order
interactive
80 / day
create an invoice
3 seconds
80 / dy
send an invoice
1600/mo
420/hr (10 sec.)
37
Use cases do not collect formulae, state,
cardinality. Capture them separately.
  • ... in any form available (just a tool problem)
  • Examples
  • 1. Order sum order item costs 1.06 tax
  • 2. Promotions may not run longer than 6 months.
  • 3. Customers only become Preferred after an
    initial 6 month period.
  • 4. A customer has one and only one sales contact.
  • 5. An order item may use many promotions.

38
Need a list of actual clients of each use case,
for use in packaging and training.
Use case
Users
set up promotion
Marketing managers
reference promotion
Managers, order clerks, other subsystems
enter an order
Managers, order clerks, other subsystems
create an invoice
Managers, invoicing subsystem
send an invoice
Managers, invoicing subsystem
39
Project management Schedule releases by
clusters of use cases.
  • Release 1
  • (12) Set up reference promotion
  • (4) Enter order
  • Release 2
  • (5) Create invoice
  • (3) Monitor promotion
  • Release 3
  • (6) Send invoice

40
Use cases can be managed in text, in Lotus Notes,
or in use case OO database.
  • Group 1 Tried Word / Wordperfect
    (unsatisfactory)
  • Hard to share, hard to modify format.
  • Group 2 Used Lotus Notes (good)
  • Excellent for sharing, evolving format, data.
  • Contents slowly became inconsistent.
  • Group 2 converting to Intelligent Software
    Factory
  • Has places for performance, etc. (like
    L.Notes)
  • OODB with semantic model, consistency, etc.

41
Now for Design Scenarios provide the basis for
design with responsibilities.
  • Responsibility-based design is based on
    role-playing a walkthrough of a scenario.
  • Multiple scenarios provide the basis for
    asserting that the design delivers the required
    function.
  • Use of failure scenarios make the design complete
    robust.

42
Designers can use the scenarios directly to
design the system.
What if...?
Scenarios
Knows how to...
Knows how to...
Knows how to...
43
Robust design requires examining use cases out of
schedule sequence.
  • A new use case may add to existing classes.
  • -gt Harder to schedule class design milestones.
  • -gt The object model is never complete, only
  • complete with respect to these use
    cases.
  • New use cases may change optimal design
  • -gt Use all use cases or do incremental design?
  • Just make sure someone is responsible for
    delivering the total function.

44
Visit http//members.aol.com/acockburn to read
more on use cases.
  • 1. Use cases hold functional requirements in an
    easy-to-read, easy-to-track, text format.
  • 2. A use case collects how 1 goal succeeds or
    fails a scenario shows one specific
    condition scenarios / use cases nest
    inside each other.
  • 3. Use cases show only the Functional reqts.
  • 4. They make a framework for non-functional
    requirements project details.
  • 5. Design is not done only in use case
    increments.

45
The system protects the interests of all the
stakeholders.
The stakeholders want ...
Enter order
System under Design
The primary actor wants...
Write a Comment
User Comments (0)
About PowerShow.com