21.01.2022 Views

Sommerville-Software-Engineering-10ed

Create successful ePaper yourself

Turn your PDF publications into a flip-book with our unique Google optimized e-Paper software.

74 Chapter 3 ■ Agile software development

Plan-based development

Requirements

engineering

Requirements

specification

Design and

implementation

Requirements change

requests

Agile development

Requirements

engineering

Design and

implementation

Figure 3.1 Plan-driven

and agile development

They may propose changes to the software and new requirements that should be

implemented in a later version of the system.

3. Extensive tool support is used to support the development process. Tools that

may be used include automated testing tools, tools to support configuration management,

and system integration and tools to automate user interface production.

Agile methods are incremental development methods in which the increments are

small, and, typically, new releases of the system are created and made available to

customers every two or three weeks. They involve customers in the development

process to get rapid feedback on changing requirements. They minimize documentation

by using informal communications rather than formal meetings with written documents.

Agile approaches to software development consider design and implementation

to be the central activities in the software process. They incorporate other activities,

such as requirements elicitation and testing, into design and implementation. By

contrast, a plan-driven approach to software engineering identifies separate stages in

the software process with outputs associated with each stage. The outputs from one

stage are used as a basis for planning the following process activity.

Figure 3.1 shows the essential distinctions between plan-driven and agile approaches

to system specification. In a plan-driven software development process, iteration

occurs within activities, with formal documents used to communicate between stages

of the process. For example, the requirements will evolve, and, ultimately, a requirements

specification will be produced. This is then an input to the design and implementation

process. In an agile approach, iteration occurs across activities. Therefore,

the requirements and the design are developed together rather than separately.

In practice, as I explain in Section 3.4.1, plan-driven processes are often used along

with agile programming practices, and agile methods may incorporate some planned

Hooray! Your file is uploaded and ready to be published.

Saved successfully!

Ooh no, something went wrong!