Use case diagrams

mohamed tahoon
mohamed tahoonstudent at FCI um FCI
Use Case Diagrams
Tutorial
What is a use case?
• A requirements analysis concept
• A case of a use of the system/product
• Describes the system's actions from a the point of
view of a user
• Tells a story
• A sequence of events involving
• Interactions of a user with the system
• Specifies one aspect of the behavior of a system,
without specifying the structure of the system
• Is oriented toward satisfying a user's goal
How do we describe use cases?
• Textual or tabular descriptions
• User stories
• Diagrams
Use Case Descriptions
• actors - something with a behavior or role, e.g., a
person, another system, organization.
• scenario - a specific sequence of actions and
interactions between actors and the system, a.k.a. a
use case instance
• use case - a collection of related success and failure
scenarios, describing actors using the system to
support a goal.
What is an Actor?
• Include all user roles that interact with the system
• Include system components only if they responsible for
initiating/triggering a use case.
• For example, a timer that triggers sending of an e-mail
reminder
• primary - a user whose goals are fulfilled by the system
• importance: define user goals
• supporting - provides a service (e.g., info) to the system
• importance: clarify external interfaces and protocols
• offstage - has an interest in the behavior but is not primary or
supporting, e.g., government
• importance: ensure all interests (even subtle) are identified
and satisfied
Finding Actors [1]
External objects that produce/consume data:
• Must serve as sources and destinations for data
• Must be external to the system
Finding Actors [2]
Ask the following questions:
• Who are the system’s primary users?
• Who requires system support for daily tasks?
• Who are the system’s secondary users?
• What hardware does the system handle?
• Which other (if any) systems interact with the system in
question?
• Do any entities interacting with the system perform
multiple roles as actors?
• Which other entities (human or otherwise) might have an
interest in the system's output?
What is a user story?
1.Who?
2.Does what?
3.And why?
As a <type of user>,
I want <some behavior from the system>
so that <some value is achieved>
•An abbreviated description of a use case
•Used in agile development
Answers 3 questions:
Use Case Diagrams
• A picture
• describes how actors relate to use cases
• and use cases relate to one another
• Diagrams are not essential
• They are helpful in giving an overview, but only
secondary in importance to the textual description
• They do not capture the full information of the
actual use cases
• In contrast, text is essential
Use Case Diagram Objective
• Built in early stages of development
•  Purpose
• Specify the context of a system
• Capture the requirements of a system
• Validate a systems architecture
• Drive implementation and generate test
cases
• Developed by analysts and domain
experts
How do use case diagrams fit in?
This applies also to use case descriptions.
Diagram reproduced from www.edrawsoft.com.
Example Use-Case Diagram
A standard form of use case diagram is defined in the Unified Modeling Language.
13
Elements of use case diagram: Actor
• Actor is someone interacting with use case
(system function). Named by noun.
• Similar to the concept of user, but
a user can play different roles;
(example: a prof. can be instructor and
researcher – plays 2 roles with two systems).
• Actor triggers use case.
• Actor has responsibility toward the system (inputs),
and Actor have expectations from the system (outputs).
Name
14
Elements of use case diagram: Use Case
• System function (process – automated or manual).
• Named by verb.
Do something
• Each Actor must be linked to a use case, while some use cases
may not be linked to actors.
= Use Case
15
Elements of use case diagram: Other details
Boundary of system
<<include>>
Include relationship between Use Cases (one UC must
call another; e.g., Login UC includes User Authentication UC)
<<extend>>
Extend relationship between Use Cases (one UC calls
Another under certain condition; think of if-then decision points)
Connection between Actor and Use Case
Linking Use Cases
• Association relationships
• Generalization relationships
• One element (child) "is based on" another element
(parent)
• Include relationships
• One use case (base) includes the functionality of
another (inclusion case)
• Supports re-use of functionality
• Extend relationships
• One use case (extension) extends the behavior of
another (base)
Use Case Levels
18
• The child use case inherits the
behavior and meaning of the
parent use case.
• The child may add to or
override the behavior of its parent.
parent
child
1. Generalization
19
registration
graduate
registration
non-graduate
registration
More about Generalization
Generalization Example
The actor Order Registry
Clerk can instantiate the
general use case Place
Order.
Place Order can also be
specialized by the use
cases Phone Order or
Internet Order.
Generalization Example
22
• The base use case explicitly incorporates the
behavior of another use case at a location
specified in the base.
• The included use case never stands alone. It
only occurs as a part of some larger base that
includes it.
base included<<include>>
2. Include
‫מידע‬ ‫מערכות‬ ‫ניתוח‬ 23
More about Include
Enables us to avoid describing the same flow of
events several times by putting the common
behavior in a use case of its own.
updating
grades
output
generating
verifying
student id
<<include>>
<<include>>
24
Include relationship
• Include relationship – a standard case linked to a
mandatory use case.
• Standard use case can NOT execute without the include
case  tight coupling .
• Example: to Authorize Car Loan (standard use case),
a clerk must run Check Client’s Credit History (include use case).
• The standard UC includes the mandatory UC (use the verb
to figure direction arrow).
25
Reading use case diagram with Include
relationship
Include Example
27
• The base use case implicitly incorporates the
behavior of another use case at certain points
called extension points.
• The base use case may stand alone, but under
certain conditions its behavior may be
extended by the behavior of another use case.
base extending<<extend>>
3. Extend
28
More about Extend
• Enables to model optional behavior or
branching under conditions.
Exam copy
request
Exam-grade
appeal
<<extend>>
29
• Extend relationship – linking an optional use case
to a standard use case.
Extend relationship
• Example: Register Course (standard use case) may have
Register for Special Class (extend use case) – class for
non-standard students, in unusual time, with special
topics, requiring extra fees…).
• The optional UC extends the standard UC
• Standard use case can execute without the extend case
 loose coupling.
