Configuration Management



Similar documents
Configuration Management Fundamentals

Configuration & Build Management

The Configuration Management process area involves the following:

SOFTWARE CONFIGURATION MANAGEMENT GUIDEBOOK

CMS Policy for Configuration Management

Space Project Management

Configuration Management in Software Development Life Cycle

Configuration Management One Bite At A Time

ISO 9001 and ISO Quality Management Guidance for CM Relative to CMII (Rev B)

Page 1. Outline of the Lecture. What is Software Configuration Management? Why Software Configuration Management?

Configuration Management Practices

CONFIGURATION MANAGEMENT PLAN GUIDELINES

The purpose of Capacity and Availability Management (CAM) is to plan and monitor the effective provision of resources to support service requirements.

Requirements Management John Hrastar

Software Configuration Management. Addendum zu Kapitel 13

Chapter 13 Configuration Management

Engineering a EIA - 632

Computer programs (both source and executable) Documentation (both technical and user) Data (contained within the program or external to it)

Checklist. Standard for Medical Laboratory

How To Integrate Software And Systems

Configuration Management ISO 10007

CHAPTER 7 Software Configuration Management

Reaching CMM Levels 2 and 3 with the Rational Unified Process

Software Configuration Management

Sound Transit Internal Audit Report - No

ISO :2005 Requirements Summary

DO-254 Requirements Traceability

General Principles of Software Validation; Final Guidance for Industry and FDA Staff

Module 12. Software Project Monitoring and Control. Version 2 CSE IIT, Kharagpur

Best Practices Statement Project Management. Best Practices for Managing State Information Technology Projects

Chapter 13 Configuration Management

THE PROJECT MANAGEMENT KNOWLEDGE AREAS

SOE. managing change in system development projects: configuration management

STSG Methodologies and Support Structure

Internal Quality Management System Audit Checklist (ISO9001:2015) Q# ISO 9001:2015 Clause Audit Question Audit Evidence 4 Context of the Organization

Introduction for Software Configuration Management Training

UNCONTROLLED COPY FOR REFERENCE ONLY

CMII Model for Configuration Management (Rev B)

IT Baseline Management Policy. Table of Contents

Ten steps to better requirements management.

Appendix H Software Development Plan Template

CDC UNIFIED PROCESS PRACTICES GUIDE

Information Technology Infrastructure Library (ITIL) Relative to CMII (Rev B)

How To Understand The Differences Between The 2005 And 2011 Editions Of Itil 20000

Transmittal Sheet #: Date: July 12, 2005

Facility Maintenance Management Competency 4.9

ALS Configuration Management Plan. Nuclear Safety Related

Software and Hardware Configuration Management

Introduction to SOA governance and service lifecycle management.

White paper. Corrective action: The closed-loop system

Guide to CQI Qualifications for learners

Theme 1 Software Processes. Software Configuration Management

How To Understand And Understand The Cmm

TEMPLATE. U.S. Department of Energy. Project Name. Configuration Management Plan. September 2002 U. S. DEPARTMENT OF ENERGY

Software Configuration Management Plan

Department of Administration Portfolio Management System 1.3 June 30, 2010

QUALITY MANAGEMENT SYSTEM REVIEW AND APPROVAL TEMPLATE (DOE G A, Appendix A, )

Configuration Management

EPA Classification No.: CIO P-01.1 CIO Approval Date: 06/10/2013 CIO Transmittal No.: Review Date: 06/10/2016

White Paper. Managed IT Services as a Business Solution

Overview of STS Consulting s IV&V Methodology

Design Verification. Introduction

Your Software Quality is Our Business. INDEPENDENT VERIFICATION AND VALIDATION (IV&V) WHITE PAPER Prepared by Adnet, Inc.

IAS ACCREDITED INSPECTION AGENCIES: GUIDELINES FOR CONDUCTING INTERNAL AUDITS AND MANAGEMENT REVIEWS. Revised January, 2016

Data quality and metadata

Change Management. Prepared by Vince Guess. Sponsored by. The PLM Company Transforming the process of innovation

5 FAH-5 H-510 CONFIGURATION MANAGEMENT

Selection and use of ISO 9000

How To Validate Software

R214 SPECIFIC REQUIREMENTS: INFORMATION TECHNOLOGY TESTING LABORATORY ACCREDITATION PROGRAM

Clinical Risk Management: Agile Development Implementation Guidance

Human Factors in Design and Construction Regulatory Perspective

