Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory1 Requirements Change Management Section Six Version: 1.0.

Slides:



Advertisements
Similar presentations
Configuration management
Advertisements

Software change management
Configuration management
Configuration Management
Software Quality Assurance Plan
Software Quality Assurance Plan
Chapter 7: Key Process Areas for Level 2: Repeatable - Arvind Kabir Yateesh.
PRJ270: Essentials of Rational Unified Process
Overview Lesson 10,11 - Software Quality Assurance
Requirements Specification
Computer Engineering 203 R Smith Requirements Management 6/ Requirements IEEE Standard Glossary A condition or capability needed by a user to solve.
SE 555 Software Requirements & Specification Requirements Management.
Software Project Transition Planning
Recall The Team Skills 1. Analyzing the Problem 2. Understanding User and Stakeholder Needs 3. Defining the System 4. Managing Scope 5. Refining the System.
SE 555 Software Requirements & Specification Beyond Requirements Based on Weigers Chapter17.
Requirements Management
DITSCAP Phase 2 - Verification Pramod Jampala Christopher Swenson.
Configuration Management
Chapter 25 – Configuration Management 1Chapter 25 Configuration management.
4. Quality Management System (QMS)
4. Quality Management System (QMS)
This chapter is extracted from Sommerville’s slides. Text book chapter
What is Business Analysis Planning & Monitoring?
S/W Project Management
RUP Requirements RUP Artifacts and Deliverables
Introduction to Software Quality Assurance (SQA)
Introduction to RUP Spring Sharif Univ. of Tech.2 Outlines What is RUP? RUP Phases –Inception –Elaboration –Construction –Transition.
Software Configuration Management
RUP Implementation and Testing
©Ian Sommerville 2000 Software Engineering, 6th edition. Chapter 6 Slide 1 Requirements Engineering Processes l Processes used to discover, analyse and.
 To explain the importance of software configuration management (CM)  To describe key CM activities namely CM planning, change management, version management.