Reading extend relationship
Extend Example #1
Extend Example #2
Extend Example #2 cont.
33
Actors may be connected to use cases by
associations, indicating that the actor and the
use case communicate with one another using
messages.
updating
grades
faculty
Relationships between Use Cases
and Actors
34
place
phone call
cellular
network
user
receive
phone call
place
conference
call
receive
additional
call
use
scheduler
<<extend>>
<<extend>>
Cellular Telephone
Example #1
Example #2
Altered State University (ASU) Registration System
1. Professors indicate which courses they will teach on-line.
2. A course catalog can be printed
3. Allow students to select on-line four courses for upcoming
semester.
4. No course may have more than 10 students or less than 3
students.
5. When the registration is completed, the system sends
information to the billing system.
6. Professors can obtain course rosters on-line.
7. Students can add or drop classes on-line.
Example #2 cont.
Altered State University (ASU) Registration System
37
How to create use case diagram
1. List main system functions (use cases) in a column:
– think of business events demanding system’s response
– users’ goals/needs to be accomplished via the system
– Create, Read, Update, Delete (CRUD) data tasks
– Naming use cases – user’s needs usually can be translated in data tasks
2. Draw ovals around the function labels
3. Draw system boundary
4. Draw actors and connect them with use cases (if more intuitive, this can be done as
step 2)
5. Specify include and extend relationships between use cases (yes, at the end - not
before, as this may pull you into process thinking, which does not apply in UC
diagramming).
Use-Case Diagrams: Example [1]
I. Begin with a Use Case!
A user placing an order with a sales company might
follow these steps :
1. Browse catalog and select items.
2. Call sales representative.
3. Supply shipping information.
4. Supply payment information.
5. Receive conformation number from salesperson.
II. Then translate Use Case sequence into Diagram
Use-Case Diagrams: Example [2]
The salesperson could also
be included in this use case
diagram because the
salesperson is also
interacting with the
ordering system.
Use-Case Diagram Case Study [1]
Vending Machine
After client interview the following system scenarios were
identified:
– A customer buys a product
– The supplier restocks the machine
– The supplier collects money from the machine
On the basis of these scenarios, the following three actors
can be identified:
Customer; Supplier; Collector (in this case Collector=Supplier)
Use-Case Diagram Case Study [2]
Use-Case Diagram Case Study [3]
Introducing annotations (notes) and constraints.
1 von 42

Recomendados

Use case diagramUse case diagram
Use case diagramCity University
779 views27 Folien
Use case DiagramUse case Diagram
Use case DiagramPreeti Mishra
1.8K views26 Folien
Use case Diagram Use case Diagram
Use case Diagram Rahul Pola
5.7K views15 Folien
Use Case DiagramUse Case Diagram
Use Case DiagramAshesh R
68.1K views48 Folien
Activity diagramActivity diagram
Activity diagrambhupendra kumar
3.3K views8 Folien

Más contenido relacionado

Was ist angesagt?