CENG492 SENIOR DESIGN PROJECT AND SEMINAR II SOFTWARE CONFIGURATION MANAGEMENT PLAN

Migration Use Cases & Processes

PROJECT MANAGEMENT METHODOLOGY SECTION 3 -- PLANNING PHASE

ISO/IEC Part 2 provides the following copyright release:

Automated Firewall Change Management. Ensure continuous compliance and reduce risk with secure change management workflows

Certified Professional in Configuration Management Glossary of Terms

Rail Network Configuration Management

Improved Software Testing Using McCabe IQ Coverage Analysis

Overview of the System Engineering Process. Prepared by

Internal Audit Checklist

Configuration Management

AP1000 European 18. Human Factors Engineering Design Control Document

PROJECT PLAN TEMPLATE

System Development Life Cycle Guide

Software Quality Subcontractor Survey Questionnaire INSTRUCTIONS FOR PURCHASE ORDER ATTACHMENT Q-201

STANDARDIZED WORK 2ND SESSION. Art of Lean, Inc. 1

Test Automation Architectures: Planning for Test Automation

SPICE International Standard for Software Process Assessment

COMMISSION REGULATION (EU)

From Chaos to Clarity: Embedding Security into the SDLC

ITIL: Service Operation

ITIL Introducing service transition

Transcription:

Chapter 9 Configuration Management CONTENTS 9.1 INTRODUCTION...3 9.1.1 ROLE OF CHANGE...3 9.1.2 CONFIGURATION MANAGEMENT (CM)...3 9.2 PROCESS DESCRIPTION...4 9.2.1 FUNCTIONS OF CONFIGURATION MANAGEMENT...4 9.2.1.1 Identification...5 9.2.1.2 Control...5 9.2.1.3 Status Accounting...5 9.2.1.4 Auditing...6 9.2.2 CONFIGURATION MANAGEMENT PROCESS...6 9.2.2.1 Planning...6 9.2.2.2 Establishing Baselines...7 9.2.2.3 Controlling, Documenting, and Auditing...7 9.2.3 UPDATING THE CM PROCESS...7 9.3 CONFIGURATION MANAGEMENT CHECKLIST...7 9.3.1 CM PLANNING...7 9.3.2 ESTABLISHING BASELINES...8 9.3.3 CONTROLLING, DOCUMENTING, AUDITING...8 9.3.4 UPDATING THE PROCESS...8 9.4 REFERENCES...8 9.5 RESOURCES...8 February 2003 9-1

Chapter 9: Configuration Management Condensed GSAM Handbook This page intentionally left blank. 9-2 February 2003

Chapter 9 Configuration Management But life is change, that is how it differs from the rocks, change is its very nature." John Wyndham 9.1 Introduction Change is a constant feature of software development. To eliminate change is to remove the opportunities to take advantage of lessons learned, incorporate advancing technology, and better accommodate a changing environment. Refusal to incorporate change can mean system limitations and early obsolescence, which in the world of technology can sign your system s death certificate before it is born. However, change is not universally benign and must be controlled in its introduction to a project. 9.1.1 Role of Change All projects have as their main objective to change something. A system is being upgraded or replaced, presumably to provide better or greater functionality, ease of use, reduction of operating expenses, etc. As a project is executed, changes to the initial project plan and products are a natural occurrence. The following are common sources of changes: Requirements the longer the delivery cycle, the more likely it is to happen. Changes in funding Technology advancements Solutions to problems Scheduling constraints Customer expectations Serendipitous (unexpected) opportunities for an improved system Some of these changes may appear as options while others may be mandated from above or by circumstance, as in the loss of funding. In addition to these sources, many development efforts involve a progressive evolution or elaboration of capabilities and requirements. In projects of this nature the final product is expected to be the result of regular, controlled changes. While all progress is accompanied by change, not all change is indicative of progress. If not properly handled, change can slip the schedule, affect the quality, and even kill the project. As a project draws closer to its completion, the impacts of change are more severe. [1] Clearly, a mechanism is needed to control change. 9.1.2 Configuration Management (CM) In software development and other projects, proposed changes must be evaluated to determine their overall contribution to the project goals. Do they lead to improvements or do they ultimately impede or lower the quality of the project? Even those changes that are ultimately beneficial must be controlled in their introduction and implementation. Putting a bigger engine in a plane may improve its capabilities but it cannot be implemented until the aircraft structure has been found capable or been upgraded to support the increased weight and thrust. Configuration Management is the process of controlling and documenting change to a developing system. It is part of the overall change management approach. As the size of an effort increases, so does the necessity of implementing effective CM. It allows large teams to work together in a stable environment, while still providing the flexibility required for creative work. [2] CM in a software environment is an absolute necessity. CM has three major purposes: [1] February 2003 9-3