Configuration Management (CM)
IT Requirements Management Balancing Needs and Expectations.
ISM 5316 Week 3 Learning Objectives You should be able to: u Define and list issues and steps in Project Integration u List and describe the components.
Develop Project Charter
Managing Change 1. Why Do Requirements Change?  External Factors – those change agents over which the project team has little or no control.  Internal.
Configuration Management and Change Control Change is inevitable! So it has to be planned for and managed.
CMSC 345 Fall 2000 Requirements Overview. Work with customers to elicit requirements by asking questions, demonstrating similar systems, developing prototypes,
Software Configuration Management (SCM). Product Developer Disciplines One view of the world is that there are three types of activities are required.
Quick Recap Monitoring and Controlling. Lesson 11: Monitoring and Controlling Project Work Topic 11A: Identify the Monitor and Control Project Work Process.
Requirement Engineering. Recap Elaboration Behavioral Modeling State Diagram Sequence Diagram Negotiation.
Purpose: The purpose of CMM Integration is to provide guidance for improving your organization’s processes and your ability to manage the development,
Maintaining and Sustaining System Integrity Configuration Management for Transportation Management Systems Configuration management (CM) describes a series.
Rational Requirements Management with Use Cases v5.5 Copyright © Rational Software, all rights reserved 1 Requirements Management with Use Cases.
Rational Unified Process Fundamentals Module 4: Core Workflows II - Concepts Rational Unified Process Fundamentals Module 4: Core Workflows II - Concepts.
1 Chapter 12 Configuration management This chapter is extracted from Sommerville’s slides. Text book chapter 29 1.
Requirements Engineering Requirements Validation and Management Lecture-24.
Requirements Engineering Requirements Management Lecture-25.
State of Georgia Release Management Training
An Agile Requirements Approach 1. Step 1: Get Organized  Meet with your team and agree on the basic software processes you will employ.  Decide how.
Requirements Management with Use Cases Module 2: Introduction to RMUC Requirements Management with Use Cases Module 2: Introduction to RMUC.
USDA 2016 Financial Management Training Transforming Shared Services Change Management Presented by Ron Gros.
Configuration & Build Management. Why Software Configuration Management ? The problem: Multiple people have to work on software that is changing More.
Chapter 25 – Configuration Management 1Chapter 25 Configuration management.
Configuration Management
Software Configuration Management
Software Project Configuration Management
Managing the Project Lifecycle
Chapter 11: Software Configuration Management
Software Configuration Management
Chapter 18 Maintaining Information Systems
Configuration Management
Software Configuration Management
Engineering Processes
KEY PROCESS AREAS (KPAs)
Chapter 11: Software Configuration Management
Requirements Management - I
Software Reviews.
Software Configuration Management
Presentation transcript:

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory1 Requirements Change Management Section Six Version: 1.0 Mehr 1386

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory2 Why Do Requirements Change? We failed to ask the right people the right questions at the right time The problem being solved changed The users changed their minds or their perceptions The external environment changed We failed to create a process to help manage change Our understanding of the problem improved Why

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory3 Stable and volatile requirements Requirements changes occur while –the requirements are being elicited, analysed and validated and – after the system has gone into service Some requirements are usually more subject to change than others –Stable requirements are concerned with the essence of a system and its application domain. They change more slowly than volatile requirements. –Volatile requirements are specific to the instantiation of the system in a particular environment and for a particular customer. What

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory4 Types of volatile requirement Mutable requirements –These are requirements which change because of changes to the environment in which the system is operating Emergent requirements –These are requirements which cannot be completely defined when the system is specified but which emerge as the system is designed and implemented Consequential requirements –These are requirements which are based on assumptions about how the system will be used. When the system is put into use, some of these assumptions will be wrong. Compatibility requirements –These are requirements which depend on other equipment or processes. What

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory5 Requirements change factors Requirements errors, conflicts and inconsistencies –As requirements are analysed and implemented, errors and inconsistencies emerge and must be corrected. These may be discovered during requirements analysis and validation or later in the development process. Evolving customer/end-user knowledge of the system –As requirements are developed, customers and end-users develop a better understanding of what they really require from a system. Technical, schedule or cost problems –Problems may be encountered in implementing a requirement. It may be too expensive or take too long to implement certain requirements. What

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory6 Requirements change factors Changing customer priorities Customer priorities change during system development as a result of a changing business environment, the emergence of new competitors staff changes, etc. Environmental changes The environment in which the system is to be installed may change so that the system requirements have to change to maintain compatibility Organisational changes The organisation which intends to use the system may change its structure and processes resulting in new system requirements What

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory7 Managing Changing Requirements - Overview Problem Solution Space Problem Space Needs Features Software Requirements The Product To Be Built Test Procedures DesignUser Docs Traceability What

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory8 Change requests come from many sources throughout each iteration of the product lifecycle A Key to Managing Change All requests go through a single channel Maint Test Code Design Req Customer and End-User inputs Marketing New Feature New Requirement Bug Help Desk End-User inputs Approved Decision Process (CCB) Single Channel for Approval Coders inputs Testers inputs Change Request (CR) What

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory9 Configuration & Change Management Controls change to, and maintains the integrity of, a project’s artifacts'.

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory10 Configuration & Change Management Identifying configuration items (Requirements Artifact set, …), Restricting changes to those items (Requirements Artifact set, …), Auditing changes made to those items, Defining and managing configurations of those items.

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory11 Requirements Configuration Management Configuration management of requirements is important for the same reasons that configuration management of source code is important. Benefits of requirements management under CM –Prevent unauthorized change –Preserve revisions of requirements documents –Retrieve previous versions of documents –Allow a managed baseline release strategy –Prevent simultaneous update of documents What

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory12 Metrics for Requirements Management What types of questions to ask? –How many requirements do we have? –What percentage are in the baseline? –What critical requirements haven’t been implemented? –What resources are needed to put in this new feature? –What’s the estimated cost of the proposed changes? –How many changes since the last customer review? Who authorized the changes? What’s the impact on test ? What

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory13 Configuration & Change Management Workflow in RUP

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory14 Plan Project Configuration & Change Control Establishing project configuration management policies Establishing policies and processes for controlling product change Documenting this information in the Configuration Management Plan

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory15 Create Project Configuration Management (CM) Environments Making sure the essential artifacts are available to developers and integrators in the various private and public workspaces They are adequately baselined and stored for subsequent use.

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory16 Controlling Requests for Change Require all changes go through a single channel Have a documented process for handling change requests Contents of a change request: –What artifact or artifacts it concerns –Problem description –Suggested solution –Priority Should be submitted to a Change Control Board (CCB) or other review authority How

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory17 Manage Change Requests (1/2) Submit Change Request –requests for new features, enhancements, corrections, changed requirements,... –Any role may submit a change request as part of any activity throughout the project lifecycle. Review Change Request –To determine if the Change Request (CR) should be accepted or flagged for rejection.

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory18 Manage Change Requests (2/2) Confirm Duplicate or Rejected CR –A designated CCB administrator should be assigned to confirm a suspected duplicate or invalid change request.CCB Verify Changes in Build –Confirms that a Change Request has been completed, typically by conducting subset of tests on one or more builds.

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory19 A Sample Change Request (1/2) Identification Project: Change Request Number: Change Request Type: (Problem or Enhancement) Title: Date Submitted: Originator: Change Request Priority: Current Problem Description of the current problem: Critical Failure: Nuisance: Enhancement: New Requirement: Conditions under which the problem was observed: Current Environment: Hardware Operating System Compiler Source of the current problem: Cost or Savings Impact of the current problem: Proposed Change (Originator) Description of the proposed change: Estimated cost to implement the proposed change: Proposed Change (Change Review Team) Action: Approved:

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory20 A Sample Change Request (2/2) Disapproved: Deferred: Description of the proposed change: Affected Configuration Items: Category: Error Fix: Enhancement: New Feature: Other: Resolution Estimated cost to implement the proposed change: Implementer: Actual time to implement change: Analysis: Implementation: Test: Documentation: Affected Number of Lines of Code: Assessment Test Methods: Inspection Analysis Demonstration Test: Test Platforms: Test Cases: Change Review Team Disposition Changes Approved and Accepted:

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory21 Monitor & Report Configuration Status Ensuring that artifacts and their associated baselines are available. Determining if required artifacts are stored in a controlled library and baselined. Supporting project Configuration Status Accounting activities. Facilitating reporting of change request information, especially the activities related to work performed against defect and enhancement requests. Ensuring that data is "rolled-up" and reported for the purposes of tracking progress and trends.

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory22 Change and Deliver Configuration Items The creation of workspaces, accessing project artifacts, making changes to those artifacts, delivering the changes for inclusion in the overall product, by any role in the project team. The building of the product, creation of baselines and promotion of the baselines for availability to the rest of the development team.

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory23 Manage Baselines & Releases The frequency and formality in which baselines are created are described in the CM Plan. The degree of formality is clearly much higher for a product being released to a customer than for executable releases within the internal project team.

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory24 Requirements Management Architecture What

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory25 Business Needs drive Customer Needs which drive User Needs which demand Product Features that drive Software Requirements that we developers Implement and Test What Is Requirements Traceability? What

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory26 Why Use Requirements Traceability? Assure quality –Verify the implementation fulfills all requirements –Verify the application does only what was intended Help manage change –Understand the impact of a change –Find related requirements Why

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory27 Requirement Traceability Strategy Stakeholder Requests Design Model Supplementary Specification End-User Documentation Materials and Training Materials Use-Case Model Vision Test Model Features Software Requirements Needs What

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory28 1. Trace top-level requirements into detailed requirements 2. Trace requirements into design 3. Trace requirements into test procedures 4. Trace requirements into user documentation plan Design Software Design Descriptions Object Models Test Suites Test 2 3 Req A 1 Product Requirements (Features) Detailed Requirements (Use Cases) Req B Documentation Plan User Docs 4 Traceability Paths What

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory29 Link Feature to Use Case Verifies that all lower level (derived requirements) are consistent with stakeholder needs Vision Document FEAT10:The recycling machine will allow the addition of new bottle types. [UC4: Use Case “Add New Bottle Type”] New kinds of bottles can be added to the machine by starting it in ‘learning mode’ and inserting 5 samples … How

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory30 Link Feature to Subflow Within a Use Case Vision Document FEAT14:The recycling machine will sound an alarm if an invalid item is deposited. UC1: Use Case “Recycle Items” The user uses this machine to automatically … UC1.1 Basic Flow UC1.1.1 The use case starts when … … UC1.1.6 End of Use Case … Alternative Flows [UC1.2 Deposit Item Not Valid …] UC1.2.1 If at step UC1.1.2, the … UC1.2.2 The item will be … UC1.2.3 An alarm will sound … UC1.2.4 Return to step UC1.1.2 … UC1.3 Printer out of Paper … If at step UC1.1.4, the paper sensor … How

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory31 Link Feature to Section of a Use Case Vision Document FEAT24:The recycling machine shall recognize deposit items with 95% reliability. UC1: Use Case “Recycle Items” The user uses this machine to automatically … UC1.1 Basic Flow Alternative Flows UC1.2 Deposit Item Not Valid Special Requirements [UC1.17 Recycle items must be recognized with 95% reliability]... Use-Case Diagram How

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory32 Link Feature to Other Requirements Verifies that all lower level (derived requirements) are consistent with stakeholder needs Vision Document FEAT101:The system shall provide maximum passenger comfort at all times. Supplementary Specification SUPP201:The motor control servo algorithm shall provide smooth acceleration and deceleration profiles with no detectable jerks, overshoots or undershoots. Hardware Requirements Specification HR271:The motor control amplifier and servo subsystem shall provide sufficient capacity to accelerate and decelerate at a rate of 1G. HR272:The environmental control system shall maintain the temperature of the elevator cabin to within 2 degrees C at all times How

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory33 Link Requirements To Implementation Objects Verifies that implementation supports the real requirements Product Requirements Document FEAT101:The system shall provide maximum passenger comfort at all times. Supplementary Specification SUPP201:The motor control servo algorithm shall provide smooth acceleration and deceleration profiles with no detectable jerks, overshoots, or undershoots. Object Specifications Object001 Name: AccelerationServo Description: Algorithm to control acceleration and.... Methods: Servo Algorithm, Motor Feedback Attributes: Location, Velocity, Acceleration How

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory34 All Requirements Should Trace to Test! Left path - Verifies that all requirements have associated tests. Right path - Validates that all requirements have been met. Vision Document FEAT101:The system shall provide maximum passenger comfort at all times. Supplementary Specification SUPP201:The motor control servo algorithm shall provide smooth acceleration and deceleration profiles with no detectable jerks, overshoots, or undershoots. Elevator Test Specification ET301:The elevator shall be instrumented with the 2000 Test System and tested to assure that acceleration and deceleration profiles are monotonic and.... System Validation Protocol SVP501:Test for passenger comfort by How

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory35 Viewing Links - Traceability Matrix How

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory36 Viewing Links: Tree Report Tree reports show the full hierarchy of traceability links How

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory37 Sample Queries Show me all user needs that are not linked to product features Show me the status of tests on all use cases in Iteration #3 Show me all supplementary requirements linked to tests whose status is untested Show me the results of all tests that failed, in order of criticality Show me the features scheduled for this release, which user needs they satisfy, and their status What

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory38 Change Management User Documentation Specifications Design Specifications Test Specifications Use-Case Model Supplementary Specifications Features Software Requirements Vision Document Change Management What

Amirkabir University of Technology, Computer Engineering Faculty, Intelligent Systems Laboratory39 Links to requirements that have changed are marked as “suspect” Suspect links must be resolved by the user Req A before edit “if return value > $5” Req B Req C “if return value > $2” Req A after edit Req C Req B Impact Analysis by Traceability Links What