Use Case ModelingUse Case Modeling
Use Case ModelingVenkat Srinivasan
21.8K views39 Folien
UMLUML
UMLiQra Rafaqat
8.3K views30 Folien
Use case diagramsUse case diagrams
Use case diagramsFajar Baskoro
4.3K views42 Folien
Use Case DiagramUse Case Diagram
Use Case DiagramKumar
27.5K views24 Folien

Was ist angesagt?(20)

Introduction to UMLIntroduction to UML
Introduction to UML
Emertxe Information Technologies Pvt Ltd41.7K views
Use Case ModelingUse Case Modeling
Use Case Modeling
Venkat Srinivasan21.8K views
SE_Lec 08_UML Use CasesSE_Lec 08_UML Use Cases
SE_Lec 08_UML Use Cases
Amr E. Mohamed1.6K views
UMLUML
UML
iQra Rafaqat8.3K views
Use case diagramsUse case diagrams
Use case diagrams
Fajar Baskoro4.3K views
Use Case DiagramUse Case Diagram
Use Case Diagram
Kumar 27.5K views
Presentation on umlPresentation on uml
Presentation on uml
Shruti Dalela4.7K views
Functional modelingFunctional modeling
Functional modeling
Fatma Al-sayegh10.8K views
Uml class-diagramUml class-diagram
Uml class-diagram
ASHOK KUMAR PALAKI24.2K views
Interaction ModelingInteraction Modeling
Interaction Modeling
Hemant Sharma14.4K views
Deployment DiagramDeployment Diagram
Deployment Diagram
University of Texas at Dallas3.9K views
Usecase PresentationUsecase Presentation
Usecase Presentation
Rungsun Promprasith12.5K views
Uml diagramsUml diagrams
Uml diagrams
barney9244.8K views
SAD11 - Sequence DiagramsSAD11 - Sequence Diagrams
SAD11 - Sequence Diagrams
Michael Heron1.4K views
Lecture11 use case sequence diagramLecture11 use case sequence diagram
Lecture11 use case sequence diagram
Shahid Riaz1.4K views
Domain ModelingDomain Modeling
Domain Modeling
Harsh Jegadeesan55K views

Destacado

5.state diagrams5.state diagrams
5.state diagramsAPU
44K views27 Folien
Activity DiagramActivity Diagram
Activity DiagramAshesh R
14.9K views30 Folien

Destacado(20)

Lecture04- Use Case DiagramsLecture04- Use Case Diagrams
Lecture04- Use Case Diagrams
artgreen21.2K views
Use case-diagramsUse case-diagrams
Use case-diagrams
Maoelana Noermoehammad58K views
5.state diagrams5.state diagrams
5.state diagrams
APU44K views
Activity DiagramActivity Diagram
Activity Diagram
Ashesh R14.9K views
School Management System pptSchool Management System ppt
School Management System ppt
Mohsin Ali150K views
Real World Akka Actor Recipes JavaOne 2013Real World Akka Actor Recipes JavaOne 2013
Real World Akka Actor Recipes JavaOne 2013
Björn Antonsson7.4K views
Use Case UML DiagramUse Case UML Diagram
Use Case UML Diagram
University of Texas at Dallas9.8K views
Lecture07Lecture07
Lecture07
artgreen5.8K views
online national pollingonline national polling
online national polling
Kasi Annapurna12.1K views
Lecture#04, use case diagramLecture#04, use case diagram
Lecture#04, use case diagram
babak danyal5.9K views
Agile Simulation in 75 MinutesAgile Simulation in 75 Minutes
Agile Simulation in 75 Minutes
BigVisible Higdon3.2K views
Final Report PTATFinal Report PTAT
Final Report PTAT
Achal Patel2.5K views
Chapter06Chapter06
Chapter06
Franco Valdez2.9K views
Bug Tracking SystemBug Tracking System
Bug Tracking System
Kishan Acharya24.3K views
use case point estimationuse case point estimation
use case point estimation
عبدالغني الهجار3.4K views

Similar a Use case diagrams(20)

