Friday, May 29, 2009

Configuration Management In Software Testing

Configuration Management

Managing the products of system change

Four Types of Activities

Configuration management planning

Change management

Version and release management

System building

Configuration Management (1)

New versions of software systems are created as they evolve

different machines / OS

offer different functionality

Tailored for particular users / requirements

CM is concerned with managing evolving software systems

System change --> team activity

control the costs and effort involved in making changes to a system

Configuration Management (2)

Involves development and application of procedures and standards to manage an evolving software product

Part of a more general quality management process

When released to CM, software systems are sometimes called baselines

a starting point for further development

System Families

CM Standards

Based on a set of standards, applied within an organization

Standards should define:

how items are identified,

how changes are controlled, and

how new versions are managed

Standards may be based on external CM standards (e.g. IEEE standard for CM)

CM Planning (1)

All products of the software process may have to be managed

Specifications

Designs

Programs

Test Data

User Manuals

Thousands of separate documents are generated for a large software system

CM Planning (2)

Start: early phases of the project

Define the documents or document classes which are to be managed

Formal Documents

Documents required for future system maintenance should be identified and specified as managed documents

Configuration Management Plan (1)

Defines types of documents to be managed and a document naming scheme

Defines who is responsible for the CM procedures and creation of baselines

Defines policies

change control and version management

Defines the CM records which must be maintained

Configuration Management Plan (2)

Describes the tools which should be used and any limitations on their use

Defines the process of tool use

Defines the CM database used to record configuration information

May include information such as the CM of external software, process auditing, etc.

CM Item Identification

Large projects typically produce thousands of documents which must be uniquely identified

Some documents are maintained for the lifetime of the software

Document naming scheme should be defined so that related documents have related names

A hierarchical scheme with multi-level names is probably the most flexible approach

Configuration Hierarchy

CM Planning Database

Maintain all CM information in a CM database

Allow queries about configurations to be answered:

Who has a particular system version?

What platform is required for a particular version?

What versions are affected by a change to component X?

How many reported faults in version T?

CM database should be linked to the software being managed

CM Database Implementation

May be part of an integrated environment to support software development

The CM database and the managed documents are all maintained on the same system

CASE tools may be integrated so that there is a close relationship between the CASE tools and the CM tools

Typically, the CM database is maintained separately as this is cheaper and more flexible

Change Management

Software systems are subject to continual change requests from

users

developers

market forces

Change Management:

keep managing these changes and ensuring that they are implemented in the most cost-effective way

Change Management Process

Change Request Form

Definition of change request form is part of the CM planning process

Records:

Change required

Suggestor of change

Reason why change was suggested

Urgency of change (from requestor of the change)

Change evaluation

Impact analysis

Change cost and recommendations (System maintenance staff)

Change Request Form

See second lecture part.

Change Tracking Tools

Major problem in change management:

tracking change status

Change tracking tools:

keep tracking the status of each change request and automatically ensure that change requests are sent to the right people at the right time

Integrated with email systems allowing electronic change request distribution

Change Control Board

Changes should be reviewed by an external group who decide whether or not they are cost-effective from a strategic and organizational viewpoint rather than a technical viewpoint

Should be independent of project responsible for system

May include representative from client and contractor staff

Derivation History

Record of changes applied to a document or code component

Should record, in outline, the change made, the rationale for the change, who made the change, and when it was implemented

May be included as a comment in code. If a standard prologue style is used for the derivation history, tools can process this automatically

Example: Derivation History

Version and Release Management

Invent identification scheme for system versions

Plan when new system version is to be produced

Ensure that version management procedures and tools are properly applied

Plan and distribute new system releases

Versions / Variants / Releases

Versions

An instance of a system which is functionally distinct in some way from other system instances

Variant

An instance of a system which is functionally identical but non-functionally distinct from other instances of a system

Release

An instance of a system which is distributed to users outside of the development team

System Releases

Not just a set of executable programs

May also include

Configuration files defining how the release is configured for a particular installation

Data files needed for system operation

An installation program or shell script to install the system on target hardware

electronic and paper documentation

Systems may be released on magnetic tape, floppy disk, or CD-ROM

Version Identification

Simple naming scheme user a linear derivation (e.g. V1, V1.1, V1.2, V2.1, V2.2…)

Actual derivation structure is a tree or a network rather than a sequence

Names are not meaningful

Hierarchical naming scheme may be better

Version Derivation Structure

Attributed Version Identification

Attributes can be associated with a version with the combination of attributes identifying that version

Examples of attributes are Date, Creator, Programming Language, Customer, Status, etc.

More flexible than an explicit naming scheme for version retrieval; Can cause problems with uniqueness

Needs an associated name for easy reference

Release Management

Releases must incorporate changes forced on the system by errors discovered by users and by hardware changes

They must also incorporate new system functionality

Release planning is concerned with when to issue a system version as a release

Lehman’s Fifth Law

The incremental system change which can be incorporated in each release of the system is approximately constant

If too many new features are included at the same time as error repairs, the cost of producing a new release is significantly increased

If a release has many changes incorporated, it must be followed by a further release fixing problems in the first release

System Release Strategy

Release Problems

Customer may not want a new release of the system

They may be happy with their current system as the new version may provide unwanted functionality (e.g. Word 6)

Release management must not assume that all previous releases have been accepted. All files required for a release should be re-created with a new release is installed