Chapter 9: Configuration Management Condensed GSAM Handbook 1. Identify the configuration of the product at various points on time. 2. Systematically control changes to the configuration. 3. Maintain the integrity and traceability of the configuration throughout the product life cycle. CM accomplishes these purposes by answering and recording the answers to the change questions, who, what, when, and why, shown in Figure 9-1. [1] Being able to answer these questions is a sign of effective CM. Who makes changes? What changes are made? When are changes made? Why are changes made? Figure 9-1 Configuration Management Questions Effective CM provides the following essential benefits to a project: 1. Reduces confusion and establishes order. 2. Organizes the activities necessary to maintain product integrity. 3. Ensures correct product configurations. 4. Limits legal liability by providing a record of actions. 5. Reduces lifecycle costs. 6. Enables consistent conformance with requirements. 7. Provides a stable working environment. 8. Enhances compliance with standards. 9. Enhances status accounting. In short, CM can provide cost effective project insurance when properly planned, organized, and implemented. [3] It must be integral to your overall project execution, and to your charter/customer agreement. [1] Proposed changes must be dealt with systematically, promptly, and honestly. [1] If the CM process is unreasonable or unresponsive, people will try to circumvent the process, leading to chaos and a loss of the benefits of true CM. 9.2 Process Description While CM is a major element of a change control program, it is such a multifaceted discipline that it should be considered not simply as another activity, but as a program in and of itself. Establishing an effective CM program requires an understanding of CM functions and of the overall CM process. The process presented herein is applicable to CM in general, including Software Configuration Management (SCM). If more details are needed for implementing SCM, please see documents specifically relating to SCM in Section 9.5, Resources. 9.2.1 Functions of Configuration Management Configuration Management is comprised of four primary functions, Identification, Control, Status Accounting, and Auditing. These are shown in Figure 9-2, along with their sub-functions. All CM activity falls within the bounds of these functions. 9-4 February 2003

Condensed GSAM Handbook Chapter 9: Configuration Management 9.2.1.1 Identification This function identifies those items whose configuration needs to be controlled, usually consisting of hardware, software, and documentation. These items would probably include such things as specifications, designs, data, documents, drawings, software code and executables, components of the software engineering environment (compilers, linkers, loaders, hardware environment, etc.), and hardware components and assemblies. Project plans and guiding documents should also be included, especially the project requirements. A schema of names and numbers is developed for accurately identifying products and their configuration or version level. This must be done in accordance with project identification requirements. Finally, a baseline configuration is established for all configuration items and systems. Any changes to the baselines must be with the concurrence of the configuration control organization. [2] Identify Acceptance Requirements Data Identification Requirements Identify Configuration Items Document Configuration Items, Requirements, Identification Scheme, Baselines Maintain Product Description Records Establish Identification Schema Identification Define Baselines Establish Change Criteria Maintain Configuration Verification Records Maintain Change Status Records Status Accounting Configuration Management Control Establish Review & Control Organizations Establish Change Control Procedures Maintain History of Change Approvals Formal Qualification Reviews Auditing Physical Configuration Audits Functional configuration Audits Control Revisions to Specifications, Designs, Drawings, Data & Documents Figure 9-2 Major Functions of Configuration Management [2] 9.2.1.2 Control Configuration control establishes procedures for proposing or requesting changes, evaluating those changes for desirability, obtaining authorization for changes, publishing and tracking changes, and implementing changes. This function also identifies those persons and organizations that have authority to make changes at various levels (configuration item, assembly, system, project, etc.,) and those who make up the configuration control board(s). Additionally, various change criteria are defined as guidelines for the control organizations. Different types of configuration items or different systems will probably need different control procedures and involve different people. For example, software configuration control has different needs and involves different people than communications configuration control and would probably require different control rules and a different control board. [2] 9.2.1.3 Status Accounting Status accounting is the documentation function of CM. Its primary purpose is to maintain formal records of established configurations and make regular reports of configuration status. These records should accurately describe the product, and are used to verify the configuration of the system for testing, delivery, and other activities. Status ac- February 2003 9-5