Use case modelingUse case modeling
Use case modeling
Wajahat Hasnain233 views
Use case modeling & analysis v 1Use case modeling & analysis v 1
Use case modeling & analysis v 1
JIGAR MAKHIJA1.3K views
2.1 usecase diagram2.1 usecase diagram
2.1 usecase diagram
Ashenafi Workie628 views
Use Case Diagram.pptxUse Case Diagram.pptx
Use Case Diagram.pptx
Genta Sahuri54 views
SE_RE-II-CH5 (3).pdfSE_RE-II-CH5 (3).pdf
SE_RE-II-CH5 (3).pdf
AZKANAAZ110 views
conversion-gate02.pptxconversion-gate02.pptx
conversion-gate02.pptx
NouraBaccar12 views
Ppt ooad ooad3unitPpt ooad ooad3unit
Ppt ooad ooad3unit
ramyalaksha25 views
Use Case Modeling In UMLUse Case Modeling In UML
Use Case Modeling In UML
Syed Hassan Ali217 views
chapter_5_5.pptchapter_5_5.ppt
chapter_5_5.ppt
MonirHossain7073196 views
Lesson02_Use Case DiagramsLesson02_Use Case Diagrams
Lesson02_Use Case Diagrams
Marwa Ali Eissa1.4K views
Chapter 4.pptxChapter 4.pptx
Chapter 4.pptx
zaaakditte1 view
Software engineeringSoftware engineering
Software engineering
renukarenuka981 views
Use Case Modelling.pptxUse Case Modelling.pptx
Use Case Modelling.pptx
azida314 views
Ch 14 s.e use case diagramsCh 14 s.e use case diagrams
Ch 14 s.e use case diagrams
Badar Waseer355 views
SELECT21.pptxSELECT21.pptx
SELECT21.pptx
devnasra110 views