Version Management Tools

Version and release identification

Systems assign identifiers automatically when a new version is submitted to the system

Controlled change

Only one version at a time may be checked out for change. Parallel working on different versions

Storage management

System stores the difference between versions rather than all the version code

Change history recording

RCS - Revision Control System

RCS is a relatively old tool but still widely used

Minimized the disk requirements by only storing differences (deltas) from a base version

Applies deltas to the latest release to re-create earlier system versions

Allows any named version or release to be generated

Allows independent development of different releases

Deltas in RCS

Parallel Development in RCS

RCS Limitations

Designed as a code control system -- therefore intended for use with ASCII text

Cannot be used to manage object code or other documents with non-ASCII representations (e.g. multimedia files)

Test-based user interface. Version browsing is difficult

Version retrieval based on the name rather than the version attributes

System Building

Involves taking all system components and combining them into a single executable system

Different systems are built from different component combinations

May take several days for large systems if all components are compiled and linked at the same time

System Building Problems (1)

Do the build instructions include all required components?

When there are many hundreds of components making up a system, it is easy to miss one out. This should normally be detected by the linker

Is the appropriate component version specified?

A more significant problem. A system built with the wrong version may work initially but fail after delivery

Are all data files available?

The build should not rely on ‘standard’ data files. Standards vary from place to place

System Building Problems (2)

Are data file references within components correct?

Embedding absolute names in code almost always causes problems as naming conventions differ from place to place

Is the system being built for the right platform?

Sometimes must build for a specific OS version or hardware configuration

Is the right version of the compiler and other software tools specified?

Different compiler versions may actually generate different code and the compiled component will exhibit different behavior

Configuration Threads

Identify the version to be built by specifying its attributes (e.g. Build the version with identifier attribute, R3; build the version with status attribute ‘beta test’ etc.)

Identify the version of the compiler and support tools along with its parameters which is to be used in building a system version

CM Support with an Integrated DB

CM tools may be implemented using database query and browsing facilities

Using process information, other tools such as editors / compilers etc. can be integrated and can automate version creation

Information dissemination of versions and changes con be incorporated in the process information

Database Oriented CM Tools

Rely on a powerful semantic or object-oriented database

Store both process and product information

Provide an integrated set of tools for configuration management

Integrated with other tools through the database

Graphical user interface

Still research prototypes

Summary (1)

CM is the management of system change to software products

Effective CM is essential in large software projects

CM activities include CM planning, change management, system building, and version and release management

A formal document naming scheme should be established and documents should be managed in a database

Summary (2)

System releases should be phased with releases fixing problems interleaved with releases offering new functionality

System building involves assembling components into a system. It is always supported by system building tools such as MAKE

Software Configuration Management

Course Objectives

What is Configuration Management?

Why Configuration Management ?

Functions of Configuration Management:

Configuration Identification

Configuration Control

Configuration Audit

Configuration Status Accounting

How to Form a Software Configuration Management Team and a Software Configuration Control Board

Chapter 1

Overview

What is Configuration Management?

Definition from IEEE – A discipline applying technical and administrative direction and surveillance to:

Identify and document the functional and physical characteristics of a configuration item

Control changes to those characteristics

Record and report change processing and implementation status

Verify compliance with specified requirements

What is Configuration Mgmt (cont’d)?

A way to control a product and its components over time

A formal process that involves:

Identifying the configuration of software work products and their descriptions at given points in time:

Applications being developed or maintained

Development and maintenance tools

Systematically controlling changes to the configuration

What is Configuration Mgmt (cont’d)?

Maintaining integrity and traceability of the configuration throughout the life cycle

SCM is part of the system configuration management process

Source: Adapted from Paulk, M.C., et. al. (CMU/SEI-93-TR-25), p. L2-71.

Exercise

As you watch the playlet on the next two pages, prepare to discuss the following questions:

What are the problems?

What are the underlying causes of the problems?

What should FFI have done to avoid them?

Common Problems

Updates are lost; over written.

Problems and changes are not tracked or related.

Changes are not related to crashes.

It is unclear exactly what changes were made.

It is unclear whether new requirements are in the product.

It is unclear which version supports which customer.

The previous version that worked cannot be rebuilt.

Poor communication – People who might be able to help are not made aware of problems.

Misconceptions

CM is not required in this program.

CM is applied after development.

CM procedures slow down development.

The document can be changed later.

We do not have time for change boards.

CM Objectives

Ensure that all project personal know:

What is supposed to be built

What is being built

What has been built

To avoid:

Delay in schedule

Cost overruns

Communication problems

Why Do We Need Configuration Management?

Because we are good at:

Creating

Having Ideas

Producing Things

Making Decisions

Writing Programs

Changing Programs

Issuing Instructions

Why Do We Need Configuration Management?

Because we are not good at:

Documenting

Recording Changes

Keeping History

Recording Decisions

Cleaning Up

Communicating

Four Common Problems in Software Development

Communication breakdown

Shared data

Multiple maintenance

Simultaneous update

What is Configuration?

A set of the artifacts or configuration items (intermediate and end-products) that define the system, or a part of the system, within the system’s lifecycle

What is a Configuration Item?

An aggregation of hardware, software, or both designated for configuration management and treated as a single unit for the configuration management process.

Functions of Software Configuration Management

Configuration identification

Configuration control

Configuration status accounting

Configuration audit

No comments:

Post a Comment