Analysis and Design - Overview

advertisement
Use-Case Analysis
Analyze the requirements to discover what the
system objects are
These slides capture the use-case analysis activity
of the Rational Unified Process
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 1
Material © IBM Rational Software
Use-Case Analysis


Use-case analysis is where the requirements meet objectorientation
 Recall: in the Unified Process, the use-case model is the
primary artifact in the requirements model
 In use-case analysis, identify the classes which perform a
use-case flow of events
 Distribute the use-case behavior to those classes
 Identifying the responsibility of the classes
 Develop use case realizations that model the
collaborations between instances of the identified classes
 How the class instances work together to deliver the
requirements
The result is a first-draft, rough-cut of the system object model
 An abstraction of the design model; refined during design
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 2
Material © IBM Rational Software
Review: Use-Case Realization
Use Case
Use-Case Realization
Class
diagram
Use
Cases
Sequence
diagrams
<<trace>>
Use Case Specification

A use-case realization is a description of
how a particular use case is realized within
the design model, in terms of collaborating
objects
 It is one possible realization,
corresponding to a specific selection
among design options
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 3
Communication
diagrams
Material © IBM Rational Software
Use-Case Analysis
Supplementary
Specification
Software
Architecture
Document
(Use-case View)
Instantiate the
activity once
per use case
Analysis
Classes
Use-Case Realization
(Preliminary)
Use-Case
Analysis
Glossary
Use-Case Realization
(Identified)
Analysis Model
(Updated)
Use-Case Model
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 4
Material © IBM Rational Software
Use-Case Analysis - Steps





Supplement the Use-Case Description
For each use-case realization
 Find classes from use-case behavior
 Distribute use-case behavior to classes
For each resulting analysis class
 Describe responsibilities
 Describe attributes and associations
 Qualify architectural analysis mechanisms
Unify analysis classes
Checkpoints
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 5
Material © IBM Rational Software
Use-Case Analysis - Steps
Next





Supplement the Use-Case Description
For each use-case realization
 Find classes from use-case behavior
 Distribute use-case behavior to classes
For each resulting analysis class
 Describe responsibilities
 Describe attributes and associations
 Qualify architectural analysis mechanisms
Unify analysis classes
Checkpoints
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 6
Material © IBM Rational Software
Supplement the Use-Case Description
Use-Case
Specification
Supplemented
Use-Case
Specification
The system displays a
list of course offerings.


Capture additional information needed in order to understand the
required internal behavior of the system that may be missing from
the use-case description written for the customer of the system.
Note: exposes some solution structure – not appropriate for
requirements, but necessary to define objects.
J. Scott Hawker
RIT
Software Engineering
The system retrieves a list of course
offerings from the course catalog
legacy database. The system
displays the course offerings.
2004-09-23
p. 7
Material © IBM Rational Software
Use-Case Analysis - Steps


Next



Supplement the Use-Case Description
For each use-case realization
 Find classes from use-case behavior
 Distribute use-case behavior to classes
For each resulting analysis class
 Describe responsibilities
 Describe attributes and associations
 Qualify architectural analysis mechanisms
Unify analysis classes
Checkpoints
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 8
Material © IBM Rational Software
Analysis Classes: A First Step Towards Executables
Use-Cases
Analysis
Classes
Design
Elements
Source
Code
Use-Case Analysis
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 9
Material © IBM Rational Software
Executables
The Analysis Model is Temporary



The analysis model is an early conceptual model of how the system
will work
 It evolves quickly
 It is fluid, changing as different representations and their
implications are explored
Analysis classes rarely survive into design unchanged
 A given analysis class often represents collaborations of multiple
design objects, encapsulated by subsystems
 Think of analysis classes as “proto-classes” representing “clumps
of behavior”
 Allow us to explore alternative distribution of responsibilities to
achieve a good separation of concerns
Be careful to not spend too much time on “formal” documentation and
a well-polished model
 Consider the analysis model as informal
 “Structured doodling”, artist “studies”
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 10
Material © IBM Rational Software
Find Classes from Use-Case Behavior
 The complete behavior of a use-case must be
allocated to analysis classes
Use-Case
Specification
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 11
Material © IBM Rational Software
Class Stereotypes for Analysis