Chapter 9: Configuration Management Condensed GSAM Handbook counting also maintains a history of change requests and authorizations, along with status of all approved changes. This includes the answers to the CM questions in Figure 9-1. [2] 9.2.1.4 Auditing Effective CM requires regular evaluation of the configuration. This is done through the auditing function, where the physical and functional configurations are compared to the documented configuration. The purpose of auditing is to maintain the integrity of the baseline and release configurations for all controlled products. [2] Auditing is accomplished via both informal monitoring and formal reviews. 9.2.2 Configuration Management Process Understanding of what CM is supposed to accomplish is one thing. Putting it into practice is another. As with most project activities CM begins with planning. With a plan, configuration baselines can be established. Following this initial configuration identification, the cyclical configuration control process is put into motion. These three major CM implementation activities are shown in Figure 9-3. Define CM Process Plan CM Program Identify Control Board Members Develop or Procure CM Tools Identify Items to Control Establish Baselines Identify Baselines Develop Schema of Identifiers Control, Document, & Audit Configuration Evaluate Proposed Changes & Approve / Disapprove Track Approved Changes to Closure Update Baseline and History - Publish Reports Audit - Compare Actual with Documented Configuration Figure 9-3 Configuration Management Implementation Process 9.2.2.1 Planning Planning begins by defining the CM process and establishing procedures for controlling and documenting change. A crucial action is the designation of members of the Configuration Control Board (CCB). Members should be chosen who are directly or indirectly involved or affected by changes in configuration. For example, a software configuration change board would obviously be populated with representatives from different software teams, but software affects many more aspects of a project. There should also be representatives from the hardware, test, systems, security, and quality groups, as well as representatives from project management and possible other organizations. Not all changes would be reviewed by this august body. Changes occur at different system levels and affect different portions of the overall system. Many changes will probably only affect a small subset of the system and could therefore be reviewed and approved by a smaller group. Some sort of delineation of change levels should be made during planning to keep change decisions at the proper level. While software CM is essential, there may need to be other 9-6 February 2003

Condensed GSAM Handbook Chapter 9: Configuration Management CCBs to control change in other areas of the project. Again, this is something that should be worked out in the planning phase. Various software tools exist which can facilitate the CM process flow and maintain configuration history. Use of a CM software tool is highly recommended. The temptation will be to choose a tool because it looks good in a demonstration and then build the CM process around it. The process should be defined first, and then a tool chosen to facilitate the process. 9.2.2.2 Establishing Baselines Once the CM program exists on paper, it must be determined just what configurations it will control. The second major step of implementing effective CM is identifying what items, assemblies, code, data, documents, systems, etc. will fall under configuration control. With the configuration items identified, the baseline configuration must be identified for each item. For items that already exist it may prove to be nothing more than examining or reviewing, and then documenting. For those items that have not been developed yet, their configuration exists in the requirements database or in the project plans. Until they come into physical or software reality, changes to their configuration will consist only of changes to the requirements or plans. Another essential activity in this step is developing a schema of numbers, letters, words, etc. to accurately describe the configuration revision, or version, for each general type of configuration item. There may be project requirements which dictate some type of nomenclature, or there may be an organizational or industry standard that can be used as the basis for configuration identification. 9.2.2.3 Controlling, Documenting, and Auditing When the baselines have been established, the challenge becomes one of keeping the actual and documented configurations identical. Additionally, these baselines must conform to the configuration specified in the project requirements. This is an iterative process consisting of the four steps shown in Figure 9-3. All changes to the configuration are reviewed and evaluated by the appropriate configuration control representatives specified in the CM plan. The change is either approved or disapproved. Both approvals and disapprovals are documented in the CM history. Approved changes are published and tracked or monitored until they are implemented. The appropriate configuration baseline is then updated, along with all other applicable documents, and reports are published and sent to affected organizations indicating the changes that have occurred. At selected time intervals and whenever there appears to be a need, products and records are audited to ensure that: The actual configuration matches the documented configuration. The configuration is in conformance with project requirements. Records of all change activity are complete and up-to-date. The controlling, documenting, auditing cycle is repeated throughout the project until its completion. 9.2.3 Updating the CM Process It is unlikely a perfect CM program will be assembled during the initial planning stage. There will be learning and changes in the program that indicate a need for adjustments in the CM process. These may be any mixture of modifications to make it more efficient, responsive, or accurate. When changes in the CM process are needed, consider them as you would any other changes, get the approval of all participating organizations, and implement them as appropriate. It would be ironic indeed to have an unchanging change process. 9.3 Configuration Management Checklist This checklist is provided to assist you in establishing an effective CM program. If you cannot answer a question affirmatively, you should carefully examine the situation and take appropriate action. 9.3.1 CM Planning! 1. Have you planned and documented a configuration management process?! 2. Have you identified Configuration Control Board members for each needed control board? February 2003 9-7

