Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal...

56
Week04 Project Requirements

Transcript of Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal...

Page 1: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Week04

Project Requirements

Page 2: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Agenda

• Identify all use cases– User Stories Technique– User Goal Technique– Event Decomposition Technique– CRUD Technique

• Build Use Case Diagram(s)• Document use cases using narratives and activity

diagrams• Identify security concerns and requirements• Define Operational and Executive reports (Covered next

week by Special Guest Speaker)

2

Page 3: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Learning Objectives• Explain why identifying use cases is the key to defining

functional requirements• Describe the two techniques for identifying use cases• Apply the user goal technique to identify use cases• Apply the event decomposition technique to identify use cases• Apply the CRUD technique to validate and refine the list of use

cases• Describe the notation and purpose for the use case diagram• Draw use case diagrams by actor and by subsystem

3

Page 4: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Use Cases

• Use case— an activity that the system performs, usually in response to a request by a user

• Use cases define functional requirements• Analysts decompose the system into a set of use

cases (functional decomposition) • Two techniques for Identifying use cases

– User goal technique– Event decomposition technique

• Name each use case using Verb-Noun

4

Page 5: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

User Goal Technique• This technique is the most common in industry• Simple and effective• Identify all of the potential categories of users of the

system• Interview and ask them to describe the tasks the

computer can help them with • Probe further to refine the tasks into specific user

goals, “I need to Ship items, Track a shipment, Create a return”

5

Page 6: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

User Goal TechniqueSome RMO CSMS Users and Goals

6

Page 7: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

User Goal Technique:Specific Steps

1. Identify all the potential users for the new system2. Classify the potential users in terms of their

functional role (e.g., shipping, marketing, sales)3. Further classify potential users by organizational level

(e.g., operational, management, executive)4. For each type of user, interview them to find a list of

specific goals they will have when using the new system (current goals and innovative functions to add value)

7

Page 8: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

User Goal TechniqueSpecific Steps (continued)

5. Create a list of preliminary use cases organized by type of user

6. Look for duplicates with similar use case names and resolve inconsistencies

7. Identify where different types of users need the same use cases

8. Review the completed list with each type of user and then with interested stakeholders

8

Page 9: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

User Story Format (one two sentences)

9

Page 10: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

User Story-Example(focus on one particular user for one particular goal for

one particular reason)

10

Page 11: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Another Example…

11

Page 12: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

User Stories(Focus is on intention, one need, no exceptions

or alternate paths etc.,)

12

Page 13: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

User Stories vs Use Cases

13

Page 14: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

14

Using a context diagram to help with identifying use cases- Example

Page 15: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Event Decomposition Technique

• More Comprehensive and Complete Technique– Identify the events that occur to which the system must

respond. – For each event, name a use case (verb-noun) that

describes what the system does when the event occurs

• Event– something that occurs at a specific time and place, can be described, and should be remembered by the system

15

Page 16: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Events and Use Cases

16

Page 17: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Types of Events

• External Event– an event that occurs outside the system, usually

initiated by an external agent or actor• Temporal Event

– an event that occurs as a result of reaching a point in time

• State Event– an event that occurs when something happens

inside the system that triggers some process– reorder point is reached for inventory item

17

Page 18: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

External Event Checklist

• External agent or actor wants something resulting in a transaction

– Customer buys a product

• External agent or actor wants some information– Customer wants to know product details

• External data changed and needs to be updated– Customer has new address and phone

• Management wants some information– Sales manager wants update on production plans

18

Page 19: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Temporal Event Checklist

• Internal outputs needed at points in time– Management reports (summary or exception)– Operational reports (detailed transactions)– Internal statements and documents (including

payroll)

• External outputs needed at points of time– Statements, status reports, bills, reminders

19

Page 20: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Finding the actual event that affects the system

20

Page 21: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Tracing a sequence of transactions resulting in many events

21

Page 22: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Perfect Technology Assumption

22

Don’t worry about functions built into system because of limits in technology and people. Wait until design.

Page 23: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Event Decomposition Technique:Specific Steps

1. Consider the external events in the system environment that require a response from the system

2. For each external event, identify and name the use case that the system requires

3. Consider the temporal events that require a response from the system

4. For each temporal event, identify and name the use case that the system requires and then establish the point of time that will trigger the use case

23

Page 24: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Event Decomposition Technique:Specific Steps (continued)

5. Consider the state events that the system might respond to, particularly if it is a real-time system in which devices or internal state changes trigger use cases.

6. For each state event, identify and name the use case that the system requires and then define the state change.

7. When events and use cases are defined, check to see if they are required by using the perfect technology assumption. Do not include events that involve such system controls as login, logout, change password, and backup or restore the database, as these are put in later.

24

Page 25: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Event Decomposition Technique: Benefits

• Events are broader than user goal: Capture temporal and state events

• Help decompose at the right level of analysis: an elementary business process (EBP)

• EBP is a fundamental business process performed by one person, in one place, in response to a business event

• Uses perfect technology assumption to make sure functions that support the users work are identified and not additional functions for security and system controls

25

Page 26: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Jerry KotubaSYST39409-Object Oriented

Methodologies26

Pharmacy System Example

Page 27: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Use Cases and CRUD Technique