Entity
Boundary
Control
Distinguish and separate the concerns of system interface from
application logic/control flow from persistent application objects
Specialize the class object in UML to represent the distinctions
 Entity classes: system information
 Long-lived, real-life object or event in the application
domain
 Data and behavior
 Usually persistent (saved in a file or database)
 Boundary classes: system boundary
 Interaction between the system and its actors
 At the system boundary
 Control classes: use-case behavior coordination
 Coordination and sequencing of system behavior
 Transactions
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 12
Material © IBM Rational Software
Analysis Classes



The distinction into the three analysis class types
helps
 Clarify and separate class roles in the
system
 Separate things that tend to change
separately
Classes identified in analysis need not have a
stereotype
Once the roles have been analyzed and there is
a good system decomposition, the distinction
between types is no longer really useful
 The distinction (and the stereotypes) tend to
go away in design
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 13
Material © IBM Rational Software
Alternate Visualizations of the Same Thing
<<boundary>>
Boundary
Boundary
Boundary
<<control>>
Control
Control
Control
<<entity>>
Entity
Entity
Entity

UML allows multiple graphical representations
(“syntax”) of the same conceptual (semantic)
model element
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 14
Material © IBM Rational Software
Boundary Classes


A boundary class intermediates between the system and
something outside the system
 Insulate the system from changes in the surroundings
(changes in external systems, user requirements, etc.)
Types
 User interface classes
 Display windows/screens, keyboard, microphone
voice recognition, motion tracker, etc.
 System interface classes
 Interface to external systems, legacy systems, use
of an external Application Programming Interface
(API)
 Device interface classes
 Interface to devices which detect external events
 Capture the responsibilities of a device or sensor
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 15
Material © IBM Rational Software
Use Case
<<actor>>
The Role of
Boundary
Classes
Boundary
Control
Actor
Boundary
Entity




Software Engineering
Entity
Model interaction between the system’s surroundings and its inner
workings
 Transform and translate events
 Note changes in the system presentation (such as a user
interface display)
Make it easier to understand and clarify system boundaries
Help identify related services
 For example, identifying a printer interface suggests the need
to format printouts
Insulate external forces from system inner workings and vice-versa
 For example, changing a communication protocol or GUI lookand-feel should mean only changing the boundary classes,
not the entity and control classes
J. Scott Hawker
RIT
Boundary
2004-09-23
p. 16
Material © IBM Rational Software
External
System
Finding
Boundary
Classes
Student
Register For
Courses
RegisterForCoursesForm



Software Engineering
CourseCatalogSystem
Guideline: Start with one boundary class per actor/use-case pair
Concentrate on the responsibilities (NOT the details)
 User interface classes
 Concentrate on what information is presented (NOT on the UI
details of graphics, layout, style, controls, etc.)
 System and device interface classes
 Concentrate on what protocols must be defined (NOT on how
the protocols will be implemented) – responsibilities, not details
 If there is already a working communication with the external
system or device, make note of it for later reference during
design
Consider the source of all external events and make sure there is a way
for the system to detect these events
J. Scott Hawker
RIT
<<actor>>
Course
catalog
system
2004-09-23
p. 17
Material © IBM Rational Software
Entity Classes




Entity objects represent the key concepts of the system
being developed
 Store and manage information in the system
 Data (usually persistent)
 Structure (usually persistent)
 Behavior
Usually not specific to one use-case
Examples
 Banking: Account, Customer
 Network Management: Node, Link
 Information the system needs to know about its actors
 A surrogate for the actor – the actor itself is separate
Identify the entity classes by name and brief description
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 18
Material © IBM Rational Software
Finding
Entity
Classes


Software Engineering
Student
Different!
Consider “StudentInfo”
or “StudentActor” as
names to clarify the
distinction
Student
Schedule
Sources
 Glossary, business/domain model, use-case flow of events, key
abstractions (from architectural analysis)
A technique: study the nouns
 Underline noun clauses in the use-case flow of events
 Remove redundant candidates
 Remove vague candidates (or make them clear)
 Remove actors (out of scope, but they may have surrogate entity
classes)
 Remove implementation constructs
 Remove attributes (save for later)
 Remove operations
J. Scott Hawker
RIT
CourseOffering
2004-09-23
p. 19
Material © IBM Rational Software
Control
Classes



RegistrationController
Use-case behavior coordinator
 Typically, one control class per use case
 Create control object at start of use-case, delete it at end
 Delegates actor-visible behavior to the entity classes
 “Orchestrate and Delegate Behavior”
 If the use-case is simply accessing and changing information, a