Chapter 9: Configuration Management Condensed GSAM Handbook! 3. Has CM software been chosen to facilitate your CM process? 9.3.2 Establishing Baselines! 4. Have all configuration items been identified?! 5. Have baselines been established for all configuration items?! 6. Has a descriptive schema been developed to accurately identify configuration items and changes to their configuration? 9.3.3 Controlling, Documenting, Auditing! 7. Is there a formal process for documenting and submitting proposed changes?! 8. Is the Configuration Control Board active and responsible in evaluating and approving changes?! 9. Is there a higher authority to appeal to when the CCB gets hung, and can t come to a consensus?! 10. Are all changes tracked until they are fully implemented?! 11. Are all changes fully documented in the baseline documents and change histories?! 12. Are regular reports and configuration updates published and distributed to interested organizations?! 13. Are regular audits and reviews performed to evaluate configuration integrity?! 14. Are configuration errors dealt with in an efficient and timely manner? 9.3.4 Updating the Process! 15. Is the CM program itself its efficiency, responsiveness, and accuracy evaluated regularly?! 16. Is the CM program modified to include recommended improvements when needed? 9.4 References [1] Software Technology Support Center Course: Life Cycle Software Project Management, Configuration Management, 9 October 2001. [2] Little Book of Configuration Management, Software Program Managers Network, November 1998. Download at: www.spmn.com/products_guidebooks.html [3] Program Manager s Guide for Managing Software, 0.6, 29 June 2001, Chapter 14: www.geia.org/sstc/g47/swmgmtguide%20rev%200.4.doc 9.5 Resources CM Today, Configuration management papers: www.cmtoday.com/yp/papers.html Configuration Management Resource Guide: www.quality.org/config/cmresourceguidemaster.doc Configuration Management II Users Group: www.cmiiug.com Crosstalk Magazine: www.stsc.hill.af.mil/crosstalk/ Software Configuration Management Terminology : www.stsc.hill.af.mil/crosstalk/1995/jan/terms.asp Software Configuration Management: Function or Discipline? : www.stsc.hill.af.mil/crosstalk/1995/oct/cmfunct.asp Stop-Gap Configuration Management : www.stsc.hill.af.mil/crosstalk/1998/feb/stopgapcm.asp Effective Software Configuration Management : www.stsc.hill.af.mil/crosstalk/1998/feb/effectivecm.asp Configuration Management Web Sites : www.stsc.hill.af.mil/crosstalk/1999/mar/cmsites.asp Demystifying Software Configuration Management : www.stsc.hill.af.mil/crosstalk/1995/may/demystif.asp 9-8 February 2003

Condensed GSAM Handbook Chapter 9: Configuration Management Evaluation and Selection of Automated Configuration Management Tools : www.stsc.hill.af.mil/crosstalk/1995/nov/evaluati.asp Software Configuration Management: A Discipline with Added Value : www.stsc.hill.af.mil/crosstalk/2001/jul/butler.asp Introducing Process into Configuration Management : www.stsc.hill.af.mil/crosstalk/1996/jun/introduc.asp Process-Based Configuration Management : www.stsc.hill.af.mil/crosstalk/1997/apr/configuration.asp Achieving the Best Possible Configuration Management Solution : www.stsc.hill.af.mil/crosstalk/1996/sep/achievin.asp A Tutorial on Control Boards : www.stsc.hill.af.mil/crosstalk/1999/mar/sorensen.asp Adopting SCM Technology : www.stsc.hill.af.mil/crosstalk/1996/mar/adopting.asp Department of Energy, Configuration Management resources: http://cio.doe.gov/sqse/pm_conf.htm Institute of Configuration Management: www.icmhq.com MIL-HDBK-61A, Configuration Management Guidance: www.assist2.daps.dla.mil/quicksearch/ Program Manager s Guide for Managing Software, 0.6, 29 June 2001, Chapter 14: www.geia.org/sstc/g47/swmgmtguide%20rev%200.4.doc Software Engineering Institute, Software Configuration Management support: www.sei.cmu.edu/legacy/scm/scmhomepage.html February 2003 9-9

Chapter 9: Configuration Management Condensed GSAM Handbook This page intentionally left blank. 9-10 February 2003