uc diuse case diagram

28
Object-Oriented Modeling U C Di Use Case Diagram Slides accompanying UML@Classroom Slides accompanying UML@Classroom Version 1.0 Business Informatics Group Institute of Software Technology and Interactive Systems Vienna University of Technology Favoritenstraße 9-11/188-3, 1040 Vienna, Austria phone: +43 (1) 58801-18804 (secretary), fax: +43 (1) 58801-18896 [email protected], www.big.tuwien.ac.at

Upload: others

Post on 07-Jun-2022

2 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: UC DiUse Case Diagram

Object-Oriented Modeling

U C DiUse Case Diagram

Slides accompanying UML@ClassroomSlides accompanying UML@ClassroomVersion 1.0

Business Informatics GroupInstitute of Software Technology and Interactive Systems Vienna University of Technologyy gyFavoritenstraße 9-11/188-3, 1040 Vienna, Austriaphone: +43 (1) 58801-18804 (secretary), fax: +43 (1) [email protected], www.big.tuwien.ac.at

Page 2: UC DiUse Case Diagram

Literature

The lecture is based on the following book:UML @ ClUML @ Classroom: An Introduction to Object-Oriented ModelingMartina Seidl, Marion Scholz, Christian Huemer , ,and Gerti Kappel

Springer Publishing, 2015

ISBN 3319127411

Use Case DiagramStructure ModelingState Machine DiagramS DiSequence DiagramActivity Diagram

© BIG / TU Wien 3

Page 3: UC DiUse Case Diagram

Content

IntroductionUse casesUse casesActorsRelationships between use cases and actors Relationships between use casesRelationships between actorsDescription of use casesDescription of use casesBest practicesTypical errorsypNotation elements

© BIG / TU Wien 3

Page 4: UC DiUse Case Diagram

Introduction

The use case is a fundamental concept of many object-oriented development methodsdevelopment methods.Use case diagrams express the expectations of the customers/stakeholders

ti l f d t il d d iessential for a detailed designThe use case diagram is used during the entire analysis and design process.We can use a use case diagram to answer the following questions:

What is being described? (The system.)Who interacts with the system? (The actors )Who interacts with the system? (The actors.)What can the actors do? (The use cases.)

© BIG / TU Wien 3

Page 5: UC DiUse Case Diagram

Example: Student Administration Systemp y

System (what is being described?)(what is being described?)

Student administration system

Actors (who interacts with the system?)

ProfessorProfessor

Use cases(what can the actors do?)(what can the actors do?)

Query student dataIssue certificateAnnounce exam

© BIG / TU Wien 4

Page 6: UC DiUse Case Diagram

Use Case

Describes functionality expected from the system under development.Provides tangible benefit for one or more actors that communicate withProvides tangible benefit for one or more actors that communicate with this use case.Derived from collected customer wishes.Set of all use cases describes the functionality that a system shall provide.

Documents the functionality that a system offers.y yAlternative notations:

© BIG / TU Wien 5

Page 7: UC DiUse Case Diagram

Actor (1/3)( )

Actors interact with the system …by using use casesby using use cases, i.e., the actors initiate the execution of use cases.by being used by use cases, i e the actors provide functionality for the execution of use casesi.e., the actors provide functionality for the execution of use cases.

Actors represent roles that users adopt.Specific users can adopt and set aside multiple roles simultaneously.

Actors are not part of the system, i.e., they are outside of the system boundaries.Alternative notations:Alternative notations:

6

Page 8: UC DiUse Case Diagram

Actor (2/3)( )

Usually user data is also administered within the system. This data is modeled within the system in the form of objects and classesmodeled within the system in the form of objects and classes.Example: actor Assistant

The actor Assistant interacts with the system Laboratory A i t by using itAssignment by using it.The class Assistant describes objects representing user data (e.g., name, ssNr, …).

© BIG / TU Wien 7

Page 9: UC DiUse Case Diagram

Actor (3/3)( )

HumanE g Student ProfessorE.g., Student, Professor

Non-humanE.g., E-Mail Server

Primary: has the main benefit of the execution of the use caseSecondary: receives no direct benefitActive: initiates the execution of the use caseActive: initiates the execution of the use casePassive: provides functionality for the execution of the use case

Example:

HumanPrimary

HumanPrimary

Non-human

PrimaryActive

PrimaryActive

Human

8SecondaryPassive

SecondaryActive

Page 10: UC DiUse Case Diagram

Relationships between Use Cases and Actors p

Actors are connected with use cases via solid lines (associations).Every actor must communicate with at least one use caseEvery actor must communicate with at least one use case.An association is always binary.Multiplicities may be specified.

89

Page 11: UC DiUse Case Diagram

Relationships between Use Cases«inlcude» - Relationship

The behavior of one use case (included use case) is integrated in the behavior of another use case (base use case)behavior of another use case (base use case)

Base use caserequires the behavior of the included use case to be able to offer its functionalitycase to be able to offer its functionality

Included use case may be executed on its own

Example:

© BIG / TU Wien 10

Page 12: UC DiUse Case Diagram

Relationships between Use Cases«extend» - Relationship

The behavior of one use case (extending use case) may be integrated in the behavior of another use case (base use case) but does not havein the behavior of another use case (base use case) but does not have to.Both use cases may also be executed independently of each other.

Base use case

Extending use case

A decides if B is executed.Extension points define at which point the behavior is integrated

Extending use case

Extension points define at which point the behavior is integrated.Conditions define under which circumstances the behavior is integrated.

© BIG / TU Wien 11

Page 13: UC DiUse Case Diagram

Relationships between Use Cases«extend» - Relationship: Extension Points

Extension points are written directly within the use case.Specification of multiple extension points is possibleSpecification of multiple extension points is possible.

Example:

© BIG / TU Wien 12

Page 14: UC DiUse Case Diagram

Relationships between Use CasesGeneralization of Use Cases

Use case A generalizes use case B.B inherits the behavior of A and may Base use caseB inherits the behavior of A and may either extend or overwrite it.B also inherits all relationships from A.

Base use case

Sub use case

B adopts the basic functionality of A but decides itself what part of A is executed or changed.A may be labeled {abstract}A may be labeled {abstract}

Cannot be executed directlyOnly B is executable

E lExample:

© BIG / TU Wien 13

Page 15: UC DiUse Case Diagram

Relationships between ActorsGeneralization of Actors

Actor A inherits from actor B.A can communicate with X and YA can communicate with X and Y.B can only communicate with Y.Multiple inheritance is permitted.

Super-actor

Sub-actor

Abstract actors are possible.

Example:Example:

Professor AND Assistant neededfor executing Query student data

Professor OR Assistant neededfor executing Query student data

© BIG / TU Wien 14

for executing Query student data for executing Query student data

Page 16: UC DiUse Case Diagram

Description of Use Casesp

Structured approachNameNameShort descriptionPrecondition: prerequisite for successful executionP t diti t t t ft f l tiPostcondition: system state after successful executionError situations: errors relevant to the problem domainSystem state on the occurrence of an errorActors that communicate with the use caseTrigger: events which initiate/start the use caseStandard process: individual steps to be taken p pAlternative processes: deviations from the standard process

[A. Cockburn: Writing Effective Use Cases, Addison Wesley, 2000][A. Cockburn: Writing Effective Use Cases, Addison Wesley, 2000]

© BIG / TU Wien 15

Page 17: UC DiUse Case Diagram

Description of Use Cases - Examplep p

Name: Reserve lecture hallShort description: An employee reserves a lecture hall at the university for an event.Precondition: The employee is authorized to reserve lecture halls.Postcondition: A lecture hall is reserved.Error situations: There is no free lecture hall.System state in the event of an error: The employee has not reserved a lecture hall.Actors: EmployeeTrigger: Employee requires a lecture hall.Standard process: (1) Employee logs in to the system.

(2) Employee selects the lecture hall.(3) Employee selects the date.(4) System confirms that the lecture hall is free.(5) Employee confirms the reservation.

Alternative processes: (4’) Lecture hall is not free.(5’) System proposes an alternative lecture hall.(6’) Employee selects alternative lecture hall and confirms the reservation.

© BIG / TU Wien 16

Page 18: UC DiUse Case Diagram

Best Practices«include»

UML standard Best practice

© BIG / TU Wien 17

Page 19: UC DiUse Case Diagram

Best Practices«extend»

UML standard Best practice

© BIG / TU Wien 18

Page 20: UC DiUse Case Diagram

Best PracticesIdentifying Actorsy g

Who uses the main use cases?Who needs support for their daily work?Who needs support for their daily work?Who is responsible for system administration?What are the external devices/(software) systems with which the system must communicate?Who is interested in the results of the system?

© BIG / TU Wien 19

Page 21: UC DiUse Case Diagram

Best PracticesIdentifying Use Casesy g

What are the main tasks that an actor must perform? Does an actor want to query or even modify information contained inDoes an actor want to query or even modify information contained in the system?Does an actor want to inform the system about changes in other

t ?systems?Should an actor be informed about unexpected events within the system?y

© BIG / TU Wien 20

Page 22: UC DiUse Case Diagram

Best PracticesTypical Errors To Avoid (1/5)y ( )

Use case diagrams do not model processes/workflows!

© BIG / TU Wien 21

Page 23: UC DiUse Case Diagram

Best PracticesTypical Errors To Avoid (2/5)y ( )

Actors are not part of the system, hence, they are positioned outside the system boundaries!the system boundaries!

© BIG / TU Wien 22

Page 24: UC DiUse Case Diagram

Best PracticesTypical Errors To Avoid (3/5)y ( )

Use case Issue information needs EITHER one actor i OR t f tiAssistant OR one actor Professor for execution

© BIG / TU Wien 23

Page 25: UC DiUse Case Diagram

Best PracticesTypical Errors To Avoid (4/5)y ( )

Many small use cases that have the same objective may be grouped to form one use case

© BIG / TU Wien 24

Page 26: UC DiUse Case Diagram

Best PracticesTypical Errors To Avoid (5/5)y ( )

The various steps are part of the use cases not separate use casesThe various steps are part of the use cases, not separate use cases themselves! -> NO functional decomposition

© BIG / TU Wien 25

Page 27: UC DiUse Case Diagram

Notation Elements (1/2)

Name Notation Description

( )

System Boundaries between the system and the users of the systemy

Use case Unit of functionality of the system

A t R l f th f th tActor Role of the users of the system

© BIG / TU Wien 40

Page 28: UC DiUse Case Diagram

Notation Elements (2/2)

Name Notation Description

( )

Association Relationship between use cases and actors

Generalization Inheritance relationship between Generalization actors or use cases

Extend B extends A: optional use of useExtend relationship

B extends A: optional use of usecase B by use case A

Include relationship

A includes B: required use of usecase B by use case A

© BIG / TU Wien 41