control class may be unnecessary (boundary classes and entity
classes interact directly)
Examples
 Transaction management
 Resource coordination
 Error handling
 Decision logic (control the flow of events; state-dependent flows)
May disappear in design – become methods on UI classes
 “On MouseEvent do X”
J. Scott Hawker
RIT
Software Engineering
Student
Register For
Courses
<<actor>>
Course
catalog
system
2004-09-23
p. 20
Material © IBM Rational Software
Analysis Classes for “Register for Courses”
External
system
Register For
Courses
Student
Course catalog system
Requirements (Use-Case) Model
Analysis Model – View of Participating Classes in Use-Case Realization
Register for Courses
RegisterForCoursesForm
External
system
RegistrationController
CourseCatalogSystem
Student
Student
J. Scott Hawker
RIT
Software Engineering
2004-09-23
Schedule CourseOffering
p. 21
Material © IBM Rational Software
Course catalog
system
Use-Case Analysis - Steps


Supplement the Use-Case Description
For each use-case realization
 Find classes from use-case behavior
Next  Distribute use-case behavior to classes
 For each resulting analysis class
 Describe responsibilities
 Describe attributes and associations
 Qualify architectural analysis mechanisms
 Unify analysis classes
 Checkpoints
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 22
Material © IBM Rational Software
Distribute Use-Case Behavior to Classes

For each use-case flow of events
 Identify participating analysis classes
 Allocate use-case responsibilities to those analysis
classes
 Model analysis class interactions in interaction diagrams
 One interaction diagram for each variant of a usecase’s flow of events
o Flows for different user options
o Exception-handling flows
o etc.
 In analysis, collaboration diagrams (as opposed to
sequence diagrams) help focus on class
responsibilities
o Even so, I tend to use sequence diagrams to
capture details and trace flow of control
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 23
Material © IBM Rational Software
Guidelines: Allocating Responsibilities to Classes

Use analysis class stereotypes as a guide
 Boundary classes
 Behavior that involves communication with an
actor
 Entity classes
 Behavior that involves the data encapsulated
within the abstraction
 Control classes
 Behavior specific to a use case or part of a very
important flow of events
(continued)
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 24
Material © IBM Rational Software
Guidelines: Allocating Responsibilities to Classes
(continued)



Who has the data needed to perform the responsibility?
 If one class has the data, put the responsibility with the data
 If multiple classes have the data
 Put the responsibility with one class and add a relationship to the
other
 Create a new class, put the responsibility on the new class, and
add relationships to classes needed to perform the responsibility
 Put the responsibility on the control class, and add relationships
to classes needed to perform the responsibility
Keep clear the responsibility: one object’s need to know information is not
the same as an object’s responsibility to provide information and manage
information: client vs. supplier
Refactor
 Re-allocate data and responsibility among classes
 Reuse: Assign new responsibility to a class that has similar
