The Object-Oriented Approach To Requirements
The Object-Oriented Approach To Requirements
The Object-Oriented Approach To Requirements
LECTURE 7:
The Object-Oriented Approach to
Requirements
1
Lecture Outline
Unified Modeling Language (UML)
Object-Oriented Requirements (OOR)
System Activities
Use Case Diagram
Activity Diagram
System Sequence Diagram
State Machine Diagram
Integrating Object-Oriented Models
2
Unified Modeling Language (UML)
By subsystem
By actor 8
Simple Use Case with an Actor
9
Use Case Diagram with
Automation Boundary and
Alternate Actor Notation
10
All Use Cases Involving Customer
as Actor
Direct access
to the system
11
A use case diagram
of the CSS for RMO
organizes by
subsystems
12
Use Cases of RMO Order Entry
Subsystem
15
Use Case Diagram vs. Structured
Techniques
• Objective of the use case diagram is to provide an overview of the
system (including actors and the functions they perform)
– A use case diagram is like a context diagram in the sense of
defining the scope of the system
– However, individual use cases appear more like a DFD fragment
in that they identify an individual function that the system must support
• Difference with structured techniques
– The use case diagram begins by defining the automation
boundary while in DFD this boundary is often not defined until the
entire process has been detailed
– In a DFD an external agent is always the original source or
destination of the information and may not necessarily be the one
interacting with the system;
– In a use case diagram, an actor is the one who actually
interacts with the system whether or not that actor is the original 16
source of information
Use Case Diagram vs. Structured
Techniques (cont’d)
Example: in the RMO case, a customer may call an RMO clerk
and make an order.
The DFD would identify the external entity as the customer;
the clerk’s activity would be embedded in a process “Enter
customer order”.
In the use case diagram, the clerk would be identified as the
actor who uses the system to enter or create a customer order
The use case diagram does not indicate data flows, i.e.
information flowing into and out of the system is not shown (this
is done with the next level of modeling – the sequence
diagrams)
Important to identify every possible role that will use the
system.
17
Developing a Use Case Diagram
Two main approaches to developing a use case diagram:
First approach: start with an event table and analyze each event to determine:
• How the system is used to support the event
• The actors who initiate the event
• Other use cases that will need to be invoked
• Generally, each event will become a use case
Second approach: identifying all the actors who use the system and the EBPs
with the user goal technique
Actors must actually contact the system
Assume perfect technology condition (no technical activities!)
Actors – are roles played by users (e.g., order clerk, manager)
Identify goal for each actor (e.g., “accept a return”)
18
Scenarios
• A use case only shows that an actor interacts with the system to carry
out a business activity
• There may be a whole series of individual steps to accomplish the use
case (these steps are described with a narrative called a flow of
activities) - steps within a use case
• A use case may have several alternative internal activities. In the
RMO example, for the use case “Create new order” there are at least
two sequences when:
– A customer creates telephone order through clerk (a clerk
interacts with the system), or
– A customer creates web order (a customer interacts with the
system)
• A particular sequence of activities within a use case is called
scenario. It represents a unique path through the use case
E.g., two possible scenarios for the RMO use case “Create new order”:
in the first instance, the second actor “Order clerk” is involved who is
actually interfacing with the system
19
Two scenarios for RMO
“Create new order”
20
Activity Diagrams
Used to document workflow of business process
activities for each use case or scenario
21
Activity
Diagram—
Telephone
Order
Scenario
22
Activity
Diagram—
Web Order
Scenario
23
Identifying Inputs and Outputs—
The System Sequence Diagram
Interaction diagram – a communication diagram or a
sequence diagram
System sequence diagram (SSD) is type of UML 2.0
interaction diagram
Used to model input and output messaging requirements
for a use case or scenario
Shows sequence of interactions as messages to/from actors
and internal objects during flow of activities
Emphasis: how the actor interacts with the system by
entering input data and receiving output data
Object notation instead of class notation is used to show
that message is sent to an individual object, not the class
System is shown as one object: a “black box”
24
Object and class names in SSD
25
SSD Notation
26
System Sequence Diagram (SSD)
Notation
27
SSD Notation
Activation line 28
SSD Lifelines
29
SSD Messages
31
Repeating
Message
32
Developing a System Sequence
Diagram
34
Resulting SSD for the Telephone
Order Scenario
35
SSD of the
Web Order
Scenario for
the Create
New Order
Use case
36
The relationship of use case
diagram, class diagram and
sequence diagrams
SSD includes objects from the class diagram and actors from the use
case diagram 37
Developing a System Sequence Diagram:
Steps
1. Identify all the objects and actors that are involved in the
scenario (they are only actors have been identified in the
use case diagram and objects from the classes that are
identified in the class diagram)
2. Based on the flow of activities, identify each message that
will be required to carry out the scenario along with both
source object (or actor) for the message and the destination
object (or actor)
3. Determine whether each message is always sent or sent only
under certain conditions
4. Sequence the messages correctly and attach them to the
appropriate lifelines of actors and objects
5. Add the formal syntax on the messages for conditions,
message names and passed parameters
6. Add response messages and communications 38
A complete
SSD for the
RMO use
case
Create new
order
39
Just for Fun!
http://www.visualjokes.com
40
Identifying Object Behaviour—
The State Machine Diagram (SMD)
SSDs give external view of object behaviour – messages
passed around but do not show, what an object does when it
gets a message
There is a need to specify internal logic for each object, i.e.,
a description of the actions that the objects perform
themselves
State machine diagram is UML a 2.0 diagram that models
object internal behaviour, states and transitions
Complex problem domain classes can be modeled
43
State Machine Terminology
45
Concurrent Paths for Printer in the
On State
46
Relationships among OO models 47
State Machine Diagram and SSD
49
States and Exit Transitions for
OrderItem
50
Partial State Machine for
OrderItem
51
Final State Machine for OrderItem
52
Order Domain Class for RMO—
States and Exit Transitions
53
First-Cut State Machine Diagram
for Order
54
Second-Cut State Machine
Diagram for Order
55
Integrating Object-Oriented
Models
Complete use case diagram is needed to
understand total scope of new system
Domain model class diagrams should also be as
complete as possible for entire system
With iterative approach, construct use case
descriptions, activity diagrams, and system
sequence diagrams for use cases in iteration
Development of a new diagram often helps refine
and correct previous diagrams
56
Relationships Between OO
Requirements Models
57
Readings
!!
u!
yo
nk
58