• CRUD is Create, Read/Report, Update, and Delete (archive)

• Often introduced in database context• Technique to validate, refine or cross-check use

cases• NOT for primarily identifying use cases

27

Page 28: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Use Cases and CRUD Technique

• For Customer domain class, verify that there are use cases that create, read/report, update, and delete (archive) the domain class

28

Page 29: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

CRUD TechniqueSteps

29

1. Identify all the data entities or domain classes involved in the new system. (Review this next week)

2. For each type of data (data entity or domain class), verify that a use case has been identified that creates a new instance, updates existing instances, reads or reports values of instances, and deletes (archives) an instance.

3. If a needed use case has been overlooked, add a new use case and then identify the stakeholders.

4. With integrated applications, make sure it is clear which application is responsible for adding and maintaining the data and which system merely uses the data.

Page 30: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

CRUD TechniqueUse Case vs. Domain Class Table

30

To summarize CRUD analysis results, create a matrix of use cases and domain classes indicating which use case C, R, U, or D a domain class

Page 31: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Use Cases andBrief Use Case Descriptions

31

Brief use case description is often a one sentence description showing the main steps in a use case

Page 32: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

RMO CSMS

Project Use Cases

32

Page 33: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

RMO CSMS Project Use

Cases

33

Page 34: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

RMO CSMS Project

Use Cases

34

Page 35: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

RMO CSMS Project

Use Cases

35

Page 36: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

J.N.KotubaSYST39409 - Object Oriented

Methodologies36

Brief Description of Create New Order Use Case

Page 37: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

J.N.KotubaSYST39409 - Object Oriented

Methodologies37

Intermediate Description of Telephone Order Scenario for Create New Order Use Case

Page 38: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

J.N.KotubaSYST39409 - Object Oriented

Methodologies38

Fully Developed Description of Telephone Order Scenario for Create New Order Use Case

Page 39: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Use Case Diagrams

39

Use case diagram— a UML model used to graphically show uses cases and their relationships to actors

Recall UML is Unified Modeling Language, the standard for diagrams and terminology for developing information systems

Actor is the UML name for a end user Automation boundary— the boundary between the

computerized portion of the application and the users who operate the application

Page 40: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Use Case DiagramsSymbols

40

Page 41: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Final Word on Use Cases

• Large software projects usually organized into sub-systems and packages.

• Package is a placeholder– Each package contains a set of use cases for

handling a certain type of business activity.• E.g. Mail Order System

» Purchasing» Warehouse» Administration

Jerry KotubaSYST39409-Object Oriented

Methodologies41

Page 42: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Use Case Diagrams

Draw for each subsystem

42

Page 43: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Use Case Diagrams

Draw for actor, such as

customer

43

Page 44: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Use Case DiagramsDraw for internal RMO actors

44

Page 45: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Use Case DiagramsThe <<Includes>> relationship

45

A relationship between use cases where one use case is stereotypically included within the other use case— like a called subroutine. Arrow points to subroutine

Page 46: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Use Case Diagrams:Steps

46

1. Identify all the stakeholders and users who would benefit by seeing a use case diagram

2. Determine what each stakeholder or user needs to review in a use case diagram: each subsystem, for each type of user, for use cases that are of interest

3. For each potential communication need, select the use cases and actors to show and draw the use case diagram. There are many software packages that can be used to draw use case diagrams

4. Carefully name each use case diagram and then note how and when the diagram should be used to review use cases with stakeholders and users

Page 47: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Jerry KotubaSYST39409-Object Oriented

Methodologies47

Example without Package Notation

Page 48: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Jerry KotubaSYST39409-Object Oriented

Methodologies48

Example using Package Notation

Page 49: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Summary

49

Three types of events include external, temporal, and state events

Brief use case descriptions are written for use cases The CRUD technique is used to validate and refine the

use cases identified The use case diagram is the UML diagram used to

show the use cases and the actors The use case diagram shows the actors, the

automation boundary, the uses cases that involve each actor, and the <<includes>> relationship.

A variety of use case diagrams are drawn depending on the presentation needs of the analysis

Page 50: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Identify Security Requirements & Concerns

• Physical Security• Network Security• Application Security• File Security• User Security• Procedural Security

50

Page 51: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Physical Security

• First level of concern.• Physical access to a computer represents an

entry point into the system and must be controlled. All computers on a network must be secure.

• Critical equipment such as servers for example, must be located in secure, protected areas.

51

Page 52: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Network Security

• How will network traffic be protected so that the data can not be accessed without authorization?

52

Page 53: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Application Security

• In addition to securing computer equipment and shielding network traffic, it is necessary to protect all server based applications.

53

Page 54: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

File Security

• Computer configuration settings,users’ personal information, and other sensitive data stored in files must be protected.

54

Page 55: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

User Security

• User security requires identity management, and comprehensive password protection.

• E.g. minimum length and complexity of a password

55

Page 56: Week04 Project Requirements. Agenda Identify all use cases – User Stories Technique – User Goal Technique – Event Decomposition Technique – CRUD Technique.

Procedural Security

• A.k.a operational security• Defines how particular tasks are to be

performed– E.g. large scale data backups, storage of emails

and forms(physical paperwork)– Recovery

56