responsibility
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 25
Material © IBM Rational Software
The
classes
Sequence Diagrams
Client
Supplier
Client object
Supplier object
Object
Lifeline
: Client
: Supplier
PerformResponsibility()
PerformAnotherResponsibility()
Reflexive message
(Message to self)
1. PerformResponsibility
1.1. PerformAnotherResponsibility
Sample
Script
Message
Script
Focus of Control
(Activation)
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 26
Hierarchical
message
numbering
Material © IBM Rational Software
Example: Wylie College Course Registration System
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 27
Material © IBM Rational Software
Key Abstractions
(from Architectural Analysis activity)
Student
Professor
Schedule
CourseOffering
Course
CourseCatalog
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 28
Material © IBM Rational Software
: Student
Build a
Sequence
Diagram for
“Register for
Courses”
:
RegisterForCoursesForm
:
RegistrationController
1: // register for courses( )
2: // is registration open?( )
[ registration open ]
3: // display possible operations( )
4: // create schedule( )
Sequence Diagram: Register
for Courses / Register for
Courses - Basic Flow (Create
Schedule)
Basic flow, top level
(The basic flow has
six diagrams
capturing different
portions of the flow)
One of these
is executed:
5: // update schedule( )
Sequence Diagram: Register
for Courses / Register for
Courses - Basic Flow (Update
Schedule)
6: // delete schedule( )
Sequence Diagram: Register for
Courses / Register for Courses
- Basic Flow (Delete Schedule)
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 29
Material © IBM Rational Software
Build a
Sequence
Diagram
for
“Register
for
Courses”
Basic flow,
create a
schedule
portion
: Student
:
RegisterForCoursesForm
:
:
RegistrationController CourseCatalogSystem
2: // get course offerings( )
Student wishes to
create a new
schedule
A list of the available
course offerings for this
semester are displayed
A blank schedule
is displayed for the
students to select
offerings
3: // get course offerings()
4: // get course offerings( )
5: // display course offerings( )
6: // display blank schedule( )
7: // select 4 primary and 2 alternate offerings( )
J. Scott Hawker
Software Engineering
: Schedule
1: // create schedule( )
8: // create schedule with offerings( )
9: // create with offerings( )
10: // add schedule(Schedule)
At this, point the Submit Schedule subflow is executed.
RIT
: Course Catalog
2004-09-23
p. 30
Sequence Diagram: Register for
Courses / Register for Courses - Basic
Flow (Submit Schedule)
Material © IBM Rational Software
: Student
Collaboration Diagrams
Message
: Client
1.1. PerformAnotherResponsibility
1. PerformResponsibility
: Supplier
Client object
Link
Supplier object
Note: A common mistake is to associate the behavior
with the client, instead of the supplier. Even though
the client initiates the behavior and needs it done, it
is the supplier that is responsible for carrying out the
behavior at the client’s request.
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 31
Material © IBM Rational Software
Collaboration Diagram for “Register for Courses”
Basic flow, create a schedule portion
5: // display course offerings( )
6: // display blank schedule( )
1: // create schedule( )
7: // select 4 primary and 2 alternate offerings( )
Compare this to the equivalent
sequence diagram, earlier. Which
visualization makes which design
aspects clearer?
: RegisterForCoursesForm
2: // get course offerings( )
8: // create schedule with offerings( )
4: // get course offerings( )
: Course Catalog
: Student
3: // get course offerings()
: RegistrationController
: CourseCatalogSystem
9: // create with offerings( )
10: // add schedule(Schedule)
: Student
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 32
: Schedule
Material © IBM Rational Software
Collaboration Diagrams vs. Sequence Diagrams

Collaboration Diagrams
 Show relationships (i.e.,
structure) in addition to
interactions
 Better for visualizing
patterns of collaboration
 Better for visualizing all of
the effects on a given
object
 Easier to use for
brainstorming sessions
 CRC (Class,
Responsibility,
Collaboration) cards
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 33

Sequence Diagrams
 Show the explicit
sequence of
messages
 Better for visualizing
overall flow of control
 Better for real-time
specifications and for
complex scenarios
Material © IBM Rational Software
Use-Case Analysis - Steps


Supplement the Use-Case Description
For each use-case realization
 Find classes from use-case behavior
 Distribute use-case behavior to classes
 For each resulting analysis class
Next  Describe responsibilities
 Describe attributes and associations
 Qualify architectural analysis mechanisms
 Unify analysis classes
 Checkpoints
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 34
Material © IBM Rational Software
// PerformAnotherResponsibility
Describe
Responsibilities
: Client
// PerformResponsibility
: Supplier



A responsibility is a statement of something
an object can be asked to provide
 Actions the object can perform on
request
 Knowledge the object maintains and
provides to other objects
Messages on interaction diagrams define
responsibilities
 Responsibilities evolve into one or more
operations on classes in design
Document responsibilities in one of two ways
 As “analysis” operations
 Class operations with “//” pre-pended
as a naming convention
 As textual description of the analysis
class
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 35
Supplier
// PerformResponsibility
// PerformAnotherResponsibility
Material © IBM Rational Software
“Register for Courses” Realization
View of Participating Classes (VOPC)
Show only those classes, attributes, operations, and
associations involved in realizing this use case
<<boundary>>
RegisterForCoursesForm
//
//
//
//
//
//
submit schedule()
display course offerings()
display schedule()
create schedule()
select 4 primary and 2 alternate offerings()
display blank schedule()
<<control>>
RegistrationController
1
1
<<boundary>>
CourseCatalogSystem
// get course offerings()
// submit schedule()
// create schedule with offerings()
0..n
0..1
+registrant
// add schedule()
// has pre-requisites()
0..1
grade
<<entity>>
Schedule
0..n
// create with offerings()
// submit()
// save()
<<entity>>
CourseOffering
// is enrolled in?()
// mark as enrolled in()
+primaryCourses
0..n
0..4
status
// mark as selected()
// is selected?()
J. Scott Hawker
Software Engineering
2004-09-23
p. 36
number : String = "100"
startTime : Time
endTime : Time
days : Enum
// add student()
0..2 // still open?()
+alternateCourses
// save()
0..n
<<entity>>
ScheduleOfferingInfo
RIT
0..1
Course Catalog
<<entity>>
PrimaryScheduleOfferingInfob
0..1
0..1
1
// get course offerings()
(f rom Use Case View)
...)
0..1
+currentSchedule
<<entity>>
Student
1
Material © IBM Rational Software
Maintaining Consistency: What to Look For



In order of criticality:
 Redundant responsibilities across classes
 Disjoint responsibilities within classes
 Class with one responsibility
 Class with no responsibilities
 Better distribution of behavior
 Class that interacts with many other classes
A class does everything about X, and only things about X
 Decompose; separate concerns
 Integrate; combine all aspects of a single concern
Update the interaction diagrams to reflect the re-factored
classes
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 37
Material © IBM Rational Software
Use-Case Analysis - Steps


Supplement the use-case description
For each use-case realization
 Find classes from use-case behavior
 Distribute use-case behavior to classes
 For each resulting analysis class
 Describe responsibilities
Next  Describe attributes and associations
 Define attributes
 Establish associations between analysis classes
 Describe event dependencies between analysis classes
 Qualify architectural analysis mechanisms
 Unify analysis classes
 Checkpoints
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 38
Material © IBM Rational Software
Notation
Review: Attributes



Attributes store information
 Atomic
 No responsibilities
Attribute name should clearly state
what information the attribute holds
 Supplement with attribute
description, where the name is not
sufficient
During analysis, attribute types should
be from the domain, not from the
programming language
 In analysis, don’t worry too much
about attribute types/signatures
 But do look for types that should
be new classes
J. Scott Hawker
RIT
Software Engineering
<<stereotype>>
ClassName
- PrivateAttribute : Type = InitialValue
+ PublicAttribute : Type = InitialValue
# ProtectedAttribute : Type = InitialValue
2004-09-23
p. 39
<<entity>>
CourseOffering
courseNumber : String
startTime : Time
endTime : Time
days : Enumeration
numStudents : Integer
CourseOffering
courseNumber : String
startTime : Time
endTime : Time
days : Enumeration
numStudents : Integer
Material © IBM Rational Software
Finding Attributes




Properties/characteristics of identified classes
Information retained by identified classes
“Nouns” that did not become classes
 Information whose value is the important thing
 Information that is uniquely “owned” by an object
 No other object refers to it
 Information that has no behavior beyond get, set,
and simple transformations
Only identify attributes relevant to the domain
 Avoid interesting but irrelevant characterizations
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 40
Material © IBM Rational Software
Review: Associations



“Associated with” relationship
The semantic relationship between
two or more model elements that
specifies connections among their
instances
 A structural relationship,
specifying that objects of one
thing are connected to objects
of another thing
An instance of an association
between two objects (instances) is
called a link
J Clark :
Professor
J. Scott Hawker
RIT
Software Engineering
2004-09-23
Student.
1
0..n
Schedule
0..n
+courses
0..4
CourseOffering
Course
0..n
+preRequisites
+instructor
Professor
BIO_101-003 :
CourseOffering
p. 41
0..n
0..n
0..4
0..1
1
Material © IBM Rational Software
Finding Associations







Every link on an interaction diagram indicate the object
classes are associated
An association of a class to itself is needed when two
different objects of the same class need to communicate
Define association role names
Define association multiplicities
Navigability is optional
 If defined, make sure messages can flow along
navigable paths
If two objects are bound by a whole-part relationship, the
relationship is aggregation
 When in doubt, use general association
Only identify associations relevant to the domain
 Avoid interesting but irrelevant associations
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 42
Material © IBM Rational Software
Association Roles

Association roles define the role an object instance
plays for its associated object instance
 The “face” it presents to its associated object
<<entity>>
CourseOffering
+instructor <<entity>> +departmentHead
Professor
<<entity>>
Department
<<entity>>
Course
0..n
+preRequisites
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 43
Material © IBM Rational Software
Multiple Associations

There can be multiple associations between classes
 Each represents distinct relationships, different
roles
+primaryCourses
<<entity>>
Schedule
0..n
0..4
0..n
<<entity>>
CourseOffering
0..2
+alternateCourses
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 44
Material © IBM Rational Software
Finding Relationships

Draw a class diagram showing the classes participating in
a use-case realization interaction diagram
 View of Participating Classes (VOPC) diagram
 Each message link in the interaction diagram
corresponds to an association in the VOPC diagram
 Note: the VOPC diagram and the collaboration diagram
look very similar, but they are different
1
1
RegisterForCoursesForm
RegistrationController
0..1
0..1
+currentSchedule
+registrant
0..1
0..1
1
J. Scott Hawker
Software Engineering
p. 45
+alternateCourses
0..2
0..n
Schedule
2004-09-23
0..n
0..4
0..n
Student.
RIT
In a collaboration diagram,
there would be up to six
instances of this class
+primaryCourses
CourseOffering
Material © IBM Rational Software
Use-Case Analysis - Steps


Supplement the Use-Case Description
For each use-case realization
 Find classes from use-case behavior
 Distribute use-case behavior to classes
 For each resulting analysis class
 Describe responsibilities
 Describe attributes and associations
Next  Qualify architectural analysis mechanisms
 Unify analysis classes
 Checkpoints
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 46
Material © IBM Rational Software
Describing Analysis Mechanisms


Collect all the architectural analysis mechanisms in a
list
Map the client classes to the analysis mechanisms
Analysis Class
Student
Schedule
CourseOffering
Course
RegistrationController

Software Engineering
Persistence, Security
Persistence, Security
Persistence, Legacy Interface
Persistence, Legacy Interface
Distribution
Identify characteristics of the analysis mechanisms for
each using class
J. Scott Hawker
RIT
Analysis Mechanism
2004-09-23
p. 47
Material © IBM Rational Software
Example: Describing Analysis Mechanisms
(continued)

Analysis mechanism characteristics
 Persistence for Schedule class:
 Granularity: 1 to 10 kbytes per schedule
 Volume: up to 2,000 schedules
 Access frequency
o Create: 500 per day
o Read: 2,000 per hour
o Update: 1,000 per day
o Delete: 50 per day
 etc.
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 48
Material © IBM Rational Software
Use-Case Analysis - Steps



Next


Supplement the Use-Case Description
For each use-case realization
 Find classes from use-case behavior
 Distribute use-case behavior to classes
For each resulting analysis class
 Describe responsibilities
 Describe attributes and associations
 Qualify architectural analysis mechanisms
Unify analysis classes
Checkpoints
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 49
Material © IBM Rational Software
Unify Analysis Classes




So far, we have identified classes in the context of
individual use cases
Now, unify the results individual results across all the
use cases
Merge classes that define similar behavior or represent
the same phenomenon
Merge entity classes that define the same attributes,
even if their behavior is different (merge the behaviors)
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 50
Material © IBM Rational Software
Use-Case Analysis - Steps




Next 
Supplement the Use-Case Description
For each use-case realization
 Find classes from use-case behavior
 Distribute use-case behavior to classes
For each resulting analysis class
 Describe responsibilities
 Describe attributes and associations
 Qualify architectural analysis mechanisms
Unify analysis classes
Checkpoints
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 51
Material © IBM Rational Software
Review Checkpoints: Analysis Classes







Are the classes reasonable?
Does the name of each class clearly reflect the role it
plays?
Does the class represent a single, well-defined
abstraction?
Are all attributes and responsibilities functionally
cohesive?
Does the class offer the required behavior?
Are all the specific requirements on the class
addressed?
Are there unnecessary attributes or relationships?
(remove them!)
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 52
Material © IBM Rational Software
Review Checkpoints: Use-Case Realizations





Have all the main and sub-flows been handled,
including exceptional cases?
Have all the required objects been found?
Has all behavior been unambiguously distributed to the
participating objects?
Has behavior been distributed to the right objects?
Where there are several interaction diagrams, are their
relationships clear and consistent?
J. Scott Hawker
RIT
Software Engineering
2004-09-23
p. 53
Material © IBM Rational Software
Download