Use Case Model. C-S 5462 Use case model describes what the user expects the system to do –functional requirements may describe only the functionalities.

Slides:



Advertisements
Similar presentations
Week 2 The Object-Oriented Approach to Requirements
Advertisements

UML an overview.
Use Case & Use Case Diagram
Chapters 7 & 9 System Scope
Chapter 7 Structuring System Process Requirements
Use Case Modeling SJTU. Unified Modeling Language (UML) l Standardized notation for object-oriented development l Needs to be used with an analysis and.
CPSC 333: Foundations of Software EngineeringJ. Denzinger Small Test: Bank account manager System has to run on an automated teller machine. User must.
Ch 12: Object-Oriented Analysis
Requirements and Design
CS3773 Software Engineering Lecture 03 UML Use Cases.
Use Case Diagrams - UML (Thanks to Helen Albanese for the starting point for this brief presentation)
ATM User Interface Design. Requirements A bank customer is able to access his or her account using an automatic teller machine. To be able to use an ATM.
Tutorial 2. What is a UML Use Case Diagram? Use case diagrams model the functionality of a system using actors and use cases. Use cases are services or.
Use Case Diagram © copyright 2001 SNU OOPSLA Lab..
Systems Analysis and Design in a Changing World, Fourth Edition
Unit 211 Requirements Phase The objective of this section is to introduce software system requirements and to explain different ways of expressing these.
Object Oriented Analysis Process
COMP1007 Intro to Systems Requirements © Copyright De Montfort University 2002 All Rights Reserved COMP1007 Intro to System Requirements Lecture 2 Use-Cases.
Requirements Analysis 4. 1 Use Case I b504.ppt © Copyright De Montfort University 2000 All Rights Reserved INFO2005 Requirements Analysis Use-Cases.
Use Case Diagram.
Use Case Modeling. Use case diagram For each use case we develop  Object class diagram (with attributes only)  System sequence diagram (analysis) 
Unified Modeling Language
Chapter 7 Structuring System Process Requirements
Object-Oriented Analysis and Design
Chapter 7: The Object-Oriented Approach to Requirements
Use Case Analysis From soft systems methodology to understanding the system functionality.
Software Engineering UNIT 2. Functional Modelling.
® IBM Software Group © 2006 IBM Corporation Rational Software France Object-Oriented Analysis and Design with UML2 and Rational Software Modeler 06. Requirements.
Rational Unified Process (Part 1) CS3300 Fall 2015.
Use Case Modeling. Watch the video on use cases Review at minute 2:41-3:37.
1 CMPT 275 Software Engineering Requirements Analysis Phase Requirements Analysis Activity (Identifying Objects, Scenarios) Janice Regan,
4 2009/10 Object Oriented Technology 1 Topic 4: The Object-Oriented Approach to Requirements Adopted from: Ch.7 The Object-Oriented Approach to Requirements.
UML Diagrams: Class Diagrams The Static Analysis Model Instructor: Dr. Hany H. Ammar Dept. of Computer Science and Electrical Engineering, WVU.
Faculty of Computer & Information Software Engineering Third year
Introduction to Rational Rose 2000 v6.5 Copyright © 1999 Rational Software, all rights reserved 1 Rational Rose 2000 Class Diagrams.
7 Systems Analysis and Design in a Changing World, Fifth Edition.
1 Use Case Modeling Reference: RUP Doc. Use Case Example 2.
A Use Case Primer 1. The Benefits of Use Cases  Compared to traditional methods, use cases are easy to write and to read.  Use cases force the developers.
Use Case Modeling Chapter 7 Part of Requirements Modeling Designing Concurrent, Distributed, and Real-Time Applications with UML Hassan Gomaa (2001)
1 System Analysis and Design Using UML INSTRUCTOR: Jesmin Akhter Lecturer, IIT, JU.
Use Case Diagram The purpose is to communicate the system’s functionality and behaviour to the customer or end user. Mainly used for capturing user requirements.
CSC480 Software Engineering Lecture 8-9 September 20, 2002.
1 Graph Coverage (6). Reading Assignment P. Ammann and J. Offutt “Introduction to Software Testing” ◦ Section
CS212: Object Oriented Analysis and Design Lecture 32: Use case and Class diagrams.
Systems Analysis and Design in a Changing World, Fourth Edition
Chapter 7 Structuring System Process Requirements Modern Systems Analysis and Design Fourth Edition Jeffrey A. Hoffer Joey F. George Joseph S. Valacich.
22 August, 2007Information System Design IT60105, Autumn 2007 Information System Design IT60105 Lecture 8 Use Case Diagrams.
Refining the Use Cases 1. How Use Cases Evolve  Early efforts typically define most of the major use cases.  The refining stages complete the process.
Session 5 Object Model Development. OOAD with UML / Session 5 / 2 of 19 Review A class icon is a rectangle with three sections within it An object is.
Chapter 6: Structuring Requirements: Use Case Description and Diagrams Object-Oriented Systems Analysis and Design Joey F. George, Dinesh Batra, Joseph.
Use Case Diagrams. Introduction In the previous Lecture, you saw a brief review of the nine UML diagrams. Now that you have the clear, you'll start to.
© 2005 by Prentice Hall Chapter 7 Structuring System Process Requirements Modern Systems Analysis and Design Fourth Edition Jeffrey A. Hoffer Joey F. George.
UML Fundamental Elements. Structural Elements Represent abstractions in our system. Elements that encapsulate the system's set of behaviors. Structural.
7 Systems Analysis – ITEC 3155 The Object Oriented Approach – Use Cases.
1 7 Systems Analysis and Design in a Changing World, 2 nd Edition, Satzinger, Jackson, & Burd Chapter 7 The Object-Oriented Approach to Requirements.
Chapter 3: Software Design –Use case Diagram Nouf Alghanmi.
1 After the scenarios are formulated Find all the use cases in the scenario Describe each of these use cases in more detail Participating actors Describe.
Introduction to Unified Modeling Language (UML) By Rick Mercer with help from The Unified Modeling Language User Guide, Grady Booch, James Rumbaugh, Ivar.
Software Engineering USE CASE DIAGRAM.
1 Team Skill 3 Defining the System Part 1: Use Case Modeling Noureddine Abbadeni Al-Ain University of Science and Technology College of Engineering and.
Systems Analysis and Design in a Changing World, Fourth Edition
CMPE 280 Web UI Design and Development August 29 Class Meeting
M.M. Pickard, PhD A Primer on Use Cases (Reference: UML Superstructure Specification, v2.1.1)
Use Case Model.
Introduction to Unified Modeling Language (UML)
The Process of Object Modeling
Concepts, Specifications, and Diagrams
SAD ::: Spring 2018 Sabbir Muhammad Saleh
CIS 375 Bruce R. Maxim UM-Dearborn
Using Use Case Diagrams
Presentation transcript:

Use Case Model

C-S 5462 Use case model describes what the user expects the system to do –functional requirements may describe only the functionalities that are visible to the user –requirements view may include additional functionalities to elaborate those in the previous step –design view consists of use case diagrams and textual descriptions

C-S 5463 Elements of a Use Case diagram actor Use case association generalization dependency System actor

C-S 5464 Definitions System –a black box that describes the system or subsystem that is modeled –example: ATM system, account verification subsystem –represented optionally as a rectangle in the use case diagram, but generally not shown Actor –a role played by an external entity that interacts with the system –One object may play multiple roles in a context in which case there will be multiple actors example: bank manager as a customer

C-S 5465 Definitions (continued) Primary actor –an actor who initiates the major, main or important use cases in the system –example : a customer in a banking system Secondary actor –an actor who is involved with one or more use cases but does not initiate the use cases –example : database The concepts of primary and secondary actors will be useful in ranking the roles played by the actors

C-S 5466 Definitions (continued) Generalization between actors –one actor can be a specialization of another actor –based on the same concept as the specialization relationship between classes –example : preferred customer in a bank is a specialization of a customer

C-S 5467 Definitions (continued) Use case –an important functionality to be implemented and is visible to the actors –an interacting behavior between an actor and the system Must yield an observable result to the actor –example: “deposit” in a banking system

C-S 5468 Definitions (continued) Association –an interaction between an actor and a use case –represented by an arrow between an actor and a use case –unidirectional associations must be represented by arrows direction of arrow indicate information flow –bi-directional associations can be represented by double-sided arrows or straight lines

C-S 5469 Definitions (continued) Generalization between use cases –based on the same concept as generalization between classes; uses the same symbol –one use case can be designated as a specialization of another use case –example: “withdraw with overdraft protection” is a specialization of “withdraw”

C-S Definitions (continued) “include” dependency –one use case may include another use case –if use case A includes a use case B, B must be implemented in order to implement A –based on the same concept as modular programming –represented as a dashed arrow from A to B with a label “ >” –example : “withdraw” includes “update account”

C-S Definitions (continued) “extend” dependency –one use case may be extended by another use case –if use case A is extended by a use case B, then both A and B can be independently implemented and used A will occasionally use B depending on some constraints –based on the same concept as modular programming –represented as a dashed arrow from B to A with a label “ >” Notice that the arrow is reversed –example : “withdraw” is extended by “check for privileged customer”

C-S Constraints in a Use Case model every use case must be connected to an actor or be included in another use case or extends another use case every use case connected to an actor must return an observable result to the actor –may be data or confirmation of termination of an action

C-S How to find actors? those that interact with the system (provide input, observe results, provide control information, …) –primary actors those that are used by the system but external to the system –secondary actors such as data stores information about actors can be found in the problem description generally, users of the system are primary actors

C-S How to find use cases? every requirement is a use case every functionality that supports the implementation of a requirement is a use case –design issue –found when the first (abstract) use case model is refined to express a design

C-S How to find use case relationships? extracted from the application domain must be justifiable from the application domain or from the designer’s choice examples –“withdraw” includes “update account” is justifiable from application domain –“withdraw” is extended by “withdraw with overdraft protection” is a designer’s choice designer can always implement two different versions of withdrawals

C-S Use case narrative not part of UML notation textual descriptions of a use case –important for design and implementation of use case most OO tools provide a mechanism to add use case narratives –see Rational Rose for example may include additional information and constraints on the use cases –pre and post-conditions

C-S Use case instance a particular situation of a use case generally described using an activity diagram (to be discussed later) –shows the algorithmic version of a use case there can be several instances of the same use case, each having a different result examples –Successful withdrawal –“withdraw” denied because of insufficient balance –“withdraw” denied because of overdraft violation

C-S Case Study - ATM Model only the transactions Customer accounts assumed to exist –Opening and closing of accounts is handled by another portion of the system Include operations “deposit”, withdraw”, “check balance”, “transfer” If balance is zero or less than the amount to be withdrawn, then withdrawal should fail

C-S Deposit Withdraw Check balance Transfer Database customer Login Logout All dependency relationships are of type >

C-S Use case narratives - ATM Deposit –Using this functionality, a user will be able to add some money to his/her account –Account identification and amount to be deposited must be input –Upon completion, the balance in the account will be updated to include the additional amount Check balance –A user can check the balance in an account using this functionality –Account identification must be input and the balance in the account will be output –The account remains unchanged upon completion

C-S Use case narratives – ATM (continued) Write the narratives for “withdraw” and “transfer” The narratives more or less reflect the requirements as written in a requirements document A requirements document may also be referred with a cross reference in each requirement pointing to the appropriate use case in the use case diagram

C-S Use case instance – “deposit” Deposit (ACCOUNT_IDENTIFIER acct, MONEY amount) { if (validate_account (acct)) { account = retrieve_account (acct); account.balance = account.balance + amount; write_account (account); // update the database } else display (“Invalid account identifier”); }

C-S Deposit Withdraw Check balance Transfer Database customer Login Logout Validate account Update account All dependency relationships are of type > Use case diagram for ATM - revisited

C-S ATM - Exercises Write the narratives for the revised version of ATM use case diagram Enhance the diagram to include the following: –A manager can open an account –A manager can close an account –An account may come with overdraft protection during withdrawal