Most efficient way to write use cases
Because use cases model requirements, they are highly dynamic by nature. The more we examine a requirement, the more we
learn, and the more things change. To further complicate the issue, changes to one use case can lead to changes in
others. Therefore, we want a flexible, highly efficient method for writing use cases that eliminates unnecessary work
and rewriting.
An iterative, breadth-first approach, in which the use case is continuously evaluated before adding detail, is an
effective way to write use cases. This breadth-first approach involves two aspects: writing the set of use cases and
writing individual use cases.
Writing sets of use cases: Use cases exist in sets, and the relationships between the various use
cases and Actors are important. As you learn more about the Actors, you also learn more about the system's
boundaries and transactions. Likewise, as you learn more about the system's transactions, you learn more about its
Actors. Therefore, it is more efficient to write several use cases simultaneously than to write them sequentially. This
way, you can identify and understand the effects of the various use cases upon each other as you write them, rather
than as afterthoughts that require rewriting or elimination of previous work.
Writing individual use cases. Similarly, it makes sense to write each individual use case iteratively.
Starting with the main scenario, you can then identify various alternative and error flows that the use case might
follow, then evaluate, rearrange or eliminate them, and then add the details of the surviving scenarios.
The level of detail that you capture depends on a number of factors. See Guideline: Use Case Formats for guidance on selecting the correct format for your
use cases.
Detail the flow of events of the main scenario
As a starting point, use the step-by-step description of the main scenario that you created during Task: Find and Outline Requirements. Then, gradually add details to this scenario,
describing what the use case does, not how to solve problems internal to the system.
A flow of events description explores:
-
How and when the use case starts
-
When the use case interacts with the Actors, and what data they exchange
-
When the use case uses data stored in the system or stores data in the system
-
How and when the use case ends
It does not describe:
-
The GUI
-
Technical details of hardware or software
-
Design issues
Identify alternate flows
A use case consists of a number of scenarios, each representing specific instances of the use case that correspond to
specific inputs from the Actor or to specific conditions in the environment. Each scenario describes alternate ways
that the system provides a behavior, or it may describe failure or exception cases.
As you detail the main scenario, identify alternate flows by asking these questions:
-
Are there different options available, depending on input from the Actor? (for example, if the Actor enters an
invalid PIN number while accessing an ATM)
-
What business rules may come into play? (for instance, the Actor requests more money from the ATM than is available
in her account)
-
What could go wrong? (such as no network connection available when required to perform a transaction)
It is best to develop these scenarios iteratively, as well. Begin by identifying them. Examine each possible scenario
to determine whether it is relevant, that it can actually happen, and that it is distinct from other scenarios.
Eliminate redundant or unnecessary scenarios, and then start elaborating on the more important ones.
Structure the use case
It is useful to structure the use case according to scenarios. This helps both to simplify communication and
maintenance and to permit the use cases to be implemented iteratively.
In addition to structuring the use cases according to scenarios, it is often useful to structure the scenarios
themselves into sub-flows. This provides an additional level of granularity for planning work and tracking progress.
Unless a sub-flow involves only a minor part of the complete flow of events (which can be described in the body of the
text), it is recommended that you describe each sub-flow in a separate section to the Flow of Events section. Sub-flows
that should be in a separate section include these examples:
-
Sub-flows that occupy a large segment of a given flow of events.
-
Exceptional and alternate flows of events. This helps the use case's basic flow of events to stand out more
clearly.
-
Any sub-flow that can be executed at several intervals in the same flow of events.
For more information, see the "Flow of Events - Structure" section in Concept: Use Case.
Describe special requirements
You should also capture any requirements that are related to the use case, but are not taken into consideration in the
flow of events of the use case. Such requirements are likely to be nonfunctional.
Typically, nonfunctional requirements that refer to a specific use case are captured in the special requirements
section of the use case. For more information, see the "Special Requirements" section in Concept: Use Case.
If there are nonfunctional requirements that apply to more than one use case, capture these in the Artifact: Supporting Requirements. For more information on supporting requirements
see Concept: Supporting Requirements.
Describe preconditions and postconditions
A precondition on a use case explains the state that the system must be in for the use case to be able
to start. Be careful in describing the system state. Avoid describing the detail of other, incidental activities that
may already have taken place.
A postcondition on a use case lists possible states that the system can be in at the end of the use
case execution. The system must be in one of those states. A postcondition also states actions that the system performs
at the end of the use case, regardless of what occurred in the use case.
Neither preconditions nor postconditions should be used to create a sequence of use cases. As a general rule, there
should never be a case where you have to first perform one use case and then another to have a meaningful flow of
events. If that is the case, correct the problem by reviewing the use cases. For more information, see the
"Preconditions" and "Postconditions" sections in Concept: Use Case.
|