Use case diagrams

  • 2. What is a use case? • A requirements analysis concept • A case of a use of the system/product • Describes the system's actions from a the point of view of a user • Tells a story • A sequence of events involving • Interactions of a user with the system • Specifies one aspect of the behavior of a system, without specifying the structure of the system • Is oriented toward satisfying a user's goal
  • 3. How do we describe use cases? • Textual or tabular descriptions • User stories • Diagrams
  • 4. Use Case Descriptions • actors - something with a behavior or role, e.g., a person, another system, organization. • scenario - a specific sequence of actions and interactions between actors and the system, a.k.a. a use case instance • use case - a collection of related success and failure scenarios, describing actors using the system to support a goal.
  • 5. What is an Actor? • Include all user roles that interact with the system • Include system components only if they responsible for initiating/triggering a use case. • For example, a timer that triggers sending of an e-mail reminder • primary - a user whose goals are fulfilled by the system • importance: define user goals • supporting - provides a service (e.g., info) to the system • importance: clarify external interfaces and protocols • offstage - has an interest in the behavior but is not primary or supporting, e.g., government • importance: ensure all interests (even subtle) are identified and satisfied
  • 6. Finding Actors [1] External objects that produce/consume data: • Must serve as sources and destinations for data • Must be external to the system
  • 7. Finding Actors [2] Ask the following questions: • Who are the system’s primary users? • Who requires system support for daily tasks? • Who are the system’s secondary users? • What hardware does the system handle? • Which other (if any) systems interact with the system in question? • Do any entities interacting with the system perform multiple roles as actors? • Which other entities (human or otherwise) might have an interest in the system's output?
  • 8. What is a user story? 1.Who? 2.Does what? 3.And why? As a <type of user>, I want <some behavior from the system> so that <some value is achieved> •An abbreviated description of a use case •Used in agile development Answers 3 questions:
  • 9. Use Case Diagrams • A picture • describes how actors relate to use cases • and use cases relate to one another • Diagrams are not essential • They are helpful in giving an overview, but only secondary in importance to the textual description • They do not capture the full information of the actual use cases • In contrast, text is essential
  • 10. Use Case Diagram Objective • Built in early stages of development •  Purpose • Specify the context of a system • Capture the requirements of a system • Validate a systems architecture • Drive implementation and generate test cases • Developed by analysts and domain experts
  • 11. How do use case diagrams fit in? This applies also to use case descriptions. Diagram reproduced from www.edrawsoft.com.
  • 12. Example Use-Case Diagram A standard form of use case diagram is defined in the Unified Modeling Language.
  • 13. 13 Elements of use case diagram: Actor • Actor is someone interacting with use case (system function). Named by noun. • Similar to the concept of user, but a user can play different roles; (example: a prof. can be instructor and researcher – plays 2 roles with two systems). • Actor triggers use case. • Actor has responsibility toward the system (inputs), and Actor have expectations from the system (outputs). Name
  • 14. 14 Elements of use case diagram: Use Case • System function (process – automated or manual). • Named by verb. Do something • Each Actor must be linked to a use case, while some use cases may not be linked to actors. = Use Case
  • 15. 15 Elements of use case diagram: Other details Boundary of system <<include>> Include relationship between Use Cases (one UC must call another; e.g., Login UC includes User Authentication UC) <<extend>> Extend relationship between Use Cases (one UC calls Another under certain condition; think of if-then decision points) Connection between Actor and Use Case
  • 16. Linking Use Cases • Association relationships • Generalization relationships • One element (child) "is based on" another element (parent) • Include relationships • One use case (base) includes the functionality of another (inclusion case) • Supports re-use of functionality • Extend relationships • One use case (extension) extends the behavior of another (base)
  • 18. 18 • The child use case inherits the behavior and meaning of the parent use case. • The child may add to or override the behavior of its parent. parent child 1. Generalization
  • 20. Generalization Example The actor Order Registry Clerk can instantiate the general use case Place Order. Place Order can also be specialized by the use cases Phone Order or Internet Order.
  • 22. 22 • The base use case explicitly incorporates the behavior of another use case at a location specified in the base. • The included use case never stands alone. It only occurs as a part of some larger base that includes it. base included<<include>> 2. Include
  • 23. ‫מידע‬ ‫מערכות‬ ‫ניתוח‬ 23 More about Include Enables us to avoid describing the same flow of events several times by putting the common behavior in a use case of its own. updating grades output generating verifying student id <<include>> <<include>>
  • 24. 24 Include relationship • Include relationship – a standard case linked to a mandatory use case. • Standard use case can NOT execute without the include case  tight coupling . • Example: to Authorize Car Loan (standard use case), a clerk must run Check Client’s Credit History (include use case). • The standard UC includes the mandatory UC (use the verb to figure direction arrow).
  • 25. 25 Reading use case diagram with Include relationship
  • 27. 27 • The base use case implicitly incorporates the behavior of another use case at certain points called extension points. • The base use case may stand alone, but under certain conditions its behavior may be extended by the behavior of another use case. base extending<<extend>> 3. Extend
  • 28. 28 More about Extend • Enables to model optional behavior or branching under conditions. Exam copy request Exam-grade appeal <<extend>>
  • 29. 29 • Extend relationship – linking an optional use case to a standard use case. Extend relationship • Example: Register Course (standard use case) may have Register for Special Class (extend use case) – class for non-standard students, in unusual time, with special topics, requiring extra fees…). • The optional UC extends the standard UC • Standard use case can execute without the extend case  loose coupling. Reading extend relationship
  • 33. 33 Actors may be connected to use cases by associations, indicating that the actor and the use case communicate with one another using messages. updating grades faculty Relationships between Use Cases and Actors
  • 35. Example #2 Altered State University (ASU) Registration System 1. Professors indicate which courses they will teach on-line. 2. A course catalog can be printed 3. Allow students to select on-line four courses for upcoming semester. 4. No course may have more than 10 students or less than 3 students. 5. When the registration is completed, the system sends information to the billing system. 6. Professors can obtain course rosters on-line. 7. Students can add or drop classes on-line.
  • 36. Example #2 cont. Altered State University (ASU) Registration System
  • 37. 37 How to create use case diagram 1. List main system functions (use cases) in a column: – think of business events demanding system’s response – users’ goals/needs to be accomplished via the system – Create, Read, Update, Delete (CRUD) data tasks – Naming use cases – user’s needs usually can be translated in data tasks 2. Draw ovals around the function labels 3. Draw system boundary 4. Draw actors and connect them with use cases (if more intuitive, this can be done as step 2) 5. Specify include and extend relationships between use cases (yes, at the end - not before, as this may pull you into process thinking, which does not apply in UC diagramming).
  • 38. Use-Case Diagrams: Example [1] I. Begin with a Use Case! A user placing an order with a sales company might follow these steps : 1. Browse catalog and select items. 2. Call sales representative. 3. Supply shipping information. 4. Supply payment information. 5. Receive conformation number from salesperson. II. Then translate Use Case sequence into Diagram
  • 39. Use-Case Diagrams: Example [2] The salesperson could also be included in this use case diagram because the salesperson is also interacting with the ordering system.
  • 40. Use-Case Diagram Case Study [1] Vending Machine After client interview the following system scenarios were identified: – A customer buys a product – The supplier restocks the machine – The supplier collects money from the machine On the basis of these scenarios, the following three actors can be identified: Customer; Supplier; Collector (in this case Collector=Supplier)
  • 42. Use-Case Diagram Case Study [3] Introducing annotations (notes) and constraints.