KEMBAR78
Software QA | PDF | Agile Software Development | Software Development
0% found this document useful (0 votes)
266 views269 pages

Software QA

Software QA

Uploaded by

Muhammad Alek
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
266 views269 pages

Software QA

Software QA

Uploaded by

Muhammad Alek
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 269

Agile Software

Development Quality
Assurance
Ioannis G. Stamelos
Aristotle University of Thessaloniki, Greece

Panagiotis Sfetsos
Alexander Technological Educational Institution of Thessaloniki, Greece

Information science reference


Hershey • London • Melbourne • Singapore
Acquisitions Editor: Kristin Klinger
Development Editor: Kristin Roth
Senior Managing Editor: Jennifer Neidig
Managing Editor: Sara Reed
Assistant Managing Editor: Sharon Berger
Copy Editor: Larissa Vinci
Typesetter: Sara Reed
Cover Design: Lisa Tosheff
Printed at: Yurchak Printing Inc.

Published in the United States of America by


Information Science Reference (an imprint of Idea Group Inc.)
701 E. Chocolate Avenue, Suite 200
Hershey PA 17033
Tel: 717-533-8845
Fax: 717-533-8661
E-mail: cust@idea-group.com
Web site: http://www.info-sci-ref.com

and in the United Kingdom by


Information Science Reference (an imprint of Idea Group Inc.)
3 Henrietta Street
Covent Garden
London WC2E 8LU
Tel: 44 20 7240 0856
Fax: 44 20 7379 0609
Web site: http://www.eurospanonline.com

Copyright © 2007 by Idea Group Inc. All rights reserved. No part of this publication may be reproduced, stored or distributed in any
form or by any means, electronic or mechanical, including photocopying, without written permission from the publisher.
Product or company names used in this set are for identification purposes only. Inclusion of the names of the products or companies
does not indicate a claim of ownership by IGI of the trademark or registered trademark.

Library of Congress Cataloging-in-Publication Data

Agile software development quality assurance / Ioannis Stamelos and Panagiotis Sfetsos, editors.

p. cm.

Summary: “This book provides the research and instruction used to develop and implement software quickly, in small iteration
cycles, and in close cooperation with the customer in an adaptive way, making it possible to react to changes set by the constant
changing business environment. It presents four values explaining extreme programming (XP), the most widely adopted agile
methodology”--Provided by publisher.

Includes bibliographical references and index.

ISBN 978-1-59904-216-9 (hardcover) -- ISBN 978-1-59904-218-3 (ebook)

1. Computer software--Development. 2. Computer software--Quality control. I. Stamelos, Ioannis, 1959- II. Sfetsos, Panagiotis,
1953-

QA76.76.D47A394 2007

005.3--dc22

British Cataloguing in Publication Data


A Cataloguing in Publication record for this book is available from the British Library.

All work contributed to this book set is new, previously-unpublished material. The views expressed in this book are those of the au-
thors, but not necessarily of the publisher.
Table of Contents

Detailed Table of Contents ..................................................................................................................iii


Foreword . ............................................................................................................................................. ix
Preface . ................................................................................................................................................. xi
Acknowledgments ............................................................................................................................xviii
About the Editor ................................................................................................................................ xix

Section I
Introduction: Agile Methods and Quality

Chapter I
Agile Software Methods: State-of-the-Art / Ernest Mnkandla and Barry Dwolatzky............................. 1

Chapter II
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to
Stakeholders’ Needs / Eleni Berki, Kerstin Siakas, and Elli Georgiadou........................................ 23

Chapter III
What’s Wrong with Agile Methods? Some Principles and Values to Encourage
Quantification / Tom Gilb and Lindsey Brodie................................................................................. 56

Section II
Quality within Agile Development

Chapter IV
Requirements Specification using User Stories / V. Monochristou and M. Vlachopoulou.................... 71

Chapter V
Handling of Software Quality Defects in Agile Software Development / Jörg Rech............................ 90

Chapter VI
Agile Quality Assurance Techniques for GUI-Based Applications / Atif Memon and Qing Xie......... 114
Section III
Quality within Agile Process Management

Chapter VII
Software Configuration Management in Agile Development / Lars Bendix and
Torbjörn Ekman................................................................................................................................... 136

Chapter VIII
Improving Quality by Exploiting Human Dynamics in Agile Methods / Panagiotis Sfetsos
and Ioannis Stamelos........................................................................................................................... 154

Chapter IX
Teaching Agile Software Development Quality Assurance / Orit Hazzan and Yael Dubinsky........... 171

Section IV
Agile Methods and Quality: Field Experience

Chapter X
Agile Software Development Quality Assurance: Agile Project Management, Quality Metrics, and
Methodologies / James F. Kile and Maheshwar K. Inampudi........................................................ 186

Chapter XI
Test-Driven Development: An Agile Practice to Ensure Quality is Built from the
Beginning / Scott Mark................................................................................................................... 206

Chapter XII
Quality Improvements from using Agile Development Methods: Lessons Learned /
Beatrice Miao Hwong, Gilberto Matos, Monica McKenna, Christopher Nelson,
Gergana Nikolova, Arnold Rudorfer, Xiping Song, Grace Yuan Tai, Rajanikanth Tanikella,
and Bradley Wehrwein......................................................................................................................... 221

About the Authors . ........................................................................................................................... 236

Index.................................................................................................................................................... 243
Detailed Table of Contents

Foreword . ............................................................................................................................................. ix
Preface . ................................................................................................................................................. xi
Acknowledgments ............................................................................................................................xviii
About the Editor ................................................................................................................................ xix

Section I
Introduction: Agile Methods and Quality

Chapter I
Agile Software Methods: State-of-the-Art / Ernest Mnkandla and Barry Dwolatzky............................. 1

This chapter provides a review of the state-of-the-art of agile methodologies. However, it focuses primar-
ily on the issue of quality and quality assurance, reviewing the benefits that agile methods have brought
to software development. An analysis framework is used for systematically analyzing and comparing
agile methodologies and is applied to three of them.

Chapter II
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to
Stakeholders’ Needs / Eleni Berki, Kerstin Siakas, and Elli Georgiadou........................................ 23

Following the presentation of the previous chapter, the agile information systems development process
is discussed here and its quality characteristics are analyzed in detail. One important issue is raised:
how suitable and applicable are agile methods when applied on different organisational and national
situations? The text provides arguments on the basis of the authors’ experiences from various European
countries differing in their academic and work values, and information systems development industrial
practices.

Chapter III
What’s Wrong with Agile Methods? Some Principles and Values to Encourage
Quantification / Tom Gilb and Lindsey Brodie................................................................................. 56

In this chapter, arguments are provided in favour of the quantification of agile processes to reinforce
quality assurance procedures. Measuring requirements, design artefacts, and delivered results provide
the basis for sound quality estimation. The text discusses in detail the benefits of quantification and
proposes the quantification approach Planguage. Interesting results from Planguage application in the
context of a Norwegian organization are given.

Section II
Quality within Agile Development

Chapter IV
Requirements Specification using User Stories / V. Monochristou and M. Vlachopoulou.................... 71

In this chapter, the authors describe a number of approaches for managing user requirements (namely
software requirements specification, use cases, interaction design scenarios). Requirements are subject
to constant changes in modern software development and the text shows how agile methods promote
the involvement of customers/users in the process of requirement modification. The tool for assuring
requirements quality are user stories and is thoroughly discussed and illustrated in this chapter.

Chapter V
Handling of Software Quality Defects in Agile Software Development / Jörg Rech............................ 90

This chapter discusses refactoring, an agile procedure during which, among other activities, quality
defect removal takes place. Because of time constraints, quality defects can not be removed in just one
refactoring phase. Documentation of detected quality defects is therefore necessary and the text pro-
poses a process for the recurring and sustainable discovery, handling, and treatment of quality defects
in software systems. The process is based on an annotation language, capable to register information
about quality defects found in source code.

Chapter VI
Agile Quality Assurance Techniques for GUI-Based Applications / Atif Memon and Qing Xie......... 114

This chapter proposes a process-based approach for assuring quality while developing in agile mode.
The authors propose a new concentric loop-based technique, which effectively utilizes resources during
iterative development. It is based on three types of testing, namely crash testing, smoke testing, and com-
prehensive testing. The overall approach is illustrated on the development of graphical user interfaces.
The GUI model used to implement the concentric-loop technique is given in detail.

Section III
Quality within Agile Process Management

Chapter VII
Software Configuration Management in Agile Development / Lars Bendix and
Torbjörn Ekman................................................................................................................................... 136
Because of the frequent changes, multiple iterations, and software versions that occur in agile develop-
ment, software configuration management is a crucial activity. This chapter discusses the additional
requirements for software configuration management with respect to the traditional development. Typical
agile activities for configuration management are described along with general guidelines. It is argued
that an agile project can assure better quality according to the agile method and configuration manage-
ment it applies and the project particular context.

Chapter VIII
Improving Quality by Exploiting Human Dynamics in Agile Methods / Panagiotis Sfetsos
and Ioannis Stamelos........................................................................................................................... 154

This chapter explores the management of the human resources that are involved in agile development.
Because evidently human factors are critical for the success of agile methods, there is an urgent need
for managing agile people effectively both at the corporate level and the project level. First part of the
chapter proposes and discusses a model for personnel management based on the well-known People-
CMM assessment and improvement model. In addition, the chapter proposes a model for allocating and
rotating developers in pairs while pair programming. The model is based on the fact that different types
of personalities and temperaments allow pairs that produce better quality results.

Chapter IX
Teaching Agile Software Development Quality Assurance / Orit Hazzan and Yael Dubinsky........... 171

This chapter differs from the rest of the book in the sense that it deals with the education of software
engineers and managers to form a culture for agile quality assurance. The text proposes a teaching frame-
work focusing on the way quality issues are perceived in agile software development environments. It
consists of nine principles, which can be adjusted according to different specific teaching environments.
The teaching framework is based on the differences between agile and traditional software development.
Overall, this chapter provides a particularly useful tool for instructors of Agile Methods.

Section IV
Agile Methods and Quality: Field Experience

Chapter X
Agile Software Development Quality Assurance: Agile Project Management, Quality Metrics, and
Methodologies / James F. Kile and Maheshwar K. Inampudi........................................................ 186

This chapter examines one of the hottest issues in modern software development, namely the adoption
of agile methods by highly disciplined and highly structured software development environments. It
appears that up to now, agile methods have been applied mostly to non-critical projects. The text de-
scribes how one IBM software development team has applied simultaneously several individual agile
development techniques. The authors report encouraging results, stating that they obtained increased
quality in shorter than normal time. Throughout the chapter, it is shown that the adoption of individual
agile techniques can be achieved with no additional risks.
Chapter XI
Test-Driven Development: An Agile Practice to Ensure Quality is Built from the
Beginning / Scott Mark................................................................................................................... 206

This chapter describes the practice of test-driven development and the benefits it brings to quality as-
surance in an agile organization. The practice is illustrated through details of two real development
projects in an industrial setting. The author gives an industry practitioner’s perspective and discusses
various practical considerations about the adoption of the practice. Overall, it is claimed that test-driven
development is well accepted by practitioners and is a successful quality assurance technique.

Chapter XII
Quality Improvements from using Agile Development Methods: Lessons Learned /
Beatrice Miao Hwong, Gilberto Matos, Monica McKenna, Christopher Nelson,
Gergana Nikolova, Arnold Rudorfer, Xiping Song, Grace Yuan Tai, Rajanikanth Tanikella,
and Bradley Wehrwein......................................................................................................................... 221

In this chapter, the experience of another large company, namely Siemens, with agile methodologies is
reported. The authors report that Siemens has applied agile processes in several projects with varying
characteristics. They also report that significant quality achievements have been observed. The text
discusses briefly project quality goals and practices and summarizes the lessons learned from successes
and failures while working for quality assurance in their projects. This chapter is important because it
shows how a large company pursues quality assurance results when applying agile methods.

About the Authors . ........................................................................................................................... 236


Index.................................................................................................................................................... 243
Foreword

After spending the summer north of the Arctic Circle, basking in the midnight sun and the warmest
weather for over 100 years in Finland, I was especially happy to find this book sitting on my desk wait-
ing to be read. Although there is no shortage of books on agile methodologies and practices, something
had been missing. The concept of quality is indeed a very important element in any software system and
development method, yet it has received little explicit attention in the agile literature. For this reason, I
am delighted to see this book contribute to this gap.
We have long known that skilled people are the most crucial resource in software development.
Back in the 1990 summer issue of American Programmer (Ed Yourdon’s Software Journal, Vol. 3, No.
7-8)—which was devoted exclusively to “Peopleware”—the editor commented that “Everyone knows
the best way to improve software productivity and quality is to focus on people.” However, it took more
than 10 years for the agile manifesto and agile methods (Extreme Programming, Scrum, Crystal, and
many others) to truly place the emphasis on people and their interaction. Since then, we have witnessed
a movement that has advanced more rapidly than any other innovation in the field of software engineer-
ing.
Software quality in agile development is not a straightforward topic. Therefore, it is essential that
a book of this kind does not aim at offering simple answers to complex problems. An edited book al-
lows the contributors to approach the topic from their particular angles in an in-depth manner. In this
book there are chapters not normally found in the agile literature dealing with, for example, metrics and
documenting defects. Some of the chapters take a controversial approach and offer new insights into
adapting agile methods in different development situations. The reader will quickly realise that these
types of arguments, studies, and suggestions are much needed in this field.
The reader can further enjoy the opportunity to select and read the contents pertaining to their
background and interests. I am happy to see that the editors have succeeded in collecting chapters that
not only build upon one another but, more importantly, form a coherent whole addressing the relevant
issues from people management to coding with experiences drawn from the industry. And all of this is
addressed from the perspective of software quality!
As an academic, I value the fact that this book includes a number of rigorously performed scientific
studies. This is particularly welcome as it enables us to answer the question why agile methods work.
To date, we have seen quite interesting anecdotal evidence that agile methods do improve quality and
even make the programmers’ work a happier one. However, this book contributes also to the scientific
discussion by providing thoughts and theories that explain the results.
Sometimes we tend to forget that one of the better ways to influence the future of software develop-
ment is to offer specific material for teachers who educate young developers in universities and other

ix
educational institutes. While I believe all the chapters are of merit in this book, I am impressed to find
a chapter written for the use of educators as well.
Whether you read this book from start to finish, or piecemeal your approach iteratively, I am sure
you will find this book as valuable as I did.

Pekka Abrahamsson
Research Professor
VTT Technical Research Centre of Finland

Pekka Abrahamsson is a research professor at VTT Technical Research Centre of Finland. Cur-
rently, he is on leave from the University of Tampere where he is a full professor in the field of informa-
tion systems and software engineering. His current responsibilities include managing an AGILE-ITEA
project (http://www.agile-itea.org), which involves 22 organizations from nine European countries. The
project aims at developing agile innovations in the domain of complex embedded systems. His research
interests are centred on mobile application development, business agility, agile software production,
and embedded systems. He leads the team who has designed an agile approach for mobile application
development—the Mobile-D. He has coached several agile software development projects in industry
and authored 50+ scientific publications focusing on software process and quality improvement, agile
software development and mobile software. His professional experience involves 5 years in industry as
a software engineer and a quality manager


Preface

Agile methods drastically alter the software development processes. Agile software processes, such as
extreme programming (XP), Scrum, etc., rely on best practices that are considered to improve software
development quality. It can be said that best practices aim to induce software quality assurance (SQA) into
the project at hand. Proponents of agile methods claim that because of the very nature of such methods,
quality in agile software projects should be a natural outcome of the applied method. As a consequence,
agile software development quality assurance (ASDQA) is hoped/expected/supposed to be more or less
embedded in the agile software processes, while SQA practices are integrated across the entire life-cycle
development, from requirements through the final release. Thus, agile methods introduce a different
perspective on QA in software development.
Agile practices are expected to handle unstable and volatile requirements throughout the development
lifecycle, to deliver software with fewer defects and errors, in shorter timeframes, and under predefined
budget constraints. The iterative and incremental way of development allows both customer require-
ments revision mechanisms and customer active participation in the decision-making process. Customer
participation provides the needed feedback mechanism, ensuring customer perceived satisfaction for the
final product. It is also known that agile methods make the key business users a very strong partner in
assuring quality. Rather than completely leaving quality to the professionals, agile projects make these
key users responsible for ensuring that the application is fit for purpose. Agile development embraces
test driven development and test first design, both coming from the arena of good practices, introduc-
ing them into mainstream development, and minimizing errors and defects of the final product. Some
other practises, such as simple planning and designing, pair programming, short iteration cycles, small
releases, continuous integrations, common code ownership, and metaphor potentially reinforce quality
assurance.
It is interesting to note that the previously mentioned practices cover and support, to a significant
extent, total quality management (TQM) (see Crosby, 1979; Deming, 1986; Feigenbaum, 1961, 1991;
Ishikawa, 1985; Juran & Gryna, 1970, all referenced in Chapter II). We remind the reader that a TQM
system comprises four key common elements: (1) customer focus, (2) process improvement, (3) human
side of quality, and (4) measurement and analysis. Agile methods deal in one way or another with all
four elements. Many reports support and evangelize the advantages of agile methods with respect to
quality assurance, even if the term “quality assurance” is avoided as coming from traditional, bureau-
cratic development.
Is it so? For example, is it the case that agile methods assure quality by default, and software man-
agers/developers need not be concerned with quality issues, such as quality planning, quality audits,

xi
or quality reports? Proponents of agile methods must provide convincing answers to questions such as
“What is the quality of the software produced?” or “Which hard/soft evidence supports the superiority
of agile quality?” There has been little published work that focuses on such agile software development
quality issues. In particular, there is a literature gap in providing a critical view of agile quality, pinpoint-
ing areas where agile methods are strong, but also areas that need improvement.

Overall Objective of the Book

This book pursues an ambitious goal: it attempts to provide answers to the questions and issues previ-
ously raised. It provides original academic work and experience reports from industry related to agile
software development quality assurance. Its mission is to describe fundamentals of ASDQA theory and
provide concrete results from agile software development organizations. To understand how quality is
or should be handled, the whole development process must be analyzed, measured, and validated from
the quality point of view, as it is claimed to be the rule when traditional methods are employed. It is
precisely from the quality point of view that the book looks at agile methods. The area is wide and entails
many facets that the book attempts to clarify, including:

• Differences and similarities between the traditional quality assurance procedures and ASDQA.
• Identification and evaluation of quality metrics in agile software development.
• Reports on the state of the art regarding quality achievements in agile methods.
• Investigation on how practices and tools affect the quality in agile software development.
• Human issues in ASDQA.
• Education in ASDQA concepts and techniques.

Book chapters provide theoretical discussion on ASDQA issues and/or results and lessons from
practical ASDQA application. Eventually, the book is expected to provide successful quality manage-
ment tips that can help participants in the agile software development process avoid risks and project
failures that are frequently encountered in traditional software projects. Because such task is extremely
difficult, given the variety of agile methods, the relatively limited time they have been exercised and
the scattered, often vague, information regarding agile quality from the field, this book could only be
edited, and not be written by a small authors’ group.
The book takes the form of a collection of edited chapters. Authors of the chapters cover all kinds of
activities related to agile methods: they are academicians, practitioners, consultants, all involved heav-
ily in practicing, researching, and teaching of agile methods. Authors come from almost all over the
world (North America, Europe, Asia, Africa) and are employed by all kinds of organizations involved
in agile development (universities, research institutes, small or large agile development/consulting
companies).

Organization of the Book

This book is made up of 12 chapters, organized in four sections. Section titles are the following:

Section I: Introduction: Agile Methods and Quality


Section II: Quality within Agile Development

xii
Section III: Quality within Agile Process Management
Section IV: Agile Methods and Quality: Field Experience

Section I: Introduction: Agile Methods and Quality provides the framework for the rest of the
book. It is particularly useful for readers not familiar with all aspects of agile methods. It reviews agile
methods and compares them with traditional approaches. Section I starts posing questions about the
quality achieved and potential problems with agile methods today. It also starts to propose solutions for
certain identified issues.
Section II: Quality within Agile Development examines how quality is pursued throughout software
development. It gives a flavour of how developers achieve quality in an agile fashion. Chapters in this
section review quality assurance when specifying requirements, when handling defects, and when user
interfaces are designed and implemented.
Section III: Quality within Agile Process Management examines how quality is pursued throughout
the handling of agile software processes. This section deals with activities that run parallel to development
or prepare the development teams for effective work. It gives a flavour of how managers achieve quality
in an agile fashion. Two chapters in this Section review quality assurance when managing agile software
configurations and when agile people are managed. Finally, a critical theme for the future is addressed,
namely the education of next generations of agile developers and managers in ASDQA issues.
Section IV: Agile Methods and Quality: Field Experience provides feedback from agile method
application. Although all chapters up to now try to capture experiences from agile projects and to in-
corporate them in theoretical frameworks, chapters of this section come right from agile companies.
Interestingly, two of the Chapters come from quite large companies, signalling the expansion of agile
methods into the realm of traditional software development. Chapters provide invaluable information
about agile project management, quality measurement, test driven development and, finally, lessons
learned from ASDQA real world application.
A brief description of each chapter follows. Chapters are organized according to the sections they
belong.

Section I: Introduction: Agile Methods and Quality

Chapter I: Agile Software Methods: State-of-the-Art

In Chapter I, Ernest Mnkandla and Barry Dwolatzky (South Africa) analyze and define agile methodolo-
gies of software development. They do so by taking a software quality assurance perspective. The chapter
starts by defining agile methodologies from three perspectives: a theoretical definition, a functional defi-
nition, and a contextualized definition. Next, a brief review of some of the traditional understandings of
quality assurance is given, and the author proceeds with certain innovations that agility has added to the
world of quality. Doing so, the text provides an understanding of the state-of-the-art in agile methodolo-
gies and quality, along with expectations for the future in this field. An analysis framework is used for
objectively analyzing and comparing agile methodologies. The framework is illustrated by applying it
to three specific agile methodologies.

Chapter II: Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Re-
spect to Stakeholders’ Needs

In Chapter II, Eleni Berki (Finland), Kerstin Siakas (Greece), and Elli Georgiadou (UK) provide an
in-depth discussion and analysis of the quality characteristics of the agile information systems develop-

xiii
ment process. They question ASDQA by exposing concerns regarding the applicability and suitability
of agile methods in different organisational and national cultures. They argue based on recent literature
reviews and published reports on the state-of-the-art in agile Methodologies. A unique feature of this
chapter is that its authors draw their experience from different European countries (Denmark, England,
Finland, Greece) with diverse academic and work values, and information systems development (ISD)
industrial practices based on different principles. They relate and compare traditional, agile, managed,
and measured ISD processes, they explore human dynamics that affect success and consensus acceptance
of a software system and propose a critical framework for reflecting on the suitability and applicability
of agile methods in the development and management of quality software systems. To achieve this, the
authors examine the different European perceptions of quality in the agile paradigm and compare and
contrast them to the quality perceptions in the established ISD methodological paradigms.

Chapter III: What’s Wrong with Agile Methods? Some Principles and Values to En-
courage Quantification

In Chapter III, Tom Gilb (Norway) proposes the quantification of agile processes to reinforce ASDQA.
He claims that agile methods could benefit from using a more quantified approach across the entire
implementation process (that is, throughout development, production, and delivery). He discusses
such things as quantification of the requirements, design estimation, and measurement of the delivered
results. He outlines the main benefits of adopting such an approach, identifying communication of the
requirements, and feedback and progress tracking as the areas that are most probable to benefit. The
chapter presents the benefits of quantification, proposes a specific quantification approach (Planguage),
and finally describes a successful case study of quantifying quality in a Norwegian organization.

Section II: Quality within Agile Development

Chapter IV: Requirements Specification user Stories

In this chapter, Vagelis Monochristou and Maro Vlachopoulou (Greece) review quality assurance in
the requirements specification development phase. Such phase is known to give a lot of problems and
injects hard to detect and correct defects in the documentation and the software itself. The authors dis-
cuss several approaches, which suggest ways of managing user’s requirements (software requirements
specification, use cases, interaction design scenarios, etc.). They emphasize the fact that many real users
requirements appear in development phases following the initial ones. One way to cope with this situation
is to involve customers/users in these development phases as well. When provided with insight about the
various sub-systems as they are developed, customers/users can re-think and update their requirements.
However, to accommodate such customer/user role within the development cycle, software organiza-
tions must take a non-traditional approach. Agile methods are this alternative approach because of the
iterative and incremental way of development they propose. Allowing for iteration and gradual system
building, user requirements revision mechanisms, and active user participation is encouraged and sup-
ported throughout the development of the system. User stories are the agile answer to the problem and
they are thoroughly discussed and illustrated in this chapter.

Chapter V: Handling of Software Quality Defects in Agile Software Development

Although the previous chapter told us how to capture and avoid problems in user requirements, defects
can still be injected in the software code. In agile software development and maintenance, the phase

xiv
that allows for continuous improvement of a software system by removing quality defects is refactoring.
However, because of schedule constraints, not all quality defects can be removed in just one refactoring
phase. Documentation of quality defects that are found during automated or manual discovery activi-
ties (e.g., pair programming) is necessary to avoid waste of time by rediscovering them in later phases.
However, lack of documentation and handling of existing quality defects and refactoring activities is
a typical problem in agile software maintenance. In order to understand the reason for modifying the
code, one must consult either proprietary documentations or software versioning systems. Jörg Rech
(Germany), the author of this chapter, describes a process for the “recurring and sustainable discovery,
handling, and treatment of quality defects in software systems.” His proposed tool for assuring quality
in this context is an annotation language, capable to register information about quality defects found in
source code, representing the defect and treatment activities of a software sub-system. One additional
benefit from using such annotation language is that it can also be useful during testing and inspection
activities.

Chapter VI: Agile Quality Assurance Techniques for GUI-Based Applications

In this chapter, Atif Memon and Qing Xie (USA) adopt a strong, process-based approach for assur-
ing quality while developing in agile mode. They discuss the need for new agile model-based testing
mechanisms, neatly integrated with agile software development/evolution and propose a new concentric
loop-based technique, which effectively utilizes resources during iterative development. They call the
inner loop “crash testing,” applied on each code check-in of the software. The second loop is called
smoke testing and operates on each day’s build. The outermost loop is called the “comprehensive testing”
loop, executed after a major version of the software is available. The authors illustrate their approach
on a critical part of today software systems, namely graphical user interface (GUI). They choose GUI
front-ends because GUI development is quite suitable for agile development and because rapid testing
of GUI-based systems is particularly challenging. They describe in detail the GUI model used to imple-
ment the concentric-loop technique.

Section III: Quality within Agile Process Management

Chapter VII: Software Configuration Management in Agile Development

Chapters in this section focus on project activities that are parallel to development and software configu-
ration management (SCM) is an essential part of any software process. Because of frequent changes,
multiple iterations and software versions, SCM is of particular importance for any agile project. In this
chapter, Lars Bendix and Torbjörn Ekman (Sweden) discuss the peculiarities of agile SCM and argue that
SCM needs to be done differently and in a more extended fashion than during traditional development.
They also define the ways in which quality is assured through the application of SCM. To do so, they
first provide a brief introduction to the focal SCM principles and list a number of typical agile activities
related to SCM. Next, they explain the reader that it is possible to define certain general SCM guidelines
for how to support and strengthen these typical agile activities. They describe the characteristics of an
agile method that are necessary in order to take full advantage from SCM and, as a consequence, to bet-
ter assure quality. Following the proposed guidelines, any agile project can obtain the best result from
SCM according to the agile method it applies and the project particular context.

xv
Chapter VIII: Improving Quality by Exploiting Human Dynamics in Agile Methods

This chapter deals with a completely different process issue than previous chapter, namely the manage-
ment of the human resources that are involved in agile development. Panagiotis Sfetsos and Ioannis
Stamelos (Greece) argue that human factors are still critical for the success of software engineering in
general. In particular, agile methods are even more sensitive to human factors because they are heavily
based on the contribution and effort of the individuals working in the agile project. Documentation is
limited with respect to traditional development and effective inter-personal communication is neces-
sary for successful project completion. The authors describe how a large agile organization can cope
with human resource management both at the corporate level and the project level. First part of the
chapter proposes and discusses a model for personnel management based on the well-known People-
CMM assessment and improvement model. The agile organization can pursue higher model levels by
assessing its current situation and by introducing advanced human resource management practices. In
doing so, the organization must take profit from the distinguished way in which humans are involved
in agile methods and activities. Second part proposes a model that exploits developer personalities and
temperaments to effectively allocate and rotate developers in pairs for pair programming. The rationale
is that by mixing different types of personalities and temperaments, pairs become more productive and
quality is more easily assured.

Chapter IX: Teaching Agile Software Development Quality Assurance

This chapter ends the section on agile process issues dealing with the preparation of software engineers
and managers to address agile quality assurance. Authors Orit Hazzan and Yael Dubinsky (Israel) provide
a teaching framework that focuses on the way quality issues are perceived in agile software development
environments. The teaching framework consists of nine principles, which can be adjusted according to
different specific teaching environments and therefore implemented in various ways. The chapter out-
lines these principles and addresses their contribution to learners’ understanding of agile quality. The
authors enrich the discussion of their teaching framework by identifying the differences between agile
and traditional software development in general, and with respect to software quality in particular. The
material of the chapter can be used by software engineering instructors who wish to base students learn-
ing on students’ experience of the different aspects involved in software development environments.

Section IV: Agile Methods and Quality: Field Experience

Chapter X: Agile Software Development Quality Assurance: Agile Project Manage-


ment, Quality Metrics, and Methodologies

In the first chapter of the section with results end experiences from agile companies, James F. Kile and
Maheshwar R. Inampudi (IBM, USA) deal with a really hot issue, crucial for the further expansion of
agile methods. They ask whether “the adaptive methods incorporated within many of the most popular
agile software development methodologies can be successfully implemented within a highly disciplined
and highly structured software development environment and still provide the benefits accorded to fully
agile projects.” They observe that agile methods have been applied mostly to non-critical projects, by
small project teams, with vague requirements, a high degree of anticipated change, and no significant
availability or performance requirements. It is therefore questionable whether agile methods can be
applied in situations with strong quality requirements. The authors report an extremely interesting

xvi
experience: they describe how one team adopted not one single agile method, but several individual
agile development techniques. They manage to achieve software development quality improvements,
while in parallel reducing overall cycle time. The authors propose that all is needed is a common-sense
approach to software development. Overall, they demonstrate that the incorporation of individual agile
techniques may be done in such a way that no additional risk is incurred for projects having high avail-
ability, performance, and quality requirements.

Chapter XI: Test-Driven Development: An Agile Practice to Ensure Quality is Built


from the Beginning

This chapter is written by Scott Mark (Medtronic, USA) and describes the practice of test-driven de-
velopment (TDD) and its impact on the overall culture of quality and quality assurance in an organiza-
tion. The discussion on this popular practice is based on the author’s personal experience introducing
TDD into two existing development projects in an industrial setting. He discusses basic concepts of
TDD from an industry practitioner’s perspective and he proceeds with an elaboration of the benefits
and challenges of adopting TDD within a development organization. He reports to the reader that TDD
was well-received by team members, and he is optimistic, in the sense that other teams will behave in
the same manner, provided that they are prepared to evaluate their own experiences and address the
challenges imposed by TDD.

Chapter XII: Quality Improvements from using Agile Development Methods:


Lessons Learned

This chapter, ending the session with experiences from industry (and the book), comes from another
large company, namely Siemens (USA). Beatrice Miao Hwong, Gilberto Matos, Monica McKenna,
Christopher Nelson, Gergana Nikolova, Arnold Rudorfer, Xiping Song, Grace Yuan Tai, Rajanikanth
Tanikella, and Bradley Wehrwein report that “in the past few years, Siemens has gained considerable
experience using agile processes with several projects of varying size, duration, and complexity.” The
authors build on this invaluable experience for the agile world and report that they have observed “an
emerging pattern of quality assurance goals and practices across these experiences.” They describe the
projects in which they have used agile processes. They also provide information on the processes them-
selves. They discuss briefly project quality goals and practices and present (as the chapter title promises)
the lessons learned from the successes and failures in practicing quality assurance in agile projects. The
material they provide is informative about the methods they employed for achieving the established
quality goals, leading to a first-hand understanding of the current state of ASDQA.

xvii
Acknowledgments

This book has become a reality only because of the hard work of the chapter authors. We sincerely wish
to thank them for the time they devoted to write their chapter, peer review two chapters of co-authors,
and revise their chapters according to the comments they received. We also wish to thank Dr. Sulayman
Sowe (Aristotle University) for proofreading a significant part of the book text. Finally, we would like
to thank Kristin Roth (IGI) for her guidance and useful suggestions throughout the preparation of the
material, and Idea Group Publishing for the opportunity they gave us to edit this interesting book.

Ioannis Stamelos
Panagiotis Sfetsos
Editors

xviii
About the Editors

Ioannis Stamelos is an assistant professor of computer science at the Aristotle University of Thessa-
loniki, Department of Informatics. He received a degree in electrical engineering from the Polytechnic
School of Thessaloniki (1983) and a PhD degree in computer science from the Aristotle University of
Thessaloniki (1988). He teaches language theory, object-oriented programming, software engineering,
software project management, and enterprise information systems at the graduate and postgraduate level.
His research interests include empirical software evaluation and management, software education, and
open source software engineering. Stamelos is the author of 60 scientific papers and a member of the
IEEE Computer Society.

Panagiotis Sfetsos is a lecturer of computer science at Alexander Technological Education Institute of


Thessaloniki, Greece, Department of Informatics, since 1990. His research interests include experimenta-
tion in SE, agile methods, extreme programming, software measurement, software testing, and quality.
Sfetsos received his BSc in computer science and statistics from the University of Uppsala, Sweden (1981),
and then worked for several years in software development at industry and education. He published a

xix
xx
Section I
Introduction:
Agile Methods and Quality

xxi
xxii


Chapter I
Agile Software Methods:
State-of-the-Art

Ernest Mnkandla
Monash University, South Africa

Barry Dwolatzky
University of Witwatersrand, South Africa

AbstrAct

This chapter is aimed at comprehensively analyzing and defining agile methodologies of software devel-
opment from a software quality assurance perspective. A unique way of analyzing agile methodologies
to reveal the similarities that the authors of the methods never tell you is introduced. The chapter starts
by defining agile methodologies from three perspectives: a theoretical definition, a functional defini-
tion, and a contextualized definition. Then an agile quality assurance perspective is presented starting
from a brief review of some of the traditional understandings of quality assurance to the innovations
that agility has added to the world of quality. The presented analysis approach opens a window into an
understanding of the state-of-the-art in agile methodologies and quality, and what the future could have
in store for software developers. An understanding of the analysis framework for objectively analyzing
and comparing agile methodologies is illustrated by applying it to three specific agile methodologies.

IntroductIon development is not just about meeting customer


requirements (because even process-driven
Agile software development methodologies have methodologies do that), but it is about meeting
taken the concepts of software quality assurance the changing requirements right up to the level
further than simply meeting customer require- of product deployment. This chapter introduces
ments, validation, and verification. Agility innova- a technique for analyzing agile methodologies in
tively opens new horizons in the area of software a way that reveals the fundamental similarities
quality assurance. A look at the agile manifesto among the different agile processes.
(Agile Alliance, 2001) reveals that agile software

Copyright © 2007, Idea Group Inc., distributing in print or electronic forms without written permission of IGI is prohibited.
Agile Software Methods: State-of-the-Art

As for now, there is a reasonable amount of chApter objectIves


literature that seeks to describe this relatively new
set of methodologies that have certainly changed The objective of this chapter is to introduce you to
the way software development is done. Most of the the fundamentals of analyzing agile methodolo-
existing work is from the authors of the methodolo- gies to reveal the bare bones of agile development.
gies and a few other practitioners. What lacks is After reading this chapter, you will:
therefore a more balanced evaluation comparing
what the original intents of the authors of agile • Understand three approaches to the defini-
methodologies were, to the actual things that have tion of agile methodologies (i.e., a theoreti-
been done through agile methodologies over the cal definition, a functional definition, and
last few years of their existence as a group, and a contextualized definition).
the possible future applications. • Understand the state-of-the-art in agile
While most of those who have applied agile methodologies.
methods in their software development projects • Understand the presented framework for
have gained margins that are hard to ignore in the objectively analyzing and comparing agile
areas of product relevance (a result of embrac- methodologies.
ing requirements instability) and quick delivery • Understand the meaning of software quality
(a result of iterative incremental development), assurance in an agile context.
some have not joined this new fun way to de-
velop software due to a lack of understanding the
fundamental concepts underlying agile method- bAckground
ologies. Hence, this chapter intends to give the
necessary understanding by comprehensively This section will start by defining agile meth-
defining agile methodologies and revealing how odologies based on what people say about agile
agile methodologies have taken software quality methodologies, what people do with agile method-
assurance further than traditional approaches. The ologies, and what agile methodologies have done
second concern resulted from more than three to the broad area of software development.
years of research into agile methodology practices
where the author discovered that the individual
agile methods such as extreme programming, defInIng AgIle MethodologIes
scrum, and lean development etc. are not that
different from each other. The apparent differ- The agile software development methodologies
ence is because people from different computing group was given the name “agile” when a group
backgrounds authored them and happen to view of software development practitioners met and
the real world differently. Hence, the differences formed the Agile Alliance (an association of
are not as much as the authors would like us to software development practitioners that was
believe. The evaluation technique introduced here formed to formalize agile methodologies) in
will reveal the similarities in a novel way and February 2001. The agile movement could mark
address the adoption concerns of agile method- the emergence of a new engineering discipline
ologies. This also reveals what quality in an agile (Mnkandla & Dwolatzky, 2004a) that has shifted
context means. the values of the software development process
from the mechanistic (i.e., driven by process
and rules of science) to the organic (i.e., driven
by softer issues of people and their interactions).


Agile Software Methods: State-of-the-Art

This implies challenges of engineering complex new release. Each release is a fully tested
software systems in work environments that are usable subsystem with limited functionality
highly dynamic and unpredictable. based on the implemented specifications.
As the development progresses, the usable
functionalities increase until a full system
theoretIcAl defInItIon is realized.
3. Self-organizing: This term introduces a
After the first eWorkshop on agile methodologies relatively foreign notion to the management
in June 2002, Lindvall et al. (2002) summarized of scientific processes. The usual approach
the working definition of agile methodologies is to organize teams according to skills and
as a group of software development processes corresponding tasks and let them report to
that are iterative, incremental, self-organizing, management in a hierarchical structure. In
and emergent. The meaning of each term in the the agile development setup, the “self-orga-
greater context of agility is shown next. nizing” concept gives the team autonomy
to organize itself to best complete the work
1. Iterative: The word iterative is derived items. This means that the implementation of
from iteration which carries with it con- issues such as interactions within the team,
notations of repetition. In the case of agile team dynamics, working hours, progress
methodologies, it is not just repetition but meetings, progress reports etc. are left to the
also an attempt to solve a software problem team to decide how best they can be done.
by finding successive approximations to the Such an approach is rather eccentric to the
solution starting from an initial minimal way project managers are trained and it re-
set of requirements. This means that the quires that the project managers change their
architect or analyst designs a full system management paradigm all together. This
at the very beginning and then changes technique requires that the team members
the functionality of each subsystem with respect each other and behave professionally
each new release as the requirements are when it comes to what has been committed
updated for each attempt. This approach on paper. In other words management and the
is in contrast to more traditional methods, customer should not get excuses for failure
which attempt to solve the problem in one to meet the commitment and there should be
shot. Iterative approaches are more relevant no unjustified requests for extensions. The
to today’s software development problems role of the project manager in such a setup
that are characterized by high complexity is to facilitate the smooth operation of the
and fast changing requirements. Linked team by liaising with top management and
with the concept of iterations is the notion of removing obstacles where possible. The
incremental development, which is defined self-organizing approach therefore implies
in the next paragraph. that there must be a good communication
2. Incremental: Each subsystem is developed policy between project management and the
in such a way that it allows more require- development team.
ments to be gathered and used to develop 4. Emergent: The word implies three things.
other subsystems based on previous ones. Firstly, based on the incremental nature of
The approach is to partition the specified the development approach the system is
system into small subsystems by functional- allowed to emerge from a series of incre-
ity and add a new functionality with each ments. Secondly, based on the self-organiz-


Agile Software Methods: State-of-the-Art

Figure 1. Definition of agility © copyright Ernest Mnkandla PhD thesis University of the Witwa-
tersrand

Agile
Methodologies

Iterative Incremental self-organizing emergent

planned develop the team has the the set of tools,


modification parts of responsibilty techniques,
of parts of the system of organizing development
the system. seperately its internal environment, and
Assists with and integrate. dynamics. requirements
modification Assists with emerge in
of design and improving the process.
requirements. overall
methodology.

ing nature a method of working emerges functIonAl defInItIon


as the team works. Thirdly, as the system
emerges and the method of working emerges Agile methodologies will now be defined ac-
a framework of development technologies cording to the way some agile practitioners have
will also emerge. The emergent nature understood them as they used them in real world
of agile methodologies means that agile practice.
software development is in fact a learning The term “agile” carries with it connotations
experience for each project and will remain of flexibility, nimbleness, readiness for motion,
a learning experience because each project is activity, dexterity in motion, and adjustability
treated differently by applying the iterative, (Abrahamsson, Salo, Ronkainen, & Warsta, 2002).
incremental, self-organizing, and emergent Each of these words will be explained further
techniques. Figure 1 sums up the theoretical in the context of agility in order to give a more
definition of agile methodologies. precise understanding of the kinds of things that
are done in agile development.
The value of agility is in allowing the concepts
defined above to mutate within the parameters set • Flexibility: This word implies that the rules
by the agile values and principles (For details on and processes in agile development can be
agile values and principles see the agile manifesto easily bended to suit given situations without
at http://www.agilealliance.org. . There is always necessarily breaking them. In other words,
a temptation to fix a framework of software de- the agile way of developing software allows
velopment if success is repeatedly achieved, but for adaptability and variability.
that would kill the innovation that comes with • Nimbleness: This means that in agile
agile development. software development there must be quick
delivery of the product. This is usually done
through the release of usable subsystems


Agile Software Methods: State-of-the-Art

within a period ranging from one week to mentation claiming that the code is sufficient
four weeks. This gives good spin-offs as the documentation. As agile methodologies
customer will start using the system before approach higher levels of maturity minimiz-
it is completed. ing documentation has evolved to generally
• Readiness for motion: In agile develop- imply providing as much documentation as
ment, the general intention is to reduce the customer is willing pay for in terms of
all activities and material that may either time and money.
slow the speed of development or increase • Efficient means doing only that work that
bureaucracy. will deliver the desired product with as little
• Activity: This involves doing the actual overhead as practically possible.
writing of code as opposed to all the plan- • Low-risk implies trading on the practical
ning that sometimes takes most of the time lines and leaving the unknown until it is
in software development. known. In actual fact, all software develop-
• Dexterity in motion: This means that there ment methodologies are designed to reduce
must be an abundance of skills in the activ- the risks of project failure. At times, a lot of
ity of developing code. The skills referred effort is wasted in speculative abstraction of
to are the mental skills that will arm the the problem space in a bid to manage risk.
developers for programming challenges and • Predictable implies that agile methodolo-
team dynamics. gies are based on what practitioners do all the
• Adjustability: This is two fold; firstly there time, in other words the world of ambiguity
must be room for change in the set of activi- is reduced. This however does not mean
ties and technologies that constitute an agile that planning, designs, and architecture of
development process, secondly the require- software are predictable. It means that agil-
ments, code, and the design/architecture ity allows development of software in the
must be allowed to change to the advantage most natural ways that trained developers
of the customer. can determine in advance based on special
knowledge.
According to Beck (1999), agile methodolo- • Scientific means that the agile software
gies are a lightweight, efficient, low-risk, flexible, development methodologies are based on
predictable, scientific, and fun way to develop sound and proven scientific principles. It
software. These terms will be defined in this nevertheless remains the responsibility of
context to give a functional perspective of agile the academia to continue gathering empirical
development. evidence on agile processes because most
of the practitioners who authored agile
• Lightweight implies minimizing everything methodologies seem to have little interest
that has to be done in the development pro- and time to carryout this kind of research.
cess (e.g., documentation, requirements, etc.) • Fun way because at last developers are al-
in order to increase the speed and efficiency lowed to do what they like most (i.e., to spend
in development. The idea of minimizing most of their time writing good code that
documentation is still a controversial one works). To the developers, agility provides a
as some assume agility to mean no docu- form of freedom to be creative and innova-
mentation at all. Such views are however not tive without making the customer pay for
unfounded because some agile extremists it, instead the customer benefits from it.
have expressed connotations of zero docu-


Agile Software Methods: State-of-the-Art

Schuh (2004) defines agile development as on which traditional methodologies are built, and
a counter movement to 30 years of increasingly they also happen to be the main limitations of the
heavy-handed processes meant to refashion com- traditional methodologies.
puter programming into software engineering, Boehm et al. (2004) view agile methodologies
rendering it as manageable and predictable as as a challenge to the mainstream software develop-
any other engineering discipline. ment community that presents a counter-culture
On a practical perspective, agile methodolo- movement, which addresses change from a radi-
gies emerged from a common discovery among cally different perspective. All agile methodolo-
practitioners that their practice had slowly drifted gies follow the four values and 12 principles as
away from the traditional heavy document and outlined in the agile manifesto.
process centered development approaches to
more people-centered and less document-driven
approaches (Boehm & Turner, 2004; Highsmith, contextuAl defInItIon
2002a; Fowler, 2002). There is a general mis-
conception that there is no planning or there is From these definitions of agile methodologies, a
little planning in agile processes. This is due to contextual definition can be derived which looks
the fact that the agile manifesto lists as one of at what agility means in terms of certain specific
its four values the preference for responding to software engineering concepts. Examples of that
change over following a plan (Agile Alliance, would be concepts are software quality assurance,
2001). In fact, planning in agile projects could software process improvement, software process
be more precise than in traditional processes it modeling, and software project management. Ag-
is done rigorously for each increment and from ile methodologies will now be defined according
a project planning perspective agile methodolo- to these concepts. Since this book is specifically
gies provide a risk mitigation approach where focused on agile software quality assurance the
the most important principle of agile planning is definition of agile software quality assurance will
feedback. Collins-Cope (2002) lists the potential be given in more detail.
risks as: risks of misunderstandings in functional
requirements, risks of a deeply flawed architecture;
risks of an unacceptable user interface; risks of AgIle softwAre QuAlIty
wrong analysis and design models; risks of the AssurAnce
team not understanding the chosen technology et
cetera. Feedback is obtained by creating a work- This section starts by summarizing the traditional
ing version of the system at regular intervals or definitions of quality and then presents a summary
per increment according to the earlier planning of the work that has been done in the area of agil-
effort (Collins-Cope, 2002). ity and quality. References to older literature on
Besides dealing with the most pertinent risks software quality are not intended to be exhaus-
of software development through incremental tive, but to be simply present a fare baseline for
development, agile methodologies attack the evaluating software quality perspectives in the
premise that plans, designs, architectures, and modern processes. The authors are aware of a
requirements are predictable and can therefore number of initiatives in research and academic
be stabilized. Agile methodologies also attack institutions where evaluation of quality concepts
the premise that processes are repeatable (High- is performed on some agile practices.
smith, 2001; Schwaber & Beedle, 2002). These
two premises are part of fundamental principles


Agile Software Methods: State-of-the-Art

defInIng QuAlIty ity with human assessment, and cost and benefit
(Hendrickson, 2004).
Have you ever wondered what Joseph Juran Some software engineers have defined soft-
generally considered to be a quality legend would ware quality as follows:
have said about agile processes and the quality
movement? Well, this is what he said about the 1. Meyer (2000) defines software quality ac-
ISO 9000 when he was asked by Quality Digest cording to an adapted number of quality
if he thought ISO 9000 had actually hindered the parameters as defined by McCall (1977),
quality movement; “Of course it has. Instead of which are correctness, robustness, extend-
going after improvement at a revolutionary rate, ibility, reusability, compatibility, efficiency,
people were stampeded into going after ISO 9000, portability, integrity, verifiability, and ease
and they locked themselves into a mediocre stan- of use.
dard. A lot of damage was, and is, being done” 2. Pressman, who derives his definition from
(QCI International, 2002). Crosby, defines quality as a “conformance
According to Juran, quality is fitness for to explicitly stated functional requirements,
use, which means the following two things: “(1) explicitly documented development
quality consists of those product features that standards, and implicit characteristics that
meet the needs of the customers and thereby are expected of all professionally developed
provide product satisfaction. (2) Quality consists software” (Pressman, 2001).
of freedom from deficiencies” (Juran & Gryna, 3. Sommerville (2004) defines software quality
1988). as a management process concerned with
Philip Crosby, who developed and taught con- ensuring that software has a low number
cepts of quality management, whose influence can of defects and that it reaches the required
be found in the ISO 9000:2000 standard, which standards of maintainability, reliability,
differs from the 1994 standard in the context of portability, and so on.
each of the eight principles, defines quality as 4. van Vliet (2003) follows the IEEE definition
conformance to requirements and zero defects of quality as stated in the IEEE Glossary of
(Crosby, 1984). Software Engineering Terminology, which
ISO 9000 defines quality as the totality of defines quality assurance in two ways as:
characteristics of an entity that bear on its ability “(1) A planned and systematic pattern of
to satisfy stated or implied needs. Where “stated all actions necessary to provide adequate
needs” means those needs that are specified as confidence that the item or product conforms
requirements by the customer in a contract, and to established operational, functional, and
‘implied needs’ are those needs that are identi- technical requirements. (2) A set of activities
fied and defined by the company providing the designed to evaluate the process by which
product. These definitions of quality have a products are developed or manufactured”
general bias towards the manufacturing indus- (IEEE, 1990). van Vliet’s perspective then
try although they should in general apply to all combines this definition with the analysis
products, nevertheless, software products are of the different taxonomies on quality.
rather complex hence they should be defined in 5. Pfleeger (2001) aligns her perspective with
a slightly different way. Garvin’s quality perspective, which views
Weinberg defines quality simply as “the value quality from five different perspectives
to some people” (Weinberg, 1991) and some have namely; the transcendental meaning that
expanded on that to mean the association of qual- quality can be recognized but not defined,


Agile Software Methods: State-of-the-Art

user view meaning that quality is fitness into the ISO 9126 (i.e., functionality, reli-
for purpose, manufacturing meaning that ability usability, efficiency maintainability,
quality is conformance to specification, and portability) does not work. His argu-
product view meaning that quality is tied ment is that “in order to use a taxonomy,
to inherent product characteristics, and a specific requirement must be put into a
the value-based view meaning that quality category” (Bass, 2006). However, there are
depends on the amount the customer is some requirements that may be difficulty
willing to pay for the product. to put under any category, for example,
6. Bass (2006) argues that the common practice “denial of service attack, response time for
of defining software quality by dividing it user request, etc.” What Bass (2006) then

Table 1. Agile quality techniques as applied in extreme programming

Technique Description
Refactoring Make small changes to code, Code behaviour must
not be affected, Resulting code is of higher quality
(Ambler, 2005).
Test-driven Create a test, Run the test, Make changes until the
development test passes (Ambler, 2005).
Acceptance Quality assurance test done on a finished system,
testing Usually involves the users, sponsors, customer,
etc. (Huo, Verner, Zhu, & Babar, 2004).
Continuous Done on a daily basis after developing a number
integration of user stories. Implemented requirements are
integrated and tested to verify them. This is an
important quality feature.
Pair Two developers work together in turns on one
programming PC, Bugs are identified as they occur, Hence the
product is of a higher quality (Huo et al., 2004).
Face-to-face Preferred way of exchanging information about a
communication project as opposed to use of telephone, email, etc.
Implemented in the form of daily stand-up
meetings of not more than twenty minutes (Huo
et al, 2004). This is similar to the daily Scrum
in the Scrum method. It brings accountability
to the work in progress, which vital for quality
assurance.
On-site A customer who is a member of the development
customer team, Responsible for clarifying requirements
(Huo et al., 2004).
Frequent Each time there is a release the customer gives
customer feedback on the system, and result is to improve
feedback the system to be more relevant to needs of the
customer (Huo et al., 2004).
Quality is in fact meeting customer requirements.
System Simple story of how the system works (Huo et al.,
metaphor 2004), Simplifies the discussion about the system
between customer/ stakeholder/ user and the
developer into a non-technical format. Simplicity
is key to quality.


Agile Software Methods: State-of-the-Art

proposes is the use of quality attributing • The provision of detailed knowledge about
general scenarios. specific quality issues of the agile pro-
cesses.
From an agile perspective, quality has been • Identification of innovative ways to improve
defined by some practitioners as follows: agile quality.
McBreen (2003) defines agile quality assur- • Identification of specific agile quality tech-
ance as the development of software that can niques for particular agile methodologies.
respond to change, as the customer requires it to
change. This implies that the frequent delivery of Literature shows that Huo et al. (2004) devel-
tested, working, and customer-approved software oped a comparison technique whose aim was to
at the end of each iteration is an important aspect provide a comparative analysis between quality
of agile quality assurance. in the waterfall development model (as a repre-
Ambler (2005) considers agile quality to be a sentative of the traditional camp) and quality in
result of practices such as effective collaborative the agile group of methodologies. The results of
work, incremental development, and iterative the analysis showed that there is indeed quality
development as implemented through techniques assurance in agile development, but it is achieved
such as refactoring, test-driven development, in a different way from the traditional processes.
modelling, and effective communication tech- The limitations of Huo et al.’s tool however, are
niques. that the analysis:
To conclude this section, Table 1 gives a sum-
mary of the parameters that define agile quality as • Singles out two main aspects of quality
specifically applied in extreme programming--a management namely quality assurance and
popularly used agile methodology. These aspects verification and validation.
of agile quality have eliminated the need for heavy • Overlooks other vital techniques used in
documentation that is prescribed in traditional agile processes to achieve higher quality
processes as a requirement for quality. Quality management.
is a rather abstract concept that is difficult to de- • Agile quality assurance takes quality issues
fine but where it exists, it can be recognized. In a step beyond the traditional software quality
view of Garvin’s quality perspective there may assurance approaches.
be some who have used agile methodologies in
their software development practices and seen Another challenge of Huo et al.’s technique is
improvement in quality of the software product that while the main purpose of that analysis was
but could still find it difficult to define quality in to show that there is quality assurance in agile
the agile world. processes, it does not make it clear what the way
forward is. Agile proponents do not seem to be
worried about comparison between agile and
evAluAtIng QuAlIty In AgIle traditional processes as some of the more zealous
processes “agilists” believe that there is no way traditional
methods can match agile methods in any situation
So can we evaluate quality assurance in agile (Tom Poppendieck, personal e-mail 2005).
processes? This can be done through: The evaluation described in this section im-
proves on (Huo et al., 2004) framework by further


Agile Software Methods: State-of-the-Art

Table 2. Mapping software quality parameters to agile techniques

Software Quality Agile Techniques Possible Improvements


Parameters
Correctness Write code from minimal Consider the possibility of
requirements. Specification using formal specification
is obtained by direct com- in agile development,
munication with the cus- Possible use of general
tomer. Customer is allowed scenarios to define require-
to change specification. ments (note that some
Test-driven development. development teams are
already using this).
Robustness Not directly addressed in Include possible extreme
agile development. conditions in requirements.
Extendibility A general feature of all OO Use of modeling tech-
developed applications. niques for software archi-
Emphasis is on techni- tecture.
cal excellence and good
design. Emphasis also on
achieving best architecture.
Reusability A general feature of all OO Develop patterns for agile
developed applications. applications.
There are some arguments
against reusability of agile
products (Turk, France,
& Rumpe, 2002; Weisert,
2002).
Compatibility A general feature of all OO Can extra features be
developed applications. added for the sake of com-
patibility even if they may
not be needed? This could
contradict the principle of
simplicity.
Efficiency Apply good coding stan- Encourage designs based
dards. on the most efficient algo-
rithms
Portability Practice of continuous Some agile methods do not
integration in extreme pro- directly address issues of
gramming. product deployment. Solv-
ing this could be to the
advantage of agility.
Timeliness Strongest point of agility,
Short cycles, quick deliv-
ery, etc.
Integrity Not directly addressed in
agile development.
Verifiability Test-driven development is
another strength of agility.
Ease of use Since the customer is part Design for the least quali-
of the team, and customers fied user in the organiza-
give feedback frequently, tion.
they will most likely rec-
ommend a system that is
easy to use.

0
Agile Software Methods: State-of-the-Art

identifying some more agile quality techniques • Correctness: The ability of a system to per-
and then in an innovative way identifies the agile form according to defined specification.
process practices that correspond to each tech- • Robustness: Appropriate performance of
nique. The contribution of this evaluation is the a system under extreme conditions. This is
further identification of possible practices that can complementary to correctness.
be done to improve on the already high quality • Extendibility: A system that is easy to adapt
achievements enjoyed by agile processes. to new specification.
• Reusability: Software that is composed of
elements that can be used to construct dif-
technIQues ferent applications.
• Compatibility: Software that is composed
The parameters that define software quality from a of elements that can easily combine with
top-level view can be rather abstract. However, the other elements.
proposed technique picks each of the parameters • Efficiency: The ability of a system to place
and identifies the corresponding agile techniques as few demands as possible to hardware
that implement the parameter in one way or anoth- resources, such as memory, bandwidth used
er. Possible improvements to the current practice in communication and processor time.
have been proposed by analysing the way agile • Portability: The ease of installing the
practitioners work. Of great importance to this software product on different hardware and
kind of analysis is a review of some of the intuitive software platforms.
practices that developers usually apply which may • Timeliness: Releasing the software before
not be documented. You may wonder how much or exactly when it is needed by the users.
objectivity can be in such information. The point • Integrity: How well the software protects
though is that developers tell their success stories its programs and data against unauthorized
at different professional forums and some of the access.
hints from such deliberations have been captured • Verifiability: How easy it is to test the
in this technique without following any formal system.
data gathering methodology. The authors believe • Ease of use: The ease with which people of
that gathering of informal raw data balances the various backgrounds can learn and use the
facts especially in cases where developers talk software.
about their practice. Once the data is gathered
formally, then a lot of prejudices and biases come
in and there will be need to apply other research softwAre process
techniques to balance the facts. Tables 2 and 3 IMproveMent
summarize the evaluation approach.
In formal software quality management, qual- A bigger-picture view of agile processes leads to a
ity assurance activities are fulfilled by ensuring notion that agile methods are a group of processes
that each of the parameters listed in Table 2 are that have reduced the development timeframe of
met to a certain extent in the software develop- software systems and introduced innovative tech-
ment life cycle of the process concerned. A brief niques for embracing rapidly changing business
definition of each of these parameters is given requirements. With time, these relatively new
according to Meyer (2000): techniques should develop into mature software
engineering standards.


Agile Software Methods: State-of-the-Art

softwAre process ModelIng other agile methodologies as long they suit a given
situation (Beck & Andres, 2004). In fact, Kent
The agile perspective to software process mod- Beck in his extreme programming (XP) master
eling is that whether formal or informal when classes frequently mentions the errors of extrem-
approaches to modeling are used the idea is to ism in the first edition of his book on XP (Beck,
apply modeling techniques in such a way that 1999). A detailed review of agile methodologies
documentation is minimized and simplicity of reveals that agile processes address the same is-
the desired system is a virtue. Modeling the agile sues using different real life models.
way has led to breakthroughs in the application of The evaluation technique presented in this
agile methods to the development of large systems chapter reveals, for example, that lean develop-
(Ambler, 2002) ment (LD) views software development using
a manufacturing and product development
metaphor. Scrum views software development
softwAre project processes using a control engineering metaphor.
MAnAgeMent Extreme programming views software develop-
ment activities as a social activity where develop-
The agile approach to managing software projects ers sit together. Adaptive systems development
is based on giving more value to the developers (ASD) views software development projects
than to the process. This means that manage- from the perspective of the theory of complex
ment should strive to make the development self-adaptive systems (Mnkandla, 2006).
environment conducive. Instead of worrying Tables 3 to 6 summarize the analysis of agile
about critical path calculation and Gantt chart methodologies. Only a few of the existing agile
schedules, the project manager must facilitate methodologies have been selected to illustrate the
face-to-face communication, and simpler ways evaluation technique. The first column from the
of getting feedback about the progress of the left on Tables 3, 4, and 5 lists some methodology
project. In agile development there is need to elements that have been chosen to represent the
be optimistic about people and assume that they details of a methodology. There is a lot of sub-
mean good hence give them space to work out jectivity surrounding the choice of methodology
the best way to accomplish their tasks. It is also elements. It is not within the scope of this chapter
an agile strategy to trust that people will make to present a complete taxonomy of methodolo-
correct professional decisions about their work gies. For more detailed taxonomies see Avison
and to ensure that the customer is represented in and Fitzgerald (2003), Boehm et al. (2004),
the team throughout the project. Glass and Vessey (1995), and Mnkandla (2006).
Therefore, the elements used here were chosen
to reveal the similarities amongst different agile
the AgIle Methodology methodologies. The importance of revealing these
evAluAtIon frAMework similarities is to arm the developers caught up in
the agile methodology jungle wondering which
All agile methodologies have striking similarities methodology to choose. While the methodology
amongst their processes because they are based used in your software development project may
on the four agile values and 12 principles. It is not directly lead to the success of a project and
interesting to note that even the authors of agile may not result in the production of a high qual-
methodologies no longer emphasize their meth- ity product use of a wrong methodology will
odology boundaries and would use practices from lead to project failure. Hence, there is in wisdom


Agile Software Methods: State-of-the-Art

selecting a correct and relevant process. Most project management aspects into XP (see www.
organization may not afford the luxury of using ccpace.com for details on Catalyst).
different methodologies for each project though Evaluation of each methodology should also
that would be ideal for greater achievements. It reveal what sort of activities and practices are
also sounds impractical to have a workforce that prevalent in the methodology. This should assist
is proficient in many methodologies. Sticking to prospective users of the methodology to determine
one methodology and expect it to be sufficient the practices that could be relevant to their given
for all projects would also be naïve (Cockburn, situation. This evaluation technique reveals that
2000). This evaluation technique therefore gives some of the practices from different methodolo-
software development organizations an innovative gies actually fulfill the same agile principles and it
wit to tailor their development process according would be up to the developers to decide which prac-
to the common practices among different agile tices are feasible in their situation. Therefore, the
methodologies. The advantage is to use many implication is that at the level of implementation
methodologies without the associated expenses it becomes irrelevant which agile methodology
of acquiring them. is used, for more on this concept see Mnkandla
There is a need to understand in detail each (2006). Another aspect of agile methodologies
agile methodology that will be analyzed so as to revealed by this evaluation technique is what the
reveal the underlying principles of the methodol- methodology delivers at the end of the project.
ogy. This technique gives the background details When a developer looks for a methodology, they
as to why the methodology was developed in the usually have certain expectations about what
first place. An answer to this question would reveal they want as an output from the methodology.
the fundamental areas of concern of the methodol- Hence, if the methodology’s output is not clearly
ogy and what fears the methodology addresses. understood problems may result. For example if
The prospective user of the methodology would the developer expects use of the methodology to
then decide whether such concern area is relevant lead to the delivery of code and yet the aim of the
to their project. Identifying what problems the methodology is in fact to produce a set of design
methodology intends to solve is another concern artifacts such as those delivered by agile model-
of this evaluation. Some methodologies have a ing this could lead to some problems. Finally,
general bias toward solving technical problems this evaluation technique also reveals the domain
within the development process (i.e., extreme knowledge of the author of the methodology. In
programming deals with issues such as how this phase of analysis, there is no need to men-
and when to test the code). There are other agile tion any names of the authors but simply to state
methodologies that solve project management their domain expertise. The benefit of revealing
problems (i.e., Scrum deals with issues such as the background of the methodology author is to
how to effectively communicate within a project). clarify the practical bias of the methodology, which
Yet other agile methodologies solve general agile is usually based on the experience, and possible
philosophy problems (i.e., Crystal deals with issues fears of the methodology’s author.
such as the size of the methodology vs. the size of Tables 3 to 5 give a summary of the analysis
the team and the criticality of the project. There of specific agile methodologies to illustrate how
may be other agile methodologies that solve a mix this analysis technique can be used for any given
of problems right across the different categories agile methodologies.
mentioned here for example Catalyst puts some


Agile Software Methods: State-of-the-Art

Table 3. Analyzing scrum methodology


Elements Description
Real Life Control engineering.
Metaphor
Focus Management of the development process.
Scope Teams of less than 10, but is scalable to larger teams.
Process Phase 1: planning, product backlog, & design.
Phase 2: sprint backlog, sprint.
Phase 3: system testing, integration, documentation, and
release.
Outputs Working system.
Techniques Sprint, scrum backlogging (writing use cases).
Methodology 1. Software developer, product manager, and industry
Author (two) consultant.
2. Developed mobile applications on an open technology
platform. Component technology developer. Architect of
advanced internet workflow systems.

AnAlyzIng scruM AnAlyzIng leAn developMent

Scrum has been in use for a relatively longer Lean software development like dynamic systems
period than other agile methodologies. Scrum, development method and Scrum is more a set
along with XP, is one of the more widely used of project management practices than a definite
agile methodologies. Scrum’s focus is on the process. It was developed by Bob Charette and
fact that “defined and repeatable processes only it draws on the success that lean manufacturing
work for tackling defined and repeatable problems gained in the automotive industry in the 1980s.
with defined and repeatable people in defined and While other agile methodologies look to change
repeatable environments” (Fowler, 2000), which the development process, Charette believes that
is obviously not possible. To solve the problem of to be truly agile, there is need to change how
defined and repeatable processes, Scrum divides a companies work from the top down (Mnkandla
project into iterations (which are called Sprints) of et al., 2004b). Lean development is targeted at
30 days. Before a Sprint begins, the functionality changing the way CEOs consider change with
required is defined for that Sprint and the team regards to management of projects. LD is based
is left to deliver it. The point is to stabilize the on lean thinking whose origins are found in lean
requirements during the Sprint. Scrum empha- production started by Toyota Automotive manu-
sizes project management concepts (Mnkandla & facturing company (Poppendeick & Poppendeick,
Dwolatzky, 2004b) though some may argue that 2003). Table 4 shows application of the analysis
Scrum is as technical as XP. The term Scrum is technique to LD.
borrowed from Rugby: “A Scrum occurs when
players from each team clump closely together…in
an attempt to advance down the playing field”
(Highsmith, 2002b). Table 3 shows application
of the analysis technique to Scrum.


Agile Software Methods: State-of-the-Art

Table 4. Analyzing lean development methodology


Elements Description
Real Life Metaphor Manufacturing and product development.
Focus Change management.
Project management.
Scope No specific team size.
Process Has no process.
Outputs Provides knowledge for managing projects.
Techniques and Tools Lean manufacturing techniques.
Methodology Author Research engineer at the US Naval Under-
water Systems Center, author of software
engineering books and papers, advisory
board in project management.

AnAlyzIng extreMe small units of functionality taking about a week


progrAMMIng or two to code and test. Programmers provide
estimates for the stories, the customer decides,
Extreme programming (XP) is a lightweight based on value and cost, which stories to do first.
methodology for small-to-medium-sized teams Development is done iteratively and incremen-
developing software based on vague or rapidly tally. Each two weeks, the programming team
changing requirements (Beck, 1999). In the second delivers working stories to the customer. Then
version of XP, Beck extended the definition of XP the customer chooses another two weeks worth
to include team size and software constraints as of work. The system grows in functionality, piece
follows (Beck et al., 2004): by piece, steered by the customer. Table 5 shows
application of the analysis technique to XP.
• XP is lightweight: You only do what you
need to do to create value for the custom-
er. A wAlk through the AnAlysIs
• XP adapts to vague and rapidly changing technIQue
requirements: Experience has shown that
XP can be successfully used even for project Each of the methodology elements as represented
with stable requirements. in Tables 3 to 5 will be defined in the context of
• XP addresses software development con- this analysis approach.
straints: It does not directly deal with project
portfolio management, project financial
issues, operations, marketing, or sales. Methodology’s reAl lIfe
• XP can work with teams of any size: There MetAphor
is empirical evidence that XP can scale to
large teams. This element refers to the fundamental model/
metaphor and circumstances that sparked the
Software development using XP starts from initial idea of the methodology. For example
the creation of stories by the customer to describe watching the process followed by ants to build an
the functionality of the software. These stories are anthill could spark an idea of applying the same
process to software development.


Agile Software Methods: State-of-the-Art

Table 5. Analyzing extreme programming


Elements Description
Real Life Metaphor Social activity where developers sit together.
Focus Technical aspects of software development.
Scope Less than ten developers in a room. Scalable
to larger teams.
Process Phase 1: Writing user stories.
Phase 2: Effort estimation, story prioritiza-
tion.
Phase 3: Coding, testing, integration testing.
Phase 4: Small release.
Phase 5: Updated release.
Phase 6: Final release (Abrahamsson et al,
2002).
Outputs Working system.
Techniques and Tools Pair programming, refactoring, test-driven
development, continuous integration, system
metaphor.
Methodology Authors 1. Software developer (Smalltalk). Strong
(two) believer of communication, reflection, and
innovation. Pattern for software. Test-first
development.
2. Software developer (Smalltalk). Director
of research and development. Developed the
Wiki. Developed Framework for Integrated
Test (Fit).

Methodology focus manage. Remember a methodology does not


do everything but simply gives guidelines that
The focus of the methodology refers to the spe- help in the management of a project. The scope
cific aspects of the software development process of a software development project is relevant in
targeted by the methodology. For example, agile determining the size of the team.
modeling targets the design aspects of the software
development process and also considers issues
of how to model large and complex projects the Methodology process
agile way.
This parameter describes how the methodology
models reality. The model may be reflected in the
Methodology scope life cycle or development process of the meth-
odology. The model provides a means of com-
This element outlines the details to which the munications, captures the essence of a problem
methodology’s development framework is spelled or a design, and gives insight into the problem
out. This is where the methodology specifies area (Avison et al., 2003). The importance of this
what it covers within a project. The importance parameter is that it gives the user a real worldview
of this parameter is to help the user to identify of the series of activities that are carried out in
the list of tasks that the methodology will help the development process.


Agile Software Methods: State-of-the-Art

Methodology outputs open source tools, which reduces potential costs


on software tools.
This parameter defines the form of deliverables to Each methodology has its own techniques
be expected from the methodology. For example that may be relevant or irrelevant to the problem
if an organization purchased lean development at hand. Examples of techniques in extreme
methodology today, would they get code from programming would be pair programming, and
application of the methodology, or would they get the scrum meeting in Scrum methodology. The
some documents, etc (Avison et al., 2003). Each user then analyzes these techniques in relation
agile methodology will give different outputs to the present project, to determine need for the
hence the user can choose the methodology that techniques and include variations that will be part
gives them the output they require. of tailoring the methodology.

technIQues And tools Methodology Author

This parameter helps the user to identify the tech- This parameter defines the domain knowledge
niques and tools applicable to the methodology. of the methodology author. The benefit of doing
Tools may be software applications that can be this is to clarify the background from which the
used to automate some tasks in the development methodology was conceived. There is no need
process, or they can be as simple as whiteboards to mention the name of the author or a detailed
and flip charts. In fact, it is the use of tools that biography of the methodology author.
makes the implementation of a methodology Table 6 summarizes the phase of the analysis
enjoyable. Organizations therefore tend to spend where all the practices are brought together and
a lot of money acquiring tools and training staff similar practices are identified across different
on tools. As technology evolves and new tools methodologies.
emerge, more acquisitions and training are usu- Table 6 classifies the practices using the su-
ally done. However, most agile methodologies do perscripts 1, 2, 3, 4, and 5. The practices with
not specify tools and most agile practitioners use

Table 6. Identifying similarities among the practices


Practices
XP The planning process1, small releases2, metaphor, test-
driven development2, story prioritization3, collective
ownership3, pair programming3, forty-hour work week3,
on-site customer4, refactoring5, simple design5, and con-
tinuous integration5.
LD Eliminate waste1, minimize inventory1, maximize flow2,
pull from demand2, meet customer requirements2, ban
local optimization2, empower workers3, do it right the
first time4, partner with suppliers4, and create a culture of
continuous improvement5.
Scrum Capture requirements as a product backlog1, thirty-day
Sprint with no changes during a Sprint2, Scrum meeting3,
self-organizing teams3, and Sprint planning meeting4.


Agile Software Methods: State-of-the-Art

the same superscript implement the same agile ing activities: planning, estimation, and schedul-
principle. ing of the tasks, design, coding, and testing, and
deployment and maintenance. What varies among
• “1” represents practices that deal with plan- the different processes is the sequence followed
ning issues such as requirements gathering. in implementing each of the phases, and the level
The three methods shown here use different of detail to which each phase is carried out. Some
terms but the principle is to capture minimal methodologies may implement all of the activities
requirements in the simplest available way and some partial methodologies may specialize
and start coding. in just a few. The other difference is in the way
• “2” represents practices that deal with im- the process values the people involved in the de-
provement of quality in terms of meeting velopment activities and what value is attached to
the volatile requirements. the customer in relation to what needs to be done.
• “3” represents practices that facilitate freely These differences mark the major boundaries
working together of developers, effective among software development methodologies.
communication, empowered decision-mak-
ing, and team dynamics issues. Agile development higher ground
• “4” represents practices that deal with quick
delivery of the product. This section looks at issues that are done in a
• “5” represents practices that deal with agile peculiar way by agile methodologies. The role of
quality assurance property of ensuring that the domain expert in agile methodologies is rather
the product is improved continuously until unique. Software development experts with practi-
deployment. cal experience in this field have a lot of knowledge
that can be classified as tacit knowledge due to
When the similar practices are identified, the the fact that it is gained through practice and is
developers can then decide to select and tailor not written down in any form. Tacit knowledge is
some practices to their environment according difficult to quantify hence this concept remains
to relevance, and project and customer priorities. quite subjective in the implementation of agile
You will notice that the choice of the activities of methodologies. However, the strength of using
the development process according to this analy- tacit knowledge rests in the team spirit that puts
sis have shifted from focusing on the individual trust on experts to do what they know best within
methodologies to a focus on practices. their professional ethics. This in fact is what
differentiates the “agile movement” from other
development processes. Another hot issue about
Issues And controversIes agile development is the concept of self-organizing
surroundIng AgIle teams. This concept means that agile develop-
developMent ment teams are allowed to organize themselves
the best way they want in order to achieve the
software development common given goals. As a result of applying this concept,
ground managing agile projects becomes different from
the traditional approaches to project management.
This section looks at issues that are done in a The role of a project manager becomes more of a
similar way among different software develop- facilitator than a controller. Detailed discussions
ment methodologies. Most software development on what has become known as “agile project
processes in use today involve some of the follow- management” can be found in Highsmith (2004)


Agile Software Methods: State-of-the-Art

and Schwaber (2004) and at http://finance.groups. in software engineering held in Europe once per
yahoo.com/group/agileprojectmanagement/. year (see www.XP2006.org). Another example
Agile methodologies also emphasize on light is the Agile Development Conference also held
documentation. This concept has been quite once per year in the USA (see www. agiledevel-
controversial since agile methodologies started. opmentconference.com).
The main reason for the controversy is that the As agile processes begin to enter grounds such
traditional methodologies have always associated as enterprise architecture, patterns, and software
documentation with proper planning, software reuse, their software process jacket is getting
quality assurance, deployment, user training, heavier and heavier and if this is not watched
maintenance, etc. Agile methodologists however, by agile proponents we might have a situation
believe that documentation should be minimum sometime in the future where another software
because of the associated expenses. In agile development revolution emerges to maintain the
methodologies, the general belief is that correctly legacy of agility.
written code is sufficient for maintenance. The
Test first technique, which was originally an XP
practice and is now widely applied in other agile the future trends of AgIle
methodologies is another peculiar agile practice softwAre developMent
(though its origins may be from earlier processes).
The test first technique is a software develop- Agile methodologies are certainly moving toward
ment approach that implements software design higher levels of maturity due to a number of
through writing tests for each story before the things. The first contribution to agile maturity is
code is written. The test code then amounts to the availability of comprehensive sources of sim-
design artifacts and replaces the need for design ple descriptive and analytical information about
diagrams etc. agile methodologies. The second contribution to
agile maturity is the growth in academic research
challenges faced by Agile interest in agility, which has resulted in a lot of
development empirical data being collected and scientifically
analyzed to prove and disprove anecdotal data
This section looks at issues that are still grey areas about agile processes. The third contribution to
to agile methodologies. One of the interesting agile maturity is the massive exchange of practical
issues about agility is what is going to happen experiences amongst the different practitioners
to the issues of innovative thinking embedded involved in agile software development. The gen-
in agile development as the processes attain eral direction of the agile movement seems to be
higher and higher levels of maturity and quality towards more and more demand for the adoption
assurance. Are we going to see a situation where of agile practices by the larger organizations that
agility retires and fails to be agile? Another area have been traditionally associated with traditional
of software development that is always heavily processes. There have been reports of higher de-
debated at agile gatherings is the area of how to mands for agile consultancy and training as more
cost projects that are developed the agile way. and more organizations adopt agile development
The main difficulty is estimating the cost of an practices, Poppendieck (personal communication,
entire project based on iterations. There has been November 07, 2005) said there was more demand
some effort towards dealing with this challenge in North America, Europe, and even Japan where
especial at big agile conferences, for example his book on lean software development sold more
the extreme programming and agile processes than ten thousand copies. Another interesting


Agile Software Methods: State-of-the-Art

development by the agile alliance is their offer references


to sponsor agile research. This will certainly go
a long way in boosting the process maturity of Abrahamsson, P., Salo, O., Ronkainen, J., &
agile methodologies. Warsta, J. (2002). Agile software development
methods: Review and analysis. VVT Publications,
(478), 7-94.
conclusIon
Agile Alliance. (2001). Manifesto for agile soft-
ware development. Retrieved May 2, 2005, from
In this chapter, an overview of agile methodologies
http://www.agilemanifesto.org
was presented without going into the details of
describing each existing agile methodology. The Ambler, S. W. (2002). Agile modeling. John Wiley
focus of the chapter was to provide an informed and Sons.
review of agile methodologies that included a
Ambler, S. W. (2003). Agile database techniques:
comprehensive definition of what agility and agile
Effective strategies for the agile software devel-
quality assurance is all about. The approach to
oper (pp. 3-18). John Wiley & Sons.
the definition as presented in this chapter was to
give a theoretical definition, which is the perspec- Ambler, S. (2005). Quality in an agile world.
tive of those who are philosophical about agile Software Quality Professional, 7(4), 34-40.
methodologies, a practical definition, which is the
perspective of those who are on the development Avison, D. E., & Fitzgerald, G. (2003). Information
work floors, and a contextual definition, which is systems development: Methodologies techniques
a perspective based on the different contexts of and tools. McGraw-Hill.
the activities of the software development process. Bass, L. (2006, January). Designing software
In order to enhance understanding of the agile architecture to achieve quality attribute
processes, an analysis model was presented. The requirements. Proceedings of the 3rd IFIP Summer
philosophy of this technique is to cut deep into School on Software Technology and Engineering
each given agile methodology and reveal the core (pp. 1-29). South Africa.
values, principles, and practices of the methodol-
ogy so as to compare the common activities among Beck, K. (1999). Extreme programming ex-
different agile processes. The aim of doing such plained: Embrace change (pp. 10-70). Reading,
an analysis is to provide a technique for striking MA: Addison-Wesley.
the balance between these two extremes: “getting Beck, K., & Andres, C. (2004). Extreme program-
lost in the agile methodology jungle and holding ming explained: Embrace change. Addison-Wes-
onto one methodology.” The benefit of using this ley Professional.
analysis method is the attainment of a deeper
understanding of all the agile methodologies Boehm, B., & Turner, R. (2004). Balancing agility
analyzed. This should lay the ground for train- and discipline: A guide for the perplexed (1st ed.,
ing and adoption of agile methodologies from a pp. 165-194, Appendix A). Addison-Wesley.
generic point of view rather than worrying about Brandt, I. (1983). A comparative study of infor-
individual agile methodologies. mation systems development methodologies,
Proceedings of the IFIP WG8.1 Working Confer-
ence on Feature Analysis of Information Systems
Design Methodologies. In T. W. Olle, H. G. Sol,

0
Agile Software Methods: State-of-the-Art

& C. J. Tully (Eds.), Information systems design Huo, M., Verner, J., Zhu, L., & Babar, M. A.
methodologies: A feature analysis (pp. 9-36). (2004). Software quality and agile methods.
Amsterdam: Elsevier. Proceedings of the 28th Annual International
Computer Software and Applications Conference
Cockburn, A. (2000). Selecting a project’s meth-
(COMPSAC04). IEEE Computer.
odology. IEEE Software, 64-71.
IEEE. (1990). IEEE standard glossary of software
Cohen, D., Lindvall, M., & Costa, P. (2003). Agile
engineering terminology. IEEE Std 610.12.
software development (pp. 11-52). Fraunhofer
Center for Experimental Software Engineering, Juran, J. M., & Gryna, F. M. (1988). Juran’s qual-
Maryland, DACS SOAR 11 Draft Version. ity control handbook. Mcgraw-Hill.
Collins-Cope, M. (2002). Planning to be agile? Lindvall, M., Basili, V. R., Boehm, B., Costa, P.,
A discussion of how to plan agile, iterative, and Dangle, K., Shull, F., Tesoriero, R., Williams, L.,
incremental developments. Ratio Technical Li- & Zelkowitz, M. V. (2002). Empirical findings in
brary White paper. Retrieved January 20 from agile methods. Proceedings of Extreme Program-
http://www.ration.co.uk/whitepaper_12.pdf ming and agile Methods: XP/agile Universe (pp.
197-207).
Fowler, M. (2000). Put your process on a diet.
Software Development, 8(12), 32-36. Marick, B. (2001). Agile methods and agile test-
ing. STQE Magazine, 3(5).
Fowler, M. (2002). The agile manifesto: Where it
came from and where it may go. Martin Fowler McBreen, P. (2003). Quality assurance and testing
article. Retrieved January 26, 2006, from http:// in agile projects. McBreen Consulting. Retrieved
martinfowler.com/articles/agileStory.html January 12, 2006, from http://www.mcbreen.
ab.ca/talks/CAMUG.pdf
Glass, R. L., & Vessey, I. (1995). Contemporary
application domain taxonomies. IEEE Software, Meyer, B. (2000). Object-oriented software
63-76. construction (pp. 4-20). Prentice Hall PTR.
Hendrickson, E. (2004). Redefining quality, Mnkandla, E., & Dwolatzky, B. (2004a). Balanc-
Retrieved January 12, 2006, from http://www. ing the human and the engineering factors in
stickyminds.com/sitewide.asp?Function=edetai software development. Proceedings of the IEEE
l&ObjectType=COL&ObjectId=7109 AFRICON 2004 Conference (pp. 1207-1210).
Highsmith, J. (2001). The great methodologies Mnkandla, E., & Dwolatzky, B. (2004b). A sur-
debate: Part 1: Today, a new debate rages: Agile vey of agile methodologies. Transactions of the
software development vs. rigours software devel- South Africa Institute of Electrical Engineers,
opment. Cutter IT Journal, 14(12), 2-4. 95(4), 236-247.
Highsmith, J. (2002a). Agile software develop- Mnkandla, E. (2006). A selection framework for
ment: Why it is hot! (pp. 1-22). Cutter Consortium agile methodology practices: A family of meth-
white paper, Information Architects. odologies approach. PhD thesis, University of
the Witwatersrand, Johanneburg.
Highsmith, J. (2002b). Agile software development
ecosystems (pp. 1-50). Addison-Wesley. Pfleeger, S. L. (2001). Software engineering:
Theory and practice. Prentice Hall.
Highsmith, J. (2004). Agile project management.
Addison-Wesley.


Agile Software Methods: State-of-the-Art

Poppendeick, M., & Poppendeick, T. (2003). considerations. Proceedings of the IFIP WG8.1
Lean software development: An agile toolkit for Working Conference on Feature Analysis of Infor-
software development managers (pp. xxi-xxviii). mation Systems Design Methodologies. In T. W.
Addison Wesley. Olle, H. G. Sol, & C. J. Tully (Eds.), Information
systems design methodologies: A feature analysis
Pressman, R. S. (2001). Software engineering a
(pp. 1-7). Amsterdam: Elsevier.
practitioner’s approach. McGraw-Hill.
Sommerville, I. (2004). Software engineering.
QCI International. (2002). Juran: A life of qual-
Addison-Wesley.
ity: An exclusive interview with a quality legend.
Quality Digest Magazine. Retrieved January 12, Turk, D., France, R., & Rumpe, B. (2002).
2006, from http://www.qualitydigest.com/aug02/ Limitations of agile software processes. Proceed-
articles/01_article.shtml ings of the Third International Conference on
eXtreme Programming and Agile Processes in
Schuh, P. (2004). Integrating agile development
Software Engineering (pp. 43-46).
in the real world (pp. 1-6). MA: Charles River
Media. van Vliet, H. (2003). Software engineering: Prin-
ciples and practice. John Wiley & Sons.
Schwaber, K., & Beedle, M. (2002). Agile soft-
ware development with SCRUM (pp. 23-30). Weinberg, G. M. (1991). Quality software manage-
Prentice-Hall. ment (Vol. 1), Systems Thinking. Dorset House.
Schwaber, K. (2004). Agile project management Weisert, C. (2002). The #1 serious flaw in extreme
with Scrum. Microsoft Press. programming (XP). Information Disciplines,
Inc., Chicago. Retrieved January 2006, from
Sol, H. G. (1983). A feature analysis of information
http://www.idinews.com/Xtreme1.html
systems design methodologies: Methodological


23

Chapter II
Agile Quality or Depth
of Reasoning?
Applicability vs. Suitability with
Respect to Stakeholders’ Needs

Eleni Berki
University of Tampere, Finland

Kerstin Siakas
Alexander Technological Educational Institution of Thessaloniki, Greece

Elli Georgiadou
University of Middlesex, UK

AbstrAct

This chapter provides a basis for discussion and analysis of the quality characteristics of the agile in-
formation systems development (AISD) process, and exposes concerns raised regarding the applicability
and suitability of agile methods in different organisational and national cultures. The arguments are
derived from recent literature reviews and reports on the state-of-the-art in agile methodologies. We
also reflect on our own research and experience in three European countries with different academic
and work values, and information systems development (ISD) industrial practices based on diverse
principles. Examining the different perceptions of quality in the agile software development paradigm
by comparing and contrasting them to the quality perceptions in the established ISD methodological
paradigms, we aim at: (i) exploring the relationship of traditional, agile, managed, and measured ISD
processes, (ii) making the human dynamics that bear on the success and consensus acceptance of IS
more explicit, and (iii) establishing a critical framework/approach for reflecting on the suitability and
applicability of agile methods in the development and management of quality software systems.

Copyright © 2007, Idea Group Inc., distributing in print or electronic forms without written permission of IGI is prohibited.
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

IntroductIon most importantly, on the ways people perceive


quality and quality assurance (Berki, 2006; Ross
Agile methods have pervaded many application & Staples, 1995; Siakas, Berki, Georgiadou, &
domains of software development and many Sadler, 1997). Awareness and application of total
claim that this has occurred because agile meth- quality management principles and the influence
ods (DSDM, XP, Crystal, SCRUM, ...) advocate of human involvement and commitment are yet
end-user participation and satisfaction by focus- unresolved and largely non-researched issues in
ing on systems realisation, requirements change, different cultural (organisational and national)
and testing as the means to achieving a “correct” contexts. Therefore, specialised knowledge is
information system (Beck, 2000, 2003; Beck & required in order to assess, assure, and certify
Fowler, 2001). On the other hand, it is argued that the quality of agile software development.
the agility of these new methods might lead to It is, yet, questionable if risks and project fail-
more complex and not well-documented systems ures that are frequently encountered in traditional
and to a fragmented software development pro- software projects could be diminished or avoided
cess (Boehm & Turner, 2003a, 2003b; Marciniak, (Siakas, Georgidaou, & Berki, 2005a) by adopting
1994). Our motivation to examine these arguments an agile approach. It is, however, argued that agile
in this chapter derives from (a) scientific and (b) methods make the key business users a very strong
practical perspectives. Naturally, a fragmented, partner in assuring quality (Beck, 2000, 2003;
unpredictable, and non-measurable IS process Beck et al., 2001). We presume that in a mature
does not add to the established scientific rules that IS society, rather than completely leaving quality
must guide software development. In that respect, to the professionals, agile development projects
the use of computational principles combined with will perceive the key ISD stakeholders, and end-
lightweight methods, which support continuous users in particular, as co-responsible for ensuring
change, might be the answer for agile quality, that the application fits the purpose. At present,
particularly for software component-based de- however, one needs to compare and contrast the
velopment in a post-modern information society agile development process (agile methods and the
(Berki, Georgiadou, & Holcombe, 2004; Siakas, life cycle they support) to traditional methods.
Balstrup, Georgiadou, & Berki, 2005b). Based on the results of comparisons one could,
Considering, though, the post-technological afterwards, analyse, measure, validate, and verify
state of the global software industry, an ISD the method suitability and applicability derived
method customisation to the needs of diverse from the agile methodology deployment. From the
and different organisational and national cultures software quality assurance’s point of view, new
points rather to further argumentation for the or/and older software quality properties could be
general applicability and suitability of the agile the key attributes for constructing process and
methods paradigm. There is an obvious need for product quality principles when both traditional
further research in order to understand the require- and agile development methods are employed
ments of quality and the requirements of agile in ISD.
quality in particular, within different cultural and Throughout this chapter, we proceed to a three
social contexts and, perhaps, the need to identify axis quality examination of the agile methodology
controllable and uncontrollable quality factors for paradigm, outlined as follows: The chapter firstly
agile ISD (Georgiadou, Siakas, & Berki, 2003). considers a historical perspective and a discussion
IS quality requires knowledge of different or- over process and product quality measurements in
ganisational and national cultures on the methods traditional software development (method and life
and tools used, on the ways they are used and, cycle models). In order to provide an overview of

24
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

the European perspective on the software process issues for re-factoring), could better be facilitated
and software product quality measurements, we with the adoption of metamodelling and method
present supportive data drawn from case studies engineering rules in MetaCASE and Computer
and questionnaires in recent cultural factors- aided method engineering (CAME) environments
oriented research that was carried out in four (4) (Berki, Lyytinen, Georgiadou, & Holcombe, 2002;
European countries, namely Finland, Denmark, Kelly et al., 1996; Tolvanen, 1998).
the UK, and Greece (Siakas, 2002; Siakas, Berki,
& Georgiadou, 2003). We subsequently comment
on recent research findings regarding software A HIstorIcAL PErsPEctIVE For
process and product measurements kept during soFtWArE ProcEss And
traditional ISD. There are, of course, many con- Product QuALItY IMProVEMEnt
trollable and uncontrollable factors in measuring
ISD. Considering the latter, we attempt to identify Long before the agile paradigm, in fact since
and deduce suitable process and product metrics/ 1968, software engineers have tried to emulate
metametrics for an agile ISD approach. traditional engineering in order to address quality
Following from the latter and considering problems and IS failures with varying degrees of
that there are controllable and uncontrollable fac- success (Georgiadou, 2003b; Sommerville, 2001).
tors that influence any ISD process, the second A significant source of experience was gained
axis of the chapter’s discussion considers soft from quality assurance processes practised in
(uncontrollable and probably non-measurable) the manufacturing industry, such as statistical
issues of agile ISD. This analysis elaborates on process control (SPC) (Burr & Georgiadou,
stakeholders’ participation, change management, 1995). The emphasis has been gradually shifted
cultural and national differences, and knowl- from software product improvement to software
edge creation and sharing. These are significant process improvement, where information systems
managerial issues and in today’s agile and lean development methods (ISDMs) have long been
management development approaches are often employed to manage the software process.
considered to be the cornerstones for productivity,
interactivity, communication, and trust in ISD Quality trends in Information
teams (Berki, Isomäki, Jäkälä, 2003; Manninen systems development
& Berki, 2004).
Finally, we examine the hard issues and quality In the ’80s and ’90s emphasis was put on software
properties (rather controllable and measurable process improvement (SPI) with the appearance of
factors) that agile methods openly claim they quality standards and guidelines, such as ISO9001
achieve, these being implementability, modifi- (ISO, 2005), capability maturity model integrated
ability, and testability. Investigating the influ- (CMM/CMMI) (Paulk et al., 1993), software
ence of method engineering (ME) in the agile process improvement (SPI), SPICE / ISO-15504
paradigm, two, rather contradictory, observations (Dorling, 1993), and Bootstrap (Kuvaja, 1999).
are analysed: (i) Agile methodology tool support More recently the Kaizen method of incremental
identifies method expressability and stakeholder improvements (Vitalo, Butz, & Vitalo, 2003), six
communication to be problems that appear fre- sigma (George, 2003), lean manufacturing (Pop-
quently in both traditional and agile development pendieck & Poppendieck, 2003), and product life
methods, while (ii) continuous change of require- cycle management (PLM) (Grieves, 2005; Saa-
ments (modifiability), and possibly quality of ksvuori & Immonen, 2003) have been adopted
re-engineering and reverse engineering (central by practitioners. This signifies the recognition of

25
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

the fact that life cycle costs are front-loaded (i.e., methods over the last 40 years. Acronyms can be
more effort, time, and costs are required at the found in Appendix A.
beginning of the life cycle). Agile development Agile software development methods fall
advocates that it is not necessary to make all within the hybrid, thus a combination of hard and
the design decisions up front. Instead, the agile soft, paradigm (Berki, 2006). Extreme program-
process and its products are constantly being ming (XP) for example builds on principles first
improved because the developers engage in per- used by Checkland (1981) and Mumford (1983)
petual value development through brainstorming, in SSM and ETHICS methodologies respectively
flexible thinking and continuously maturing and and later on by the dynamic systems development
improved commitment and decision-making. method (DSDM) (Stapleton, 1997). In particular,
the agile paradigm was built on a foundation which
Proliferation of Methods in the encapsulates user participation, time boxing, (the
software development Life cycle amount of features released in a fixed amount of
time), and frequent delivery of product.
During the last 40 years, several ISDMs have been By applying one of the available methodolo-
established (Figure 1) that have been characterised gies to the development of software, insights were
as hard (technically oriented), soft (human-cen- gained into the problems under consideration and,
tered), hybrid (a combination of hard and soft), thus, software product and process quality could
and specialised (application-oriented) (Avison & be addressed more systematically (Berki et al.,
Fitzgerald, 2003; Berki et al., 2004; Georgiadou 2002). The final software-based IS should, nor-
& Milankovic-Atkinson, 1995). Hard methodolo- mally and traditionally, comply with the quality
gies span the range of structured, object-oriented, requirements of timeliness, relevance, accuracy,
and formal methods. Soft methodologies are and cost effectiveness.
exemplified by the soft systems method (SSM)
(Checkland, 1981; Checkland & Scholes, 1990) From traditional Isd to Agile Isd:
and effective technical and human interaction user Involvement and Problem
for computer-based systems (ETHICS) (Mum- solving
ford, 1983, 2003). Figure 1 provides a historical
overview of the approximate year of introduction The application of solely hard or soft methods
of the main exponents of prescriptive and agile led to IS with problematic functionality and

Figure 1. Forty years of information systems development methodologies


Information Enginering

eXtreme Programming
Lean Development

Coad-Yourdon
Multiview
STRADIS

ETHICS

SCRUM

Crtystal
SSADM

Yordon
Ad-hoc

DSDM
OMT
NCC

CBD
SSM

FDD
ASD
JSD

AM
ISD

?
Z

1965 1970 1975 1980 1985 1990 1995 2000 2005 2010

26
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

stakeholder dissatisfaction. Inevitably IS were of generating many alternative solutions to a


also constructed with specialised (application- problem in a continuous interaction, trade-offs
oriented) methods with no stakeholder satisfac- and “accommodations” throughout the process
tion solutions or compliance to the most recent (Georgiadou et al., 1995).
academic knowledge and related scientific reason- Moreover, the level of user participation is
ing. The appearance of hybrid methods, such as inherent in each methodology. In fact, we argue
multiview (Avison & Wood Harper, 1990), indi- that a methodology is as strong as the user involve-
cated the need to integrate soft and hard issues. ment it supports (Berki, Georgiadou, & Siakas,
Hybrid methods concentrated on hard issues, such 1997). Traditional participative methodologies
as implementability (Holcombe & Ipate, 1998), (see SSM and ETHICS) place a strong emphasis
structuredness (Avison et al., 2003), and test- on managerial and social issues and, usually,
ability (Berki, 2004) and on soft issues, such as devote extra time and effort during the early
user participation (Mumford, 1983, 2003), conflict stages of the systems life cycle. This moulds the
analysis (Checkland et al., 1990), and stakeholder development process and the type of the solution(s)
communication (Berki et al., 2003). Emphasis on achieved, also dependent on the lifecycle model.
testing at many stages (including acceptance test- For instance, waterfall model emphasis, step-
ing) was practised using the V and W life cycle wise refinement, and problem reduction, while
models (Burr et al., 1995). prototyping approach denotes an evolutionary
Traditional IS development had some user and sometimes state transition approach. User
involvement, usually at the two ends of the devel- involvement is mainly through discussions with
opment process, namely the feasibility study phase the developers and participation in walkthroughs,
and the system acceptance phase; without, though, reviews, and inspections. Larman (2004) argues
widely employing formal testing techniques (such that lessons learned from prototyping and iterative
as acceptance testing). The prototyping approach development as well as cyclic models, such as the
signalled the need for ongoing user participation. spiral model, paved the way for the evolution of
The dynamic interaction of the two constituencies, the agile paradigm.
namely the users and the developers, is represented Comparing the early aims of software en-
in Figure 2, which emphasises the possibility gineering as a discipline to handle the unfore-

Figure 2. The components in the development process: The “balanced” interaction—prototyping

problem developer

models
structures
M
e technical knowhow
t
h
o
d o
worries l
conflicts o efficiency
g s
additional requirements y n
o
i
business knowhow ut
ol
s
user usability solution

27
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

seen software crisis of the 60s by a disciplined 1994). Despite these efforts, systems continue
method(ology) to the aims of the Agile Manifesto to fail with dramatic frequency (Dalcher et al.,
(2001), one could conclude that there is, now, a 2003). Systems development methodologies have
new software engineering challenge. Attributing been proposed and used to address the problems
though the appearance of the agile methods to a of ambiguous user requirements, non-ambitious
traditional method(ology) crisis (Berki, 2006) systems design, unmet deadlines, exceeded
might lead to a deeper understanding of the budgets, poor quality software with numerous
reasons that agile methods have been accepted, “bugs” and poor documentation. These and other
discussed, and/or criticised in equal measures. factors made IS inflexible to future changes and
Notwithstanding, traditional ISDMs have retained difficult to maintain.
a role as quality assurance instruments for the
software development process, and there has Quality and software Process
been substantial evidence in theory and practice Improvement
for living up to such expectations (Avison et al.,
1990; Boehm & Turner, 2003a, 2003b Jayaratna, Software process improvement (SPI) has become
1994). a practical tool for companies where the quality of
the software is of high value (Järvinen, 1994). In
a technical report with results from 13 organisa-
ProcEss And Product tions, and with the number of post-release defect
QuALItY MEtrIcs In reports used as a measure, Herbsleb, Carleton,
trAdItIonAL And AGILE Rozum, Siegel, and Zubrow (1994) showed that
soFtWArE dEVELoPMEnt due to software process improvement (SPI), the
products and business value (especially return on
Failure and success of IT/IS projects have been investment – ROI) was improved. It is generally
discussed since the early 70s when organisations considered that a well documented and a repeat-
started to use computer technology to harness the able process is essential for developing software
ability of their information systems (Lyytinen products of high quality. There is also evidence
& Hirschheim, 1987). IT project failures have that the use of standards and process assessment
been widely reported and studied (Dalcher & models has a positive impact on the quality of the
Genus, 2003; Heeks, 2002; Moussa & Schware, final software product (Kitchenham & Pfleeger,
1992). Failures range from total malfunction to 1996).
abandonment, rejection, and non-use. Statistics The software engineering community has
presented in Johnson and Foote (1988) revealed gradually moved from product quality-centred
that five out of six software projects were consid- corrective methods to process quality-centred,
ered unsuccessful, and approximately a third of preventive methods, thus shifting the emphasis
software projects were cancelled. The remaining from product quality improvement to process
projects delivered software at almost double the quality improvement. Inspections at the end of
expected budget and time to develop than origi- the production line have long been replaced by
nally planned. design walkthroughs and built-in quality assur-
Considerable advances have also been achieved ance techniques throughout the development
by the introduction of methods and tools for the life cycle (Georgiadou et al., 2003). Quality is
systematic planning and control of the develop- an elusive, complex concept (Berki et al., 2004)
ment process (Avison et al., 2003; Berki, 2001; and software quality depends on the opinions and
Georgiadou, 2003b; Jackson, 1994; Jayaratna, attitudes of the stakeholders, who are concerned

28
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

Table 1. Values in traditional SPI and in agile paradigms


SPI Agile
Processes and tools Individuals and interactions
Comprehensive documentation Workable software
Contract negotiation Customer collaboration
Change through following a plan Change through fast response

Table 2. Quality factors in the basic principles and values of SPI and agile paradigms

Quality factors SPI Agile


Philosophy Empowerment Innovative, participative, em-
powerment
Lifestyle Work-orientated Life-orientated
Approach Plan driven and Flexible
prescriptive processes Evolutionary, adaptive, itera-
Process driven--rigid--bureau- tive, incremental
cratic
Driving forces Management commitment and Technically competent and
leadership (Deming, 1986) motivated developers
Customer involvement Early and late stages in life Throughout life cycle
cycle
Customer participation Encouraged—Customer Focus Imperative user participation
Communication Formal Informal
Teams Inter-group coordination Self-organising teams
(Humphrey, 1995; Deming,
1986)
Responsiveness Bureaucratic delays Quick responses
Knowledge creation Tacit, Formal, Explicit Tacit, Informal, Explicit
Knowledge sharing Desirable, Formal Imperative, Informal
Documentation Maximum Minimum
Changing requirements Processes have to be followed Adaptability to changes
throughout the development
process (Berki, 2001; 2004)
Testing Late in life cycle Test first (Holcombe, 2005)
Error detection Inspection (Gilb & Graham) Pair programming (XP) (Beck,
2001; 2003)
Progress reviews Formal peer reviews (CMMI) Continuous peer reviews
Requirements elicitation Planned and infrequent Daily stand-up meeting
Tool support Tools supporting different Automated testing tools—Inte-
phases of the life cycle—frag- grated CASE (I-CASE)
mented
Delivery of product Planned Frequent—loose plan
QA function Formalised—Separated Informal—Embedded

29
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

with different quality attributes (Siakas & Geor- software (and their interconnected nature) need
giadou, 2005; Siakas et al., 1997). Quality is in to be identified and controlled (Georgiadou et
the eye of the stakeholder! al., 2003) to ensure predictable and measurable
Evidence for the emphasis on process quality is totality of features and quality characteristics of
also that ISO certification does not certify product the particular software.
quality but takes into consideration that a stated There is significant evidence that culture
and documented process is followed. Similarly, influences on how people perceive quality and
well-known and recognised assessment models quality assurance (Berki, 2006; Ross et al., 1995;
like CMM / CMMI (CMM, 2005; Paulk, 1993, Siakas et al., 1997), and that there are differences
1995; Paulk, Curtis, & Chrissis, 1993), BOOT- amongst IS professionals from different nations
STRAP (Haase, 1992; Haase & Messnarz, 1994; (Couger & Adelsberger, 1988; Couger, Borovitz,
Kuvaja, Similä, Kranik, Bicego, & Saukkonen, & Zviran, 1989; Couger, Halttunen, & Lyytinen,
1994), and SPICE / ISO15504 (Dorling, 1993) con- 1991; Holmes, 1995; Ives & Järvenpää, 1991; Keen,
centrate on the assessment of the process quality 1992; Kumar & Bjorn-Andersen, 1990; Palvia,
and not on the quality of the final product. Palvia, & Zigli, 1992, Siakas, 2002). Revisiting
Critically reflecting and summarising on the this chapter’s main research question: Does the
values and principles of traditional software much praised applicability of agile methods fit
process improvement (SPI) and agile paradigms, different organisational and national cultures
Tables 1 and 2 provide a comparative review on and human needs in a world of turbulent quality
the trends and shifts that the two approaches are perspectives under the globalisation of software
based on. Firstly, Table 1 outlines the values of development? The following section considers
SPI and agile approaches. Table 2 continues to this question in the context of measurement and
expose the quality factors and the special features/ other factors.
principles through which quality is encapsulated
for the software development process, and/or is
built in for the software product, being that a WHAt to MEAsurE And HoW
workable prototype—a frequent release or the to IMProVE QuALItY In AGILE
final product itself. soFtWArE dEVELoPMEnt?

It has long been recognised that measures provide


AGILE MEtHod(oLoGY): A nEW insights into the strengths and weaknesses of both
trEnd WItH LIttLE QuALItY process and product. To measure is to know. If you
AssurAncE or InHErEnt cannot measure it, you cannot improve it (Wil-
QuALItY FActors? liam Thomson, later Lord Kelvin (1824-1907);
DeMarco, 1982). Hence, the “why to measure”
Apart from the quality properties of imple- is understood and accepted, but the decision on
mentability, changeability, and testability, agile “what to measure,” “how to measure,” “when to
methods have re-introduced a stakeholder—or measure,” and, in particular, “who measures” and
user—centred approach relating to requirements “for whom” becomes crucial if benefits are to
conformance, concentrating on the software/in- be gained by particular groups (Berki, 2001). In
formation products’ frequently released versions turn, we need to understand which stakeholders
in order to ensure competitive advantage, end-user and why they will benefit from measurements
acceptance, and general stakeholder satisfac- and improvements, and in the long run, who is
tion. Factors, though, that affect the quality of the most suitable to measure and bring about

30
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

reforms, changes, and improvements in the External attributes (Fenton, 1991; Hennell,
software products and processes. The following 1991; Georgiadou, 1994) such as understand-
two sections take a closer look at the role of mea- ability and maintainability are behavioural, and
surement and estimation in traditional software their associated metrics are both qualitative and
development while the two sections after them quantitative. They are always obtained indirectly
intend to introduce the concepts and attributes through the use of surrogate measures. In gen-
of measurement and estimation, regarding pro- eral, product measurement affords us with direct
cess and product quality improvement, in agile metrics (in terms of counts such as NLOC and
software development. ratios such as density of calls), whereas process
measurement invariably takes the indirect route
the role of software Measurement of surrogacy and use of indicators and indices
in software Quality Assurance (Georgiadou, 1994, 2001; Kitchenham, 1996).
In the light of the previous and examining the
Hennel (1988) and Fenton (1991) believe that inter- relevant direct, indirect and surrogate measures
nal attributes are the key to improving software that are kept or/and could be kept in agile paradigm
quality and can be measured in terms of the code. methodologies, Table 3 characterises the nature
Many traditional software engineering methods of these measurements.
provide rules, tools, and heuristics for producing
software products. They show how to provide the role of cost Estimation Models
structure in both the development process and in traditional Isd
the products themselves such as documents and
code. These products have properties (internal In traditional software development, cost esti-
attributes) such as modularity, re-use, coupling, mation models such as the original COCOMO
cohesiveness, redundancy, D-structuredness, (COnstructive COst MOdel) (Boehm, 1981) and
and hierarchy. They aim to assure reliability, subsequent versions (COCOMO Web site, 2006)
maintainability, and usability for users, and also aimed at estimating the cost, effort, and schedule
assure high productivity and cost-effectiveness when planning new development activities, ac-
for managers/sponsors. cording to software development practices that
were commonly used in the 1970s through the

Table 3. Measurement in agile software development

Agile Measures: Direct/Indirect/Surrogate


User satisfaction Surrogate
Changing requirements Direct
Frequent delivery of working software Direct
User participation Indirect
Developer motivation and trust Indirect/Surrogate
Efficiency through face-to-face conversation Indirect
Working software—the primary measure of progress Indirect
Sustainable development Surrogate
Continuous attention to technical excellence and good Indirect
design enhances agility
Simplicity (delivery of essentials functionalities) Surrogate
Self-organising teams Surrogate
Regular reflection and tuning of teams behaviour Indirect

31
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

1980s. COCOMO and its variations link inter- project cycles. However, rigorous and flexible
nal and external attributes (see earlier section) agile metrication procedures could be difficult to
providing rough estimates of software costs. establish for the requirements of agile software
Accuracy is necessarily limited because of the development. Evidentially there is no concrete,
difficulty to account for differences in hardware established scientific procedure to do so and,
constraints, personnel quality and experience, use furthermore, neither vast industrial nor academic
of different tools and techniques, and other project substantial proof for keeping quantifiable mea-
attributes that may have a significant influence sures in agile software development projects.
on cost. Effort-predicting metrics must inevitably Some agile metrics, for instance, have been
be available fairly early on in the development reported and used by a research team in the Israeli
life cycle if management teams are expected to army. The reported results support the stated
commit expenditure and plan the timing of deliv- goal, that is to “enable an accurate and profes-
ery. In addition, Beizer (1990) observed that it is sional decision-making process for both short- and
important to be aware of the purpose of a metric; long-term purposes” (Dubinsky, Talby, Hassan,
moreover, confusing an effort-predicting metric & Keren, 2006).
with a defect-predicting metric can nullify the On the other hand, agile metrics are not them-
metric’s usefulness. selves very different from traditional metrics (see
also Table 3). The difference in “agility” probably
Product or Process Quality refers to the method and speed of collection. Since,
Measurements in Agile software though, agile methods advocate lean documenta-
development? tion and frequent delivery of product, agility in
estimation and continuous adjustment is necessary
Could flexible agile quality metrics exist for so that projects are delivered on time and within
the agile software development process and its budget. In order for this iterative process to suc-
deliverables? The agility here refers to the ability ceed, we must assume the practice of a mature
to continuously modify both cost and effort using process within the organisation.
parameters such as function points and lines of code. At capability maturity model (CMM) level
For instance, a recent variation of COCOMO and 5—the optimising level—quantitative feedback
associated Web-based tools is the Agile COCOMO data drawn from the process allows continuous
II, which facilitates cost estimation and enables process improvement. At this maturity level
adjustments to “estimates by analogy through (Humphrey, 1995; Zahran, 1998), data gather-
identifying the factors that will be changing and by ing must be automated and the emphasis should
how much” (Agile COCOMO Web site, 2006). be shifted from product maintenance to process
Gilb (2006) suggests that the agile methods analysis and improvement. Managing the agile
paradigm would benefit, if it included “stakeholder development process, and any process, requires
metrics” for focusing on critical requirements, the collection of suitable metrics, which will
measuring progress, and enabling response to provide holistic insights into the strengths and
feedback. In suggesting so, Gilb (2006) asserts weaknesses of the process, assuring general
the need for agile development to focus on the stakeholder satisfaction.
most critical stakeholder quantified and measur-
able requirements and the need to keep track of
changes and plans for better progress in shorter

32
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

Figure 3. The evolution of the life cycle model maturity (Georgiadou, 2003b)

V-model X-model
Waterfall Prototyping W-model OO-models ??
1970 1975 1980 1985 1990 1995 2000

Waterfall RAD
NCC
with Client-server
Feedback

CMM

1 2 3 4 5
ad hoc repeatable defined managed optimised

Process Assessment Scale

tEstInG, IMProVEMEnt, And satisfaction. There are even approaches with stake-
rE-EnGInEErInG FActors In holder requirements testing before development,
trAdItIonAL And In AGILE LIFE hence, the maturity of the software development
cYcLE ProcEssEs process continuously raises with the awareness
and advanced practices of testing!
Efforts to model the process gave us numerous Nevertheless, cyclic development models,
life cycle models, ISD methodologies, quality incremental prototyping (Pressman, 2000; Shep-
models, and process maturity models (Berki et al., perd, 1995), and rapid application development
2002). A study of different life cycle models was (RAD) (Bell & Wood-Harper, 1992) offered
carried out (Georgiadou, 2003b; Georgiadou et al., mechanisms for monitoring, timing, and qual-
1995) with particular emphasis on the position of ity of deliverables. Prototyping maximizes the
testing in the whole of the life cycle. The study probability of achieving completeness because
so far recognised that more mature life cycles, of the principle of delivering workable versions
and hence more mature software engineering upon user acceptance. The need for continuous
processes, moved testing and other quality as- improvement was widely recognized, and is
surance techniques to the earliest stages of the encapsulated by the concept of Kaizen (“Kai”
development life cycle. meaning school and “Zen” meaning wisdom),
A juxtaposition of a historical introduction of which is a Japanese word meaning “many small
the models to the CMM scale (Figure 3) demon- improvements” (Imai, 1986).
strates that between 1970 and 2000, as we moved According to Beck (2000, 2001), traditional
from the waterfall model (which appeared as early lifecycle models are inadequate and should be
as in 1956) to incremental models, the maturity replaced by incremental design and rapid pro-
of the underlying process was increasing. In the totyping, using one model from concept to code
case of agile development methods, the testing through analysis, design, and implementation. In
activities are frequent and central for stakeholder other words, design starts while still analysing

33
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

and coding starts soon after starting the detailed Legacy code accounts for more than 80% of
design. Portions of the design are tested along with the total effort in the whole of the community
implementation. Extreme programming (XP), (Polymenakou, 1995). The extent to which the in-
for instance, is one of the agile or lightweight dustry is still using 30 or even 40-year-old systems
methodologies to denote a breakaway from too became all too apparent with the Millennium bug,
many rules and practices. which was an unintended consequence of much
The XP approach is considered successful earlier design decisions and testing limitations.
since it stresses customer satisfaction upon de- Maintenance of existing code requires under-
sign, testing, implementation, subsequent and standing of the requirements and the behaviour
on-going customer participation, and feedback. of the system as well as of new technologies,
The particular methodology was designed to such as new database management systems,
deliver the software a customer needs when it is new programming languages, new methods, and
needed. XP (and most other agile methods) em- tools that cater for change and re-use. Legacy
power developers to confidently respond to and code may need drastic restructuring, and often
test changing customer requirements, even late reverse engineering due to inadequate or absent
in the life cycle (Beck, 2002; Holcombe, 2005). documentation to facilitate re-engineering.
Acceptance of changes also empowers the custom-
ers and end-users, but do additional requirements The Four Rs: Re-Engineering,
violate the requirements specification and do Re-Structuring, Re-Use, Re-Factoring
they invalidate carefully tested and documented
requirements within previous modelling efforts? When considering software development we
Unless, of course, the continuous re-structuring generally think of a natural process starting from
and re-engineering of requirements specification the concept, going through the specification,
empowers reverse engineering and re-factoring. design, implementation, and delivery of product
Refactoring, an agile concept and different from (going live) which in turn reaches obsolescence.
rearranging code activity, whereupon the strength This process (modelled by different life cycles)
of testing lies therein, perhaps indicates that is known as forward engineering. In contrast,
frequent requirements change doesn’t preclude reverse engineering starts from a product and
changing functionality. The following sections in reverse order generates specifications (Press-
take a closer look to re-engineering, restructuring, man, 2000). Legacy code without accompanying
reverse engineering and refactoring with reference documentation (or with documentation, which has
to the agile development paradigm. long ceased to keep in step with modifications) is
often a serious problem. The dilemma is whether
software design Quality Factors to reverse-engineer or to embark onto develop-
ment from scratch. Cost and time constraints
We are interested in both internal and external play a significant part in the resolution of this
quality attributes because the reliability of a pro- dilemma.
gram is dependent not just on the program itself, A more frequent activity is the re-engineering
but on the compiler, machine, and user. Also, or restructuring of code for the purpose of improv-
productivity is dependent on people and project ing its performance and/or as a result of changing
management. It is often necessary to use surrogate requirements and hence, sometimes, changing
measures for complex external attributes (Fenton functionality. Here, we need to at least ensure the
& Pfleeger, 1997; Kitchenham, 1996). preservation of the existing functionality (unless

34
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

parts of it are not required) and to also enhance The key insight is that it is easier to rearrange
problematic areas and add new functionality as the code correctly if you do not simultaneously
required. Re-engineering of existing code needs try to change its functionality. The secondary
to be planned and managed according to speci- insight is that it is easier to change functional-
fied rules of acceptance thresholds and tolerance. ity when you have clean (re-factored) code. The
Again, the costs of reengineering may be just expectation is that re-factored code will be more
as high if not higher than the costs for forward maintainable, which in turn, will result in ef-
engineering (developing from scratch). ficiency and cost savings. The cyclic nature of
Reuse has long been advocated as the key to re-factoring also improves understanding in the
productivity improvement. Fenton (1991) speci- development team, and ensures the reuse of tried
fies private reuse as the extent to which modules and tested code. Re-factoring, therefore, improves
within a product are reused within the same the overall quality of software.
product whilst public reuse is the proportion of Notwithstanding, agile methods have, to-date,
a product, which was constructed (Fenton, 1991). failed to propose measures for process or product
The problem with reuse is whether a system is improvement. Additionally, one can envisage cost
reusable. Often it is necessary to restructure over-runs, which can neither be predicted nor con-
existing code before reuse can be made possible. trolled. The re-engineering metrics developed by
Funding a reuse program can be expensive, and it Georgiadou (1994, 1995, 1999) provide indicators
is difficult to quantify the cost reductions expected as to whether legacy code can be restructured or
from reuse (Sommerville, 2001). It is desirable that developed from scratch. Re-factoring is in effect
components (modules) should be highly cohesive a re-engineering activity. If we hope to control the
and loosely coupled with other components. The costs and time of delivery, benefits could be gained
authorised re-user of the components must have from adopting metrics such as the re-engineering
confidence in that the components will behave as factor rho (ρ) (Georgiadou, 1995) and the associated
specified and will be reliable. The components productivity gains in agile development.
must have associated documentation to help the
re-user understand them and adapt them to a new
application. In recent years, much promise came non-MEAsurAbLE And
from the OO paradigm and component-based uncontroLLAbLE QuALItY
development (CBD). FActors In AGILE soFtWArE
Agile methodologies, and XP in particular, dEVELoPMEnt
introduced the concept of re-factoring as a process
of “changing a software system in such a way that In knowledge intensive organisations, strategic
it does not alter the external behaviour of the code decisions should be based on the development
yet improves its internal structure” (Fowler, 1999). and improvement of their own resources (Conner
Fowler advocates that re-factoring is typically & Prahalad, 1996). This also means development
carried out in small steps. After each step, you of a flexible organisational culture, which can
are left with a working system that is functionally quickly respond to various business situations
unchanged. Practitioners typically interleave bug (Rantapuska, Siakas, Sadler, & Mohamed, 1999).
fixes and feature additions between these steps. One of the basic features in agile methodologies
In so doing, re-factoring does not preclude chang- is to embrace changing requirements with a quick
ing functionality; it supports that it is a different, response. No detailed plans are made. Instead,
from re-arranging code, activity. changing requirements is considered a necessity

35
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

to sustain and improve the customers’ competi- vestigation) in four counties, namely Denmark,
tive advantage. Finland, Greece, and the UK, cultural differences
The previous meta-requirements of ag- in software development and their influence on
ile software development can be critical and software quality were investigated (Georgiadou
uncontrollable quality factors while develop- et al., 2003; Siakas, 2002; Siakas et al., 2003;
ing human-centred software for technological Siakas & Balstrup, 2000; Siakas & Georgiadou,
products and organisational, societal, personal, 2002). The questionnaire was sent to organisations
and interpersonal information systems (see e.g., developing software for own use or for sale, and
Koskinen, Liimatainen, Berki, & Jäkälä, 2005). normally kept formal measures of software qual-
When designing huma-centered systems require- ity. In total, 307 questionnaires were completed.
ments flexibility as well as the debate between In addition, field-studies were undertaken in
changeability vs. stability of the object domain of several organisations. In total, 87 interviews were
software are central questions for quality consid- conducted in Finland, Denmark, and Greece with
ering different stakeholders intersts and values. software developers at different levels and with
The following section briefly refers to the research different positions in the organisations. Following
findings on recent quality measurements made the initial verification phase, observations were
for software development process in European carried out in a Danish organisation for a period
countries and summarises the conclusions from of two months (Siakas et al., 2000). The objective
previous published work by the authors of this of using observations was to investigate in more
chapter. The three subsequent sections scrutinise depth the research problem of organisational and
the concepts of knowledge sharing, cultural fac- national culture diversity and their influence on
tors, and stakeholder participation as soft issues software quality management practices and to
and unpredictable software quality factors within verify the findings. Amongst other findings, we
the agile paradigm. proved that there are statistically significant dif-
ferences in the responses on the degree to which
current Practices and formal quality measures are kept depending on
Measurements Kept for software the country of origin. Figure 4 depicts some of
Quality: A European Perspective the research findings.
From Figure 4 we observe that amongst the
In a comparative study carried out in the form software development organisations taking part
of triangulation (quantitative and qualitative in-

Figure 4. Measures of the quality of the software process

50,00%
45,00%
40,00%
35,00%
30,00% not at all
25,00% a little
20,00% quite a lot
15,00% very much so

10,00%
5,00%
0,00%
Greece Finland UK Denmark

36
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

in the study, Greece is the country that keeps internalised knowledge instead of expressing
measures of the quality of the software develop- knowledge by explicit procedures. Successive
ment process to the highest degree. The sum of knowledge creation also requires voluntary ac-
the values for “quite a lot” or “very much so” is tions including openness, scrutiny, and reluctance
61.9% for Greece, 44.7% for Denmark, 42.6% for to different views and interpretations.
Finland, and 42.5% for the UK. The significance New knowledge always begins with the indi-
of the Chi-square is 0.002, which indicates that the vidual. The individual’s self-interest determines
null-hypothesis, that the responses are similar for in which informal knowledge creation processes
all countries, can be rejected. This means that we to participate (Chen & Edgington, 2005). Indi-
have statistically proved that there are significant viduals also tend to hoard knowledge for various
differences in responses depending on country of reasons (Bock, Zmud, Kim, & Lee, 2005); one
origin. reason being the cultural value system of the team,
The research study itself was the starting organisation, or country (Siakas & Mitalas, 2004).
point to examine and classify in a typology the Within a single culture certain beliefs, values,
different organisational and national cultural procedural norms, attitudes, and behaviours are
factors and their influence in software qual- either favoured or suppressed (Siakas et al., 2003).
ity management strategies. In what follows Making personal knowledge available to others is
we draw from these conclusions and attempt a central activity in knowledge creation. Explicit
their re-framing and examination within the knowledge is formal and systematic, while tacit
agile paradigm principles and strategies for knowledge is highly personal (Nonaka, 1998). The
stakeholders’ involvement. constructive learning process in work places is
revealed through bottom-up knowledge creation
Knowledge creation and transfer in spread from individual to individual in the sociali-
Agile development sation process (Nonaka & Takeuchi, 1995).
Because of extensive customer involvement
Knowledge is an active part of human working in the agile development process, and the direct
practice. Malhotra (1997) lists four concerns feedback through frequent face-to-face commu-
regarding knowledge creation in organisations, nications between customers, representatives,
namely: and developers, there is an efficient transfer of
individual knowledge. Pair-programming, pair-
• Dynamic and continuously evolving nature rotation across programming pairs and feature
of knowledge. teams, and peer-reviews could also facilitate
• Tacit and explicit dimensions in knowledge tacit knowledge creation and transfer (Boehm
creation. & Turner, 2003a, 2003b; Luong & Chau, 2002).
• Subjective, interpretative, and meaning Organisations and teams expect their members
making base of knowledge creation. to keep up-to-date by continuously obtaining
• Constructive nature of knowledge cre- internal and external information relating to their
ation. profession. Team members reflect in action, ac-
cumulate, and refine the knowledge required for
Knowledge evolves continuously as the indi- completing their tasks (context) through a process
vidual adapts to amplifications and innovations of learning-by-doing (Garud & Kumaraswamy,
from their peer workmates. Working knowledge is 2005). Initial tacit knowledge created in the work-
at a great proportion tacit, which means that people ing practice is only the first step in the organi-
rely on their earlier experiences, perceptions, and sational knowledge creation process according

37
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

to Nonaka et al. (1995). In addition, knowledge needed to accomplish the project. Some high-level
is sometimes introduced into organisational use conceptual documentation such as user stories
by making it first explicit and then transferring (short descriptions of features in requirements),
back to the members of the organisation. In agile high-level architectural design, and/or documen-
methodologies, this part seems to be disregarded. tation of high-risk components are usually also
Individuals may maximise personal benefit, but created to define a contract model or to support
to transform tacit knowledge into organisational communication with an external part (Amber,
knowledge (if possible) is not an easy task, because 2005). This type of documentation accomplishes
tacit knowledge is human capital that ‘walks out a high-level road map, which can be useful for
the door at the end of the day” (Spiegler, 2005). projects newcomers and post-mortem analysis.
In order to utilise the individual knowledge The close collaboration of team-members,
and transfer it into organisational knowledge, the including stand-up meetings, peer-reviews, pair-
organisation needs to strategically align organi- rotation, and pair-programming in agile develop-
sational learning investment with organisational ment ensure knowledge of each other’s work and
value outcome taking into account both current therefore improve domain knowledge and quality
and future organisational tasks. The organisa- of the deliverables. Automated documentation
tion has more control over a formal or structured tools, such as design tools, may be used for the fi-
knowledge creation process (Chen et al., 2005). nal documentation, while during the development
However, deliberate knowledge management frequent iterations would cause version problems
(KM) involves more than sponsorship of initia- (Manninen et al., 2004). Research has shown that
tives at and across different organisational levels there is a visible conflict related to the amount of
(Garud et al., 2005). It also involves an active documentation that should be kept (Karlström &
process of causing intended consequences. The Runeson, 2005); a balance between how much
organisational culture, including the organisa- work to put into documentation and the usefulness
tional structure, processes, and procedures, is of documentation has to be found.
important for avoiding organisational knowledge
dilution, creating, transferring, and sustaining customer Involvement vs.
organisational knowledge. Recently, there were End-user(s) representative or
indications for an emergent need for integrat- consensus Participation
ing KM and agile processes (Holz, Melnik, &
Schaaf, 2003). The distinction between predictive (plan-driven)
In agile development, documentation is kept and adaptive (agile) recognises the fact that achiev-
to a minimum (Agile manifesto, 2005). Docu- ing plan milestones does not necessarily equate to
mentation is seen as a non-productive and non- customer success (Mellor, 2005). In order to ensure
creative task resulting in static documents that conformance to requirements, user satisfaction,
seldom reflect reality and are hardly ever used and competitive advantage agile development
after they are created. The question seems to be involves the user in the entire process. However,
how much return on investment (ROI) and added customer identification can be difficult, and may
business value are provided by documentation. require the identification of suitable internal cus-
Agile development focuses on executable docu- tomer representative(s) providing a single point of
mentation, also called agile testing (Pettichord, contact both for the team and senior management
2002), namely self-documented code, which is on a daily basis. The high iteration frequency in
code including comments, self-describing vari- agile development also provides opportunities for
able names, and functions, as well as test cases, product feedback on conformance to requirements

38
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

(Karlström et al., 2005). The emphasis on user procedures, organisational rules, and regulations
viewpoints relating to the characteristics of the that empower developers and technical staff by
final product (user-centred approach) in combina- giving a back-to-basics sense to their work (Boehm
tion with a daily feedback mechanism increases et al., 2003a, 2003b; DeMarco & Boehm, 2002;
the rate of feedback on performed work and the Karlström et al., 2005). Competent agile teams
speed of discovering erroneous functionality at that possess the necessary mix of technical skills,
an early development stage (Siakas et al., 2005; people expertise, and agility are built on cohesive
Karlström et al., 2005). team environments and are committed to the com-
Developer motivation, commitment, and mon goals. However, generating group identity
satisfaction are key elements for success (Abra- may prove difficult (Boehm et al., 2003a, 2003b).
hamsson, 2002; Siakas et al., 2003) due to the The main issues though seem to be changes in
fact that they recognise the actual need of a values and attitudes in organisational culture and
quality outcome and to the importance of their function and synchronisation of teams based on
role in the creation process (feelings of personal communication, leadership, and trust (Jäkälä &
ownership). The high iteration frequency also Berki, 2004). The larger the organisation and the
has consequences for contracts variables, such more traditional, the more difficult is a cultural
as scope, price and time and thus the contracts change in the organisation (Siakas, 2002).
need to be flexible (Geschi, Sillitti, & Succi, The agile approach to software development
2005). This, in turn, may be a drawback for the has the characteristics of a group of people that
customer’s cost-analysis plans. differentiate themselves from others through a
whole set of shared values, visions, principles,
organisational and national culture ideals, practices, etc, that emerge in the interac-
Issues: Is Agility Acceptable and tion between members of a group. The extreme
suitable for all cultures? programming (XP) pioneers for example, draw at-
tention to four XP values, namely, communication,
The basis of agile development lies in small teams simplicity, feedback, and courage, the underlying
working in co-located development environments basis for the 12 principles which are translated
developing non-safety critical software (Abra- into practices (Robinson & Sharp, 2003). These
hamsson, 2005). Agile development relies on practices are the artefacts of the XP culture.
self-directed teams consisting of highly skilled, Having a consistent culture is important for
motivated, and innovative software engineers, consensus and agreement, as well as for avoid-
who are collaborative in team work and self- ance of friction due to cultural clashes within
organised, active learners. These characteristics the team and the whole organisation. The social
impose a competitive environment with potential characteristics of the team members are important.
cultural, political, and social implications. Inte- Employment of technically highly competent and
grating agile approaches and philosophies into competitive software professionals generates the
traditional environments with existing “legacy” basis for the creation of a strong team/organisa-
staff and processes is difficult (Boehm et al., tional culture. The agile culture requires active
2003a, 2003b). The focus on agility and simplic- involvement of all team members and seems to be
ity, people-orientation, and final product delivery most suitable in Democratic-type of organisations,
in agile development indicates many degrees which have horizontal hierarchy emphasising
of freedom and individual skills building. This flexibility and spontaneity (Siakas et al., 2000).
is opposed to process orientation and maturity This type of organisation generates initiative and
approaches through frameworks of policies and responsibility approaches; the leadership style is

39
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

that of coordination and organisation. The organi- which is flexible, customisable to designers and
sation has flexible rules and problems are solved by to end-users needs. This, of course, moves the
negotiations. Employees are encouraged to make problem to a more abstract level, that of method
contribution to the decision-making process and metamodelling and method engineering. The next
to the development of the organisation in gen- section explores these issues further in the context
eral. Democratic organisations can be said to be of this chapter and of this book.
people-oriented. Examples of countries belonging
to the Democratic type are some Scandinavian
countries, Anglo-Saxon countries, and Jamaica tHE nEEd For ForMAL
(Siakas et al., 2000). MEtAModELLInG And AGILE
The globalisation of software development, MEtHod EnGInEErInG
involving virtual teams and offshore outsourc- PrIncIPLEs WItH suItAbLE tooL
ing, increases complexity. The management of suPPort
large, global organisations, dependent on people
with different underlying norms, values, and Assuming that the benefits of using agile methods
beliefs, experiences difficulties when applying are remarkable and unquestionable, how could
traditional management approaches (Siakas et practitioners and software project managers
al., 2005). Despite significant improvements in choose among agile and non-agile methods? How
ICT, the complexity will increase even more if could someone evaluate the “agility” or “agile-
agile software development is introduced in such ness” of an agile method as this is defined in the
global settings. By nature, agile development agile manifesto (2005) (Cockburn, 2004), and as
facilitates pair-programming, pair-reviews, is defined by many other supporters? Moreover,
and pair-rotation, and thus, could not be fa- how could systems analysts and designers con-
cilitated among virtual teams. Additional na- struct and/or adopt an agile method if they are
tional differences in working values, attitudes, not fully satisfied with the ones currently avail-
and time-zone differences will be difficult to able? Otherwise, how could the quality proper-
overcome. ties of requirements changeability (and therefore
Having to consider so many differences and specification modifiability), implementability
desires for empowerment of developers and end- (and therefore specification computability), and
users, suitability and applicability of an agile frequent deliverable artefacts’ testability be es-
method in a particular organisational, cultural, tablished and assured? The answer(s) probably lie
or national setting still remains questionable. in utilising cost-effective technology and existing
Moreover, method customisation and adaptability MetaCASE tools (Berki, 2004). Implementability,
issues are not completely resolved for maximum changeability, and testing, as hinted in the agile
designer and end-user involvement. XP (and most manifesto and as praised by the agile methodol-
other agile methods) empower developers to con- ogy supporters, are considered as the significant
fidently respond to and test changing customer difference quality properties offered in agile
requirements, even late in the life cycle (Beck, software development teams. Moreover, and
2002; Holcombe, 2005). Acceptance of changes turning to soft issues of collaboration and com-
also empowers the customers but do additional munication between end-users and IS designers,
customer requirements violate the requirements how could the properties of communicability and
specification and do they invalidate previous synergy among stakeholders be ensured for the
modelling efforts? Unless, of course, the require- agile method to be used?
ments specification is empowered by a method

40
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

Because method, application, software, and for facilitating frequent future implementations and
process engineers want to create their own their redesign in a testable way (Berki, 2001).
knowledge-oriented methods, document their
own tool environment, and design their software the need for Agile Method
development processes, they frequently resort Engineering (AME) with cAME tools
to metamodels and method engineering (ME)
principles (Berki, 2001). In so doing, assurance The expansion and use of agile methods and the
is granted for customised and flexible methods associated technology gave rise to more demand-
and for maximum designer involvement and user ing modelling processes among the ISD stakehold-
participation (Berki, 2004, 2006; Georgiadou ers. On the one hand, the need for preserving the
et al., 1998). Bridging the gaps that traditional consistency, correctness, and completeness of
non-agile design methods created, the utilisation the associated artefacts of every developmental
of MetaCASE and computer-assisted method en- stage indicated the need for advanced software
gineering (CAME) tools (Berki, 2001; Tolvanen, and groupware tool use and shared and agreed
1998) for the evaluation and/or construction of work and method models for communication and
an agile process model (method) could be the collaboration. On the other hand, more abstrac-
answer to the quality assurance required for agile tion, analytical, and communication skills are
methods. constantly required to collaborate with a variety
of stakeholders. These integrated requirements
Agileness and its Meaning in terms assisted in realising the need for more coopera-
of Method Engineering tion and interaction in the IS life cycle and, at the
same time, the need to capturing the computational
Representing the rules of metamodelling and characteristics and the dynamic knowledge of a
method engineering in the context of MetaCASE method. The diverse cognitive needs of human
(CASE-Shells) and CAME tools, a proposal to behaviour and interaction (Huotari & Kaipala,
model agile and formal process models in CAME 1999), in particular, gave rise to expressive soft-
environments requires to utilise meta-design ware systems modelling through shared process
knowledge patterns that facilitate collaboration models that represent agreed views. People
and interaction. In order to construct an agile change and their opinions and requirements con-
method, many quality properties such as the ones stantly change, too. Systems engineers that use
previously mentioned are required. agile methods need evolutionary and expandable
Method flexibility and adaptability to accom- models to capture modelling concepts and com-
modate changes is of foremost importance. When municate them with others (Berki, 2004).
requirements, specifications, and programming Existing MetaCASE technology offers to
artefacts undergo changes after frequent end-users humans possibilities to formalise the systems
feedback, methods’ models and techniques need development processes and lead to standardisation
to be extended and integrated in order to facilitate and integration of agile methods and tools with
the accommodation of new stakeholders’ needs. quality assurance procedures. The great chal-
Expressing and understanding method techniques lenges though of MetaCASE technology will be
and models in terms of their dynamics requires the to provide guidance on implementation strategies
utilisation of formal meta-concepts to define new and facilitate the requirement for testing of agile
representations of a method syntactically and se- modelling processes and products. Some of the
mantically. Furthermore, a generic and agile method MetaCASE tools that can be used to construct
model should possess computational characteristics agile methods in a dynamic and computational

41
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

way are CoCoA (complex covering aggregation), manner and could provide capture of frequently
MetaView, NIAM (Nijssen’s information analysis changing requirements and testing (Berki, 2001,
method), and Object-Z. Not all, though, are fully 2004), both requirements of foremost importance
automated for complete use as MetaCASE tools. in agile systems development. For instance, at
Moreover, they do not offer method testability MetaEdit+ an agile method (and any method)
(Berki, 2004, 2006). The exception is MetaEdit+, a could be represented as a Graph, Table, or Ma-
multi-method, and a multi-tool CASE and CAME trix, having the following semantic and syntactic
platform, which offers the modelling power to meta-design constructs:
construct an agile method with its method work-
bench to varying degrees of support (Kelly et al., • Graphs: Sets of graphical objects and their
1996; Tolvanen, 1998;). connections.
• Objects: Identifiable design entities in every
A Formal Method Workbench to technique/method.
built-In Quality When constructing • Properties: Attributes of graphs, objects,
Agile Methods relationships, and roles.
• Relationships: Associations between ob-
MetaEdit+ establishes a versatile and powerful jects.
multi-tool environment that could enable flexible • Roles: Define the ways in which objects
creation, maintenance, manipulation, retrieval, participate in specific relationships.
and representation of design information among
multiple developers. MetaEdit+ is a multi-user The method workbench is a significant part of
tool constructed to involve as many possible MetaEdit+ tool. The basic architectural structure
developers and multi-users in a flexible creation that is used to create the products of all levels
of, a suitable to their needs, method. The tool (i.e., methods and their instances) is GOPRR. As
has been used worldwide in academia and in in- outlined earlier, GOPRR recognises in a method’s
dustry but it has mainly been utilised in systems generic structure (and therefore in its instances)
development in Scandinavian countries, that is the semantic concepts of objects and relationships,
the democratic type of countries (see previous which both possess properties and roles. When
section entitled: “Organisational and National creating new method specifications in MetaEdit+,
Culture Issues: Is Agility Acceptable and Suitable the metamodeller should firstly concentrate on
for all Cultures?”). the constructs of a method (Kelly, et al., 1996;
Being of such nature and created to address Rossi, 1998; Tolvanen, 1998). In doing so, he or
the needs for participation and maximum user she must use the GOPRR metamodel to guide
involvement, MetaEdit+ could point to and ap- the whole metamodelling process as well as the
praise the suitability and applicability of an agile assisting drawing, hypertext, etc. tools that are
method with respect to stakeholders’ needs. As offered with MetaEdit+ and are depicted in the
a computer aided method engineering (CAME) MetaEdit+’s architecture, which is presented in
environment with a method workbench, it offers Appendix B.
an easy-to-use, yet powerful environment for Naturally, this way of metamodelling offers
agile method specification, integration, change a degree of integration but limited expressability
management, and re-use (Kelly, et al., 1996; for data and process dynamics. Methods are pro-
Rossi, 1998; Tolvanen, 1998). The tool could also cess models that transform data continuously but
facilitate method implementations in a computable very few dynamic methods exist in MetaCASE

42
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

tool support (Berki, 2004; Tolvanen, 1998). And, quality properties of changeability as dynamic
finally, formalised generic guidelines of a “process models and specification computability by deriv-
for modelling an agile method” together with ing implementable designs. Moreover, machines
formal testing procedures and suitable method are testable computational models, known for the
engineering metrics should be incorporated in finite state machine standard procedure for test-
the meta-design process of the next generation ing in early phases of specification and design.
of MetaCASE and CAME tools. Furthermore, As a framework, CDM-FILTERS recognises the
hypertext facilities are under development in order evolutionary and frequently changing nature of
to express explicit knowledge (knowledge about systems and their stakeholders and facilitates stan-
method’s constructs) more accurately but also dard feedback and communication mechanisms
facilitate the expression of tacit knowledge, that among them. (Berki, 2001, 2004).
is the feedback mechanisms and opinions among Thus, with CDM-FILTERS as an agile method
stakeholders at many different levels. engineering instrument, it will be possible to
evaluate and integrate existing methods and build
the need for an Agile, Formal, and test methods by revealing and testing at the
Generic Metamodel same time the implementation details of the pro-
totype code that needs to be frequently released.
It is argued that computability and implementation This conceptual computational modelling, which
issues in method metamodelling can be captured is hereby suggested for agile software development
with more abstract and classic computational mod- processes, is based on dynamic metarepresenta-
els (Berki, 2001; Holcombe & Ipate, 1998). With tions of methods, and is achieved by capturing
this choice, the method’s computational quality the method’s pragmatics, semantics, and syntax
properties can be documented and communicated as machines specifications, which are general,
as implementation details for the system design- dynamic, and testable computational models
ers, when the purpose is to analyse the given (Berki, 2001, 2004). This systemic (holistic)
stakeholders needs and design and implement metamodelling and process-based approach can
them into a software system. Such a facility can offer a smooth transition between the systems
be offered by the CDM-FILTERS model (Berki, development phases by improving the communi-
2001), which provides an integrated specification cation channels for stakeholders in requirements
platform for agile software development with the engineering and re-engineering, and by mapping
agile paradigm qualities and values (see again the exact testable artefacts of one stage to those of
Tables 1 and 2). the next (Berki, 2001), which is a major challenge
CDM-FILTERS stands for a Computational in traditional software systems engineering and
and Dynamic Metamodel as a Flexible and Inte- in the agile software development processes.
grating Language for Testing, Expressing, and Re-
engineering Systems. It was constructed as a result
of a large survey in metamodelling technology dIscussIon, concLusIVE
and existing MetaCASE and CAME tools and as a rEMArKs, And FuturE
promise to overcome severe limitations that were rEsEArcH consIdErAtIons
observed in software development with traditional
information systems development methodologies In identifying the reasons for the popularity of
in the last 40 years (see Figure 1). As a metamodel, agile methods and state-of-the-art in software
CDM-FILTERS is based on machines (general engineering, we examined the quality of agile
finite state machines) that provide the inherent software development processes and analysed

43
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

socio-technical and organisational factors related integrated with the development environment.
to quality information systems and stakeholders’ Furthermore, MetaCASE and CAME tools should
involvement and satisfaction. Contemporary be foremost utilised to construct an agile, flexible
agile methods, compared to traditional software to the stakeholders and especially to end-users
development methods, still need to demonstrate needs, development method.
further practicality, applicability, their “generic” Societal norms, which are expressed by the
suitability, and finally, their potential for quality value system shared by the majority of a society,
assurance. Some research projects from industry have influenced the development of structures and
and academia (Abrahamsson et al., 2002; Berki, ways of functioning of organisations (Hofstede,
2004; Sfetsos, Angelis, Stamelos, & Bleris, 2004) 2001). People in a particular organisational set-
mostly report on the advantages of agile methods. ting or software development team share values,
Supporters of agile methods, though, must provide beliefs, attitudes, and patterns of behaviour (or
convincing answers to questions such as what is not!). The agile approach can be considered to be
the quality of the software produced, or which a culture in its own right aiming at socially-con-
evidence supports the superiority of agile quality structed and user-accepted software. The question
attributes over pure scientific reasoning as this is of course remains open if the socially-constructed
employed in traditional SE development methods part of reality suits for agile method engineer-
and software tools that support them? ing. The literature examined in this chapter has
There has been little research work that focuses suggested that higher customer involvement also
on agile software development quality issues, results in higher quality, especially in terms of
while limited industrial practice, often contra- meeting requirements. Agile methodologies em-
dicted by the academia, disproves the benefits phasise user satisfaction through user participa-
claimed from agile method(ology) use. Moreover tion, recognition of and response to continuous
and more often the evidence of the superiority changing requirements, and frequent delivery
of the agile methods, coming from academia or of products together with adaptive and iterative
industry, are contradicting and bound to other un- software development by self-organising teams,
controlled experimental factors. Certainly, opin- which recognise that team-members are compe-
ions and observations on agile development have tent professionals, able to choose and follow an
not been derived from formal measurements. No adaptive process. A further research question that
matter how strong the beliefs on the applicability rises is to which degree agile methods cater for
and suitability of agile methods are, these remain representative and consensus end-user participa-
subjective claims, and they do not constitute a tion like the traditional ETHICS methodology (see
formal proof of the agile method deployment or, in Mumford, 1983; 2003) caters for? Maximum
rather, of the quality function deployment. stakeholder and user involvement in an agile
The XP community, for instance, believes development process does not necessarily mean
that design information should allow the design maximum end-user involvement. Otherwise,
to be captured in a form that is machine process- end-users are not very willing to frequently pro-
able and the components to be reused smoothly vide feedback on software artefacts and other
integrated. However, software development tools devliverables. Hence, usability engineering and
should control the management of this agile cognitive systems engineering principles need
development process, enabling the top-down to be taken onboard for an agile, holistic design
development of applications up to code genera- process that encounters human beings, their
tion and bottom-up development to include and opinions and feelings.
provide for reengineering of existing codes, fully

44
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

Frequent delivery of product (incremental), requirements changed versions documentation


user-involvement, and adaptability to changing procedures.
or erroneously understood requirements has in Extensions of agile methods constructs,
recent years been the domain of agile software through metamodelling and method engineering
development. Maintainability, reliability, pro- principles, to include metrication procedures and
ductivity, and re-engineering issues are all con- be supported by automated tools is also possible
nected to timeliness, which is a demand of agile in future. The latter could prove particularly fruit-
software development by adopting a frequent ful for continuous recording of product metrics
product release approach in shorter deliverable to draw comparisons before and after re-factor-
cycles. Timeliness and how it is achieved is an ing. In general, software tools that could support
issue that has not been adequately researched. agile methods and agile processes need to be rich
Hence, the answer to the question whether agile in communication and collaboration features in
methods are time-consuming or time-effective order to realise participative design decisions and
remains open for future investigation. requirements management challenges. According
As exposed in this chapter, process and product to Damian and Zowghi (2003), who report on a field
metrics are useful indicators of improvement. study with cross-functional stakeholder groups,
Direct measures of internal characteristics are requirements management in multi-site software
by far the easiest to obtain. However, external development organisations, due to increasing
characteristics (such as commitment, job satisfac- globalisation of the software industry, demands
tion, user satisfaction, and knowledge transfer) to address the following groups of problems: (i)
are complex and often not measurable in simple cultural diversity, (ii) inadequate communication,
terms. Measurement activities can only be suc- (iii) ineffective knowledge management, and (iv)
cessful if the development process is mature. This time zone differences. The previous resulted in
presupposes commitment at all levels within an inadequate participation, difficulties in require-
organisation. Knowledge creation and experi- ments’ common understanding, delays in deliver-
ence sharing could be formalised and reused in ables, ineffective decision-making meetings, and a
a continuously improving cycle. reduced level of trust, to name just but a few, real
A further emerging research question is how software development stakeholders’ problems.
will agile methods accommodate the need to keep We propose that in an agile, global software
metrics with the philosophy of minimal documen- development, situations similar to the previously
tation? We propose that the use of automated data mentioned problematic circumstances could be
capture will improve the process and ultimately supported by suitable groupware, hypertext, e-
the product. Future research should probably point mail, video-conferencing, or other stakeholder-
to an agile collection of metrics rather than agile and end-user-centred information and commu-
metrics, that is the agility will be shifted in the nication technologies. These process quality-ori-
process and not in the actual product metrics, in ented facilities could allow them to inform and be
order to overcome the dangers inherent in the informed on requirements’ change, express own
agile philosophy of minimal documentation. opinions, and willingly provide feedback upon
These can, perhaps, be addressed by automation frequent information retrieval on the product’s
tools, efficient ways of data/feedback collection, development progress. Equally important is to
data/information organisation, organisational have access to reports on similar success or failure
memory information systems, procedures for stories on agile development project teams. Such
making knowledge explicit, data mining, and reports will allow a deeper study to the levels of

45
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

knowledge, communication, and trust that are Yet, links, opinions, and insights from various
required to operate in a project team. related contexts and contents need to be provided
According to Holcombe et al. (1998), there for agile software development teams to reach a
is little empirical evidence of the superiority of level of maturity. Notwithstanding the culture of
one method over another and that can be seen the agile methods paradigm promotes significant
clearly in large-scale projects where methodologi- working values and exposes scientific knowl-
cal problems are more obvious. Moreover, there edge principles in software and IS development
seems to be a crisis of intellectual respectability in that have not been combined and utilised in a
the method selection and evaluation subject. Not similar way before. In order, however, for agile
only the evaluation and quality assurance of the methodologies to finally present an integrated
methods under use are weak, the selection of the solution based on holistic communication rules
types of system and problem to focus on (method within appropriate structures, researchers will
application domain) restricts the suitability and have to answer a future research question. That
applicability of any method. In order to convince, will need to capture the modelling of the seman-
in a scientific manner, that a method A is better tics, pragmatics, and semiotics of systems’ and
than a method B in large design projects (where stakeholders’ requirements and thus provide the
most of the problems really lie), we must present scientific ground for usability engineering in dif-
rigorous evidence drawn from carefully controlled ferent cultural contexts.
experiments of suitable complexity. This is, more It is questionable and not, yet, clear if agile
or less, impossible in practical terms. Is there and lightweight methods cater for a flexible,
an alternative approach? The use of theoretical lightweight quality or if traditional development
models of computing systems can provide some methods provide scientific reasoning that is not
alternative approaches (Berki, 2001; Berki, 2006; offered by agile methods. The latter is probably
Holcombe et al., 1998). inherent in the nature of agile methodology since it
The interest for agile methodology designers, is considered a cooperative game of invention and
therefore, should be in identifying and using communication that utilises poetry, Wittgenstein’s
general and understandable, groupware-oriented philosophical concepts, and participative games
structures that adequately capture the features (see Cockburn, 2002). Cockburn (2002) further
of changeable specifications, testable computa- defines agile software development as the use of
tions, collaboration and feedback mechanisms for light but sufficient rules of project behaviour and
frequent communication. This can be achieved the use of human and communication-oriented
in terms of specialised and sufficiently general rules. On the other hand, “agility” is described as
design structures that can capture the richness dynamic, context-specific, aggressively change-
and testedness of domain specifications, consid- embracing, and growth-oriented. “It is not about
ering at the same time people’s cognitive needs improving efficiency, cutting costs, ... It is about
(Huotari et al., 1999) and maximum participation succeeding in emerging competitive arenas, and
and, therefore, empowerment (Berki, 2001). On about winning profits, market share, and custom-
the other hand, it is important for the various IS ers ...” (Goldman, Nagle, & Preiss, 1995).
stakeholders to state clearly their objectives and In assisting developers to make judgements
expectations from the software products, in order about the suitability and applicability of agile
for agile software developers to respond to these development methods, Miller and Larson (2006)
characteristics and define the agile final product support that the intentions of an actor are vital to a
and agile work processes with features that reflect further deontological analysis, while a utilitarian
these required objectives. analysis forces a broad view of who is affected

46
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

by an act. Hence, further utilitarian analysis will for collaborative business values and academic
assist software engineers to think professionally values will, in turn, maximise the likelihood of
about the consequences for other stakeholders suitable ISD methods. The ultimate contribu-
and especially consider the end-users consensus tion of this analysis could be a critical thinking
participation, while a deontological viewpoint will framework that will provide a dialectical instru-
always guarantee a “proper,” ethical decision. ment for re-assessing and re-framing the potential
applicability and suitability of agile methods
construction and adoption. That metacognitive
suMMArY and meta-constructivist method knowledge itself
could give agile, improved ways of work to evalu-
This chapter examined and analysed the trends ate and model information systems and people’s
and challenges that exist in traditional software needs in a scientific and progressive manner.
development and in agile software development,
in a critical manner. The chapter concluded by
committing to the motivation and accomplishment rEFErEncEs
of the agile manifesto initial expectations and
ambitions, that is the consideration of a flexible Abrahamsson, P. (2002). The role of commitment
approach in software development by adopting in software process improvement. PhD thesis,
scientific and communication principles for University of Oulu, Department of Information
ISD. The belief that these aims can be achieved Processing Science and Infotech, Finland.
is emphasised by the suggestion of utilising
Abrahamsson, P. (2005). Project manager’s
metamodelling and ME technology. For instance,
greetings: Agile greetings. Agile Newsletter,
the generic process architectural constructs of
1(1), 2004.
the CDM-FILTERS metamodel encapsulate both
communicative and scientific quality properties, Abrahamsson, P., Salo, O., Ronkainen, J., &
which can be utilised in agile method engineer- Warsta, J. (2002). Agile software development
ing. The latter can automatically be utilised by methods: Review and analysis. Espoo, Finland:
MetaCASE and CAME tools, which offer an ad- VTT Publications.
equate platform that support stakeholder-centred
Agile COCOMO Web site. (2006). Retrieved May
and -originated quality requirements for a flexible
3, 2006, from http://sunset.usc.edu/cse/pub/re-
construction of agile methods.
search/AgileCOCOMO/
This work supports the combination of creative
intuition and engineering principles to transform Agile Manifesto Web site. (2005). Retrieved
stakeholders’ requirements to adequate human- November 27, 2005, from http://www.agilema-
centred information systems. Stakeholders’ nifesto.org/
needs will be mirrored successfully in a natural,
Amber, S. (2005). Agile documentation: Strate-
smooth, and unambiguous manner, if the software
gies for agile software development. Retrieved
artefacts’ transformation will be based on agile
November 28, 2005, from http://www.agilemodel-
methods that serve as a communicative platform
ing.com/essays/agileDocumentation.htm
for understanding, and offer total quality assur-
ance. Avison, D., & Fitzgerald, G. (2003). Information
Considering that commercial applicability systems development: Methodologies, techniques,
with scientific reasoning is likely to increase in and tools (3rd ed.). UK: McGraw-Hill Publishing
ongoing research, the development perspectives Company.

47
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

Avison, D., & Wood-Harper, T. (1990). Mul- Berki, E., Georgiadou, E., & Siakas, K. (1997,
tiview: An exploration in information systems March 7-9). A methodology is as strong as the user
development. Oxford: Blackwell Scientific Pub- involvement it supports. International Symposium
lications. on Software Engineering in Universities – ISSEU
97 (pp. 36-51). Rovaniemi.
Beck, K. (2000). Extreme programming ex-
plained: Embrace change. Reading, MA: Addison Berki, E., Isomäki, H., & Jäkälä, M., (2003).
Wesley Longman. Holistic communication modeling: Enhancing
human-centred design through empowerment. In
Beck, K. (2001). Extreme programming explained.
D. Harris, V. Duffy, M. Smith, & C. Stephanidis
Software Quality Week, San Francisco, May.
(Eds.), Cognitive, social, and ergonomic aspects
Beck, K. (2003). Test driven development: By (Vol. 3 of HCI International) (pp. 1208-1212). Her-
example. Boston: Addison Wesley. aklion, Crete: Lawrence Erlbaum Associates.
Beck, K., & Fowler, M. (2001). Planning extreme Berki, E., Lyytinen, K., Georgiadou, E., Hol-
programming. Boston: Addison Wesley. combe, M., & Yip, J. (2002). Testing, evolution,
and implementation issues in metacase and
Beizer, B. (1995). Foundations of software testing
computer assisted method engineering (CAME)
techniques. The 12th International Conference
environments. In G. King, M. Ross, G. Staples, &
& Exposition on Testing Computer Software,
T. Twomey (Eds.), Issues of quality management
Washington, DC.
and process improvement. The 10th International
Beizer, B. (1990). Software testing techniques (2nd Conference on Software Quality Management,
ed.). Van Nostrand Reinhold. SQM02. Limerick: Computer Society.

Bell, S., & Wood-Harpet, A. T. T. (1992). Rapid Bock, G. W., Zmud, R. W., Kim, Y. G., & Lee,
information systems development: A non-special- J. N. (2005). Behavioural intention formation
ist’s guide to analysis and design in an imperfect in knowledge sharing: Examining the roles of
world. McGraw-Hill. extrinsic motivators. Socio Psychological Forces
and Organisational Climate. MIS Quarterly, 29(1),
Berki, E., (2004). Formal metamodelling and agile
87-111, March.
method engineering in MetaCASE and CAME
tool environments. In K. Tigka & P. Kefalas (Eds.), Boehm, B. W. (1981). Software engineering eco-
The 1st South-East European workshop on formal nomics. Prentice Hall.
methods. Thessaloniki: SEERC.
Boehm, B., & Turner, R. (2003a). Using risk to
Berki, E. (2006, March). Examining the quality balance agile and plan-driven methods. Computer,
of evaluation frameworks and metamodeling 36(6), 57-64.
paradigms of information systems development
Boehm, B., & Turner R. (2003b). Balancing agility
methodologies. In E. Duggan & H. Reichgelt
and discipline: A guide for the perplexed. Addison
(Eds.), Measuring information systems delivery
Wesley Professionals.
quality. Hershey, PA: Idea Group Publishing.
Burr, A., & Georgiadou, E. (1995). Software
Berki, E., Georgiadou, E., & Holcombe, M. (2004).
development maturity—a comparison with other
Requirements engineering and process modelling
industries (5th ed.). World Congress on Total Qual-
in software quality management: Towards a ge-
ity, India, New Delhi.
neric process metamodel. The Software Quality
Journal, 12, 265-283.

48
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

Checkland, P. (1981). Systems thinking, systems Damian, D. E., & Zowghi, D. (2003). RE challenges
practice. Chichester, UK: Wiley. in multi-site software development organisations.
Requirements Engineering, 8(3), 149-160.
Checkland, P., & Scholes J. (1990). Soft systems
methodology in action. Toronto: John Wiley & DeMarco, T. (1982). Controlling software proj-
Sons. ects: Management, measurement, & estimation.
Englewood Cliffs, NJ: Prentice Hall.
Chen, A. N. K., & Edgington, T. M. (2005).
Assessing value in organizational knowledge DeMarco, T., & Boehm, B. (2002). The agile
creation: considerations for knowledge workers. methods fray. Computer, 35(6), 90-92.
MIS Quarterly, 29(2), 279-309.
Deming, W. E. (1986). Out of the crisis: Quality,
Cockburn, A. (2004). Agile software development. productivity, and competitive position. MA.
Cockburn-Highsmith Series. Addison-Wesley.
Dorling, A. (1993). Spice: Software process im-
COCOMO Web site. (2006). Retrieved May 3, provement and capability determination. Software
2006, from http://sunset.usc.edu/research/coco- Quality Journal, 2(93), 209-224.
mosuite/index.html
Dubinsky, Y., Talby, D., Hassan, O., & Keren,
Conner, K., & Prahalad, C. (1996). A resource- A. (2006). Agile metrics at the Israeli Air force.
based theory of the firm: Knowledge versus op- Retrieved January 21, 2006, from http://www.
portunism. Organization Science, 7(5), 477-501. cs.huji.ac.il/~davidt/papers/Agile_Metrics_Ag-
ileUnited05.pdf
Couger, J. D., & Adelsberger H. (1988). Compar-
ing motivation of programmers and analysts in Fenton, N. (1991). Software metrics—A rigorous
different socio/political environments: Austria approach. Chapman & Hall.
compared to the United States. Computer Person-
Fenton, N., & Pfleeger, S. (1997). Rigorous &
nel, 11(4), 13-17.
practical approach. PWS Publishing Company.
Couger, J. D., Borovitz, I., & Zviran, M. (1989).
Fowler, M. (1997). UML distilled. Addison
Comparison of motivating environments for
Wesley.
programmer/analysts and programmers in the
U.S., Israel, and Singapore in Sprague. In R/H. Fowler, M. (1997). Analysis patterns: Reusable
JR (Ed.), Proceedings of the 22nd Annual Hawaii object models. Addison Wesley.
International Conference on Systems Sciences
Fowler, M. (1999). Refactoring: Improving the
(pp. 316-323). Washington, DC: IEEE Computer
design of existing code. Addison-Wesley.
Society Press.
Garud, R., & Kumaraswamy, A. (2005). Vi-
Couger, J. D., Halttunen, V., & Lyytinen, K.
cious and virtuous circles in the management
(1991). Evaluating the motivating environment in
of knowledge: The case of Infosys technologies.
Finland compared to the United States—a survey.
MIS Quarterly, 29(1), 9-33, March.
European Journal of Information Systems, 1(2),
107-112. George, M. (2003). Lean six sigma for service: how
to use lean speed and six sigma quality to improve
Dalcher, D., & Genus, A. (2003). Avoiding IS/IT
services and transactions. McGraw Hill.
implementation failure. Technology Analysis and
Strategic Management, 15(4), 403-407.

49
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

Georgiadou, E. (2003a). GEQUAMO—A Ge- land: Computational Mechanics Publications,


neric, Multilayered, Customisable, Software August 1994.
Quality Model. Software Quality Management
Georgiadou, E., Siakas, K., & Berki, E. (2003).
Journal, December
Quality improvement through the identification
Georgiadou, E., (2003b). Software Process and of controllable and uncontrollable factors in
Product Improvement: A Historical Perspec- software development, EuroSPI 2003 (European
tive. Cybernetics, and Systems Analysis, 11(4), Software Process Improvement Conference) (pp.
125-142. IX-45), Graz, Austria, 10-12.
Georgiadou, E., & Keramopoulos, E. (2001, April). Geschi, M., Sillitti, A., Succi, G., & Panfilis, G.
Measuring the understandability of a graphical (2005). Project management in plan-based and
query language through a controlled experiment. agile companies. IEEE Software, 22(3), 21-27
The 9th International Conference on Software
Gilb, T. (2006). Software project management,
Quality Management, SQM 2001, University of
adding stakeholder metrics to agile projects.
Loughborough, UK.
Retrieved January 21, 2006, from http://www.
Georgiadou, E., & Milankovic-Atkinson, M. gilb.com/Download/AgileEvo.pdf
(1995, November). Testing and information sys-
Goldman, S., Nagle, R., & Preiss, K. (1995).
tems development life cycles. The 3rd European
Competitors and virtual organisations. New York:
Conference on Software Testing Analysis and
John Wiley & Sons.
Review (EuroSTAR’95), London.
Grieves, M. (2005). Product life cycle manage-
Georgiadou, E., & Sadler, C. (1995, April). Achiev-
ment driving the next generation of lean thinking,
ing quality improvement through understanding
McGraw-Hill.
and evaluating information systems development
methodologies. The 3rd International Conference Haase, V. H. (1992, May). Bootstrap: Measuring
on Software Quality Management, SQM’95, software management capabilities. First Find-
Seville, Spain. ings in Europe. Proceedings of the 4th IFAC/IFIP
Workshop, Austria.
Georgiadou, E., Hy, T., & Berki, E. (1998). Auto-
mated qualitative and quantitative evaluation of Haase, V., & Messnarz, R. (1994). Bootstrap:
software methods and tools. The 12th International Fine-tuning process assessment. IEEE Software,
Conference of the Israel Society for Quality, 11(4), 25-35.
November-December, Jerusalem.
Hennell, M. A. (1991). How to avoid systematic
Georgiadou, E., Karakitsos, G., & Sadler, C. software testing, Software Testing. Verification
(1994b). Improving the program quality by us- Reliability, 1(1), 23-30.
ing the re-engineering factor metric ρ. The 10th
Herbsleb, J., Carleton, A., Rozum, J., Siegel, J.,
International Conference of the Israel Society for
& Zubrow, D. (1994). Benefits of CMM-based
Quality, November 1994.
software process improvement: Initial results.
Georgiadou, E., Karakitsos, G., Sadler, C., Sta- Technical Report, CMU/SEI-94-TR-13, August.
sinopoulos, D., & Jones, R. (1994a). Program
Hofstede, G. (2001). Culture’s consequences:
maintainability is a function of structuredness.
Comparing values, behaviours, institutions,
Software Quality Management. Edinburg, Scot-

50
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

and organisations(2nd ed.). Thousand Oaks, CA; Jackson, M. (1994). Problems, methods, and
London: Sage Publications. specialisation. Software Engineering Journal,
9(6), 249-255.
Holcombe, M. (2005, June 18-23). Extreme
programming and agile processes in software Jäkälä, M., & Berki, E. (2004, March 24-26).
engineering. The 6th International Conference, Exploring the principles of individual and group
XP 2005, Sheffield, UK (Lecture Notes in Com- identity in virtual communities. In P. Commers,
puter Science). P. Isaias, & N. M. Baptista (Eds.), Proceed-
ings of the 1st IADIS Conference on Web-Based
Holcombe, M., & Ipate, F. (1998). Correct systems:
Communities (pp. 19-26). Lisbon: International
Building a business process solution. Springer-
Association for the Development of Information
Verlag.
Society (IADIS).
Holmes M. C. (1995). The relationship of cross-
Järvinen, J. (1994). On comparing process assess-
cultural differences to the values of information
ment results: BOOTSTRAP and CMM. Software
systems professionals within the context of systems
Quality Management, SQM94 (pp. 247-261),
development. PhD dissertation, Denton, Texas.
Edinburgh.
Holz, H., Melnik, G., & Schaaf, M. (2003).
Jayaratna, N. (1994). Understanding and evalu-
Knowledge management for distributed agile pro-
ating methodologies: NIMSAD—A systemic
cesses: models, techniques, and infrastructures.
framework. Berkshire, UK; McGraw Hill.
The 1st Workshop on Knowledge Management
for Distributed Agile Processes: Models, Tech- Johnson, R.E., & Foote, B. (1988). Designing
niques, and Infrastructures, June 9-11, Germany. reusable classes. Journal of OO Programming,
Retrieved January 25, 2006, from http://www. 1(2), 22-35.
dwm.unihildesheim.de/homes/schaaf/WET-
Karlström, D., & Runeson, P. (2005). Combining
ICE03/content.html
agile methods with stage-gate project manage-
Humphrey, W. (1995). A discipline for software ment. IEEE Software, 22(3), 43-49.
engineering. Reading, MA: Addison Wesley.
Keen P. W. (1992). Planning globally: Practi-
Huotari, J., & Kaipala, J. (1999). Review of HCI
cal strategies for information technology in the
research—Focus on cognitive aspects and used
transnational firm. In S. Palvia, R. Palvia, & R.
methods. Proceedings of T. Kakola (Ed.), IRIS 22
Zigli (Eds.), The global issues of information
Conference: Enterprise Architectures for Virtual
technology management (pp. 575-607). Hershey,
Organisations. Jyvaskyla, Finland, Keuruselka:
PA: Idea Group Publishing.
Jyvaskyla University Printing House.
Kelly, S., Lyytinen, K., & Rossi, M. (1996). Me-
Imai, M. (1986). Kaizen, the key to Japan’s com-
taEdit+: A Fully Configurable Multi-User and
petitive success. The Kaizen Institute.
Multi-Tool CASE and CAME Environment. In
ISO. (2005). Retrieved November 16, 2005, from P. Constantopoulos, J. Mylopoulos, & Y. Vas-
http://www.iso.org/ siliou (Eds.), Advances in Information Systems
Engineering, Proceedings of the 8th International
Ives, B., & Järvenpää, S. (1991). Applications
Conference CAiSE ’96, pp. 1-21.
of global information technology: Key issues
for management. MIS Quarterly, 15(1), 33-49, Kitchenham, B. (1996). Software metrics: Mea-
March. surement for software process improvement.
NCC, Blackwell.

51
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

Kitchenham, B., & Pfleeger, S. L. (1996). Soft- Mini-track) (pp. 293-295). Indianapolis, IN.
ware quality: The elusive target. IEEE Software,
Manninen, A., & Berki, E. (2004). Coordinat-
13(1), 12-21.
ing the quality of requirements change and
Koskinen, M., Liimatainen, K., Berki, E., & Jäkä- organisational communication—An evaluation
lä, M. (2005, January 2-5). The human context of framework for requirements management tools.
information systems. In R. H. Sprague, Jr. (Ed.), In D. Edgar-Neville, M. Ross, & G. Staples (Eds.),
The Proceedings of the 38th Hawaii International New approaches to software quality. Software
Conference on Systems Sciences (HICSS 2005) quality management XII. University of Kent at
(pp. 219a-234). Conference CDROM, IEEE Com- Canterbury, British Computer Society.
puter Society, IEEE, Los Alamitos, California.
Marciniak, J. (1994). Encyclopaedia of software
Kumar, K., & Bjorn-Andersen, N. (1990). A engineering. In B. Randell, G. Ringland, & B.
cross-cultural comparison of IS designer values. Wulf (Eds.), Software 2000: A view of the future.
Communications of the ACM, 33(5), 528-238, ICL and the Commission of European Communi-
May 1990. ties. John Wiley & Sons.
Kuvaja, P. (1999). New developments in software Mellor, S. (2005). Adapting agile approaches to
process improvement. Keynote Speech in Soft- your project needs. IEEE Software, 22(3), 17-34,
ware Quality Management Conference (SQM May/June.
99). Southampton. Retrieved from http://www.
Miller, K. W., & Larson, D. (2005). Agile software
bootstrap-institute.com/assessment.htm
development: Human values and culture. IEEE
Kuvaja, P., Similä, J., Kranik, L., Bicego, A., Sauk- Technology and Society, 24(4), 36-42.
konen, S., & Koch, G. (1994). Software process
Moussa, A., & Schware, R. (1992). Informatics
assessment and improvement—The BOOTSTRAP
in Africa: Lessons from World Bank experience.
approach. Cambridge, MA: Blackwell Publish-
World Development, 20(12), 1737-1752.
ers.
Mumford, E. (1983). Designing human systems for
Larman, C. (2004). Agile and iterative develop-
new technology: The ETHICS method. Retrieved
ment: A manager’s guide. Addison-Wesley.
from http://www.enid.u-net.com/C1book1.htm
Luong, F., & Chau, T. (2002). Knowledge man-
Mumford, E. (2003). Redesigning human systems.
agement in agile methods. Retrieved from sern.
Hershey, PA: Idea Group Publishing.
ucalgary.ca/courses/SENG/ 609.24/F2002/slides/
KM.ppt Nonaka, I. (1998). The knowledge-creating com-
pany. Harvard Business Review on Knowledge
Lyytinen, K., & Hirschheim, R. (1987). Informa-
Management. Harvard Business School Press.
tion systems failures—a survey and classification
of the empirical literature. Oxford surveys in Nonaka, I., & Takeuchi, H., (1995). The knowledge
information technology. In P. I. Zorkoczy (Ed.), creating company: How Japanese companies
Oxford University Press, 4, 257-309 create the dynamics of innovation. Oxford Uni-
versity Press.
Malhotra, Y. (1997, August 15-17). Knowledge
management in inquiring organizations. Proceed- Palvia, S., Palvia, R., & Zigli, R. (1992). The global
ings of 3rd Americas Conference on Information issues of information technology management.
Systems (Philosophy of Information Systems Hershey, PA: Idea Group Publishing.

52
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

Paulk, M. C. (1993). Comparing ISO 9001 and ence on Software Quality Management, SQM95,
capability maturity model for software. Software Seville (pp. 369-375).
Quality Journal, 2(4), 245-256.
Rossi, M. (1998). Advanced computer support for
Paulk, M. C. (1995, June 20-22). The rational method engineering: Implementation of CAME
planning of [software]: Projects. Proceedings of environment in MetaEdit+. PhD thesis. Jyvas-
the First World Congress for Software Quality, kyla Studies in Computer Science, Economics,
ASQC, San Francisco. and Statistics. Jyvaskyla, Finland: Jyvaskyla
University.
Paulk, M. C., Curtis, B., & Chrissis, M. B. (1993).
Capability maturity model (Version 1.1). IEEE Saaksvuori, A., & Immonen, A. (2003). Product
Software, 10(4), 19-27, July. life cycle management. Springer Verlag.
Pettichord, P. (2002). Agile testing, What is it? Sfetsos, P., Angelis, L., Stamelos, I., & Bleris, G.
Can it work? Retrieved November 28, 2005, from (2004, June). Evaluating the extreme program-
http://www.io.com/~wazmo/papers/agile_test- ming system—an empirical study. The 5th Inter-
ing_20021015.pdf national Conference on Extreme Programming
and Agile Processes in Software Engineering,
Pfleeger, L. (1998). Software engineering, theory,
Garmisch-Partenkirchen, Germany.
and practice. Prentice Hall.
Shepperd, M. (1995). Foundation of software
Polymenakou, S. (1995, December). Unlocking
measurement. Prentice Hall International (UK).
the secrets of information systems failures: The
key role of evaluation. The 5th Greek Conference Siakas, K. V. (2002). SQM-CODE: Software
in Computing, Athens (pp. 505-519). quality management—cultural and organisa-
tional diversity evaluation. PhD thesis, London
Poppendieck, M., & Poppendieck, T. (2003).
Metropolitan University.
Lean software development: An agile toolkit
for software development managers. The Agile Siakas, K., & Balstrup, B. (2005, November 9-11).
Software Development Series. Global software; Sourcing by Virtual Collabora-
tion? EuroSPI 2005 (European Software Process
Pressman, R. (2000). Software engineering: A
Improvement and Innovation, Conference), Bu-
practitioner’s approach (European Adaptation).
dapest, Hungary.
Ch. 19, Fifth Edition.
Siakas, K. V., & Georgiadou, E. (2000, Sep-
Rantapuska, T., Siakas, K., Sadler, C., & Moha-
tember 7-9). A new typology of national and or-
med, W. (1999, September 9-11). Quality issues of
ganisational cultures to facilitate software quality
end-user application development. The 4th Interna-
management. The 5th International Conference
tional Conference on Software Process Improve-
on Software Process Improvement—Research
ment—Research into Education and Training,
into Education and Training, INSPIRE 2000,
INSPIRE ’99, Crete, Greece (pp. 77-89).
London.
Robinson, H.M, & Sharp, H. (2003). XP culture:
Siakas, K. V., & Georgiadou, E. (2002). Empirical
Why the twelve practices both are and are not the
measurement of the effects of cultural diversity on
most significant things. Proceedings of the Agile
software quality management. Software Quality
Development Conference (ADC’03).
Management Journal, 10(2), 169-180.
Ross, M., & Staples, G. (1995, April). Maintaining
quality awareness. The 3rd International Confer-

53
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

Siakas, K., & Georgiadou, E. (2003, April 23-25). Siakas, K., Berki, E., Georgiadou, E., & Sadler,
The role of commitment for successful software C. (1997). The complete alphabet of quality soft-
process improvement and software quality man- ware systems: conflicts and compromises. The 7th
agement. The 11th Software Quality Management World Congress on Total Quality & Qualex 97
Conference, SQM 2003 (pp. 101-113). Glasgow, (pp. 603-618). New Delhi, India.
UK.
Siakas, K., Georgidaou, E., & Berki, E. (2005a).
Siakas, K., & Georgiadou, E. (2005). PERFUMES: Agile methodologies and software process im-
A scent of product quality characteristics. The 13th provement, IADIS (International Association
Software Quality Management Conference, SQM for Development of the Information Society).
2005, March, Glouchestershire, UK. International Virtual Multi Conference on
Computer Science and Information Systems
Siakas, K. V., & Mitalas, A. (2004). Experiences
(MCCSIS 2005)—SEA (Software Engineering
from the use of the personal software process (PSP)
and Applications).
in Greece. Analysis of cultural factors in the 9th
International Conference on Software Process Sommerville, I. (2001). Software engineering (6th
Improvement—Research into Education and ed.). Pearson Education.
Training, INSPIRE 2004 (pp. 11-21). Kent, UK.
Spiegler, I. (2005). Knowledge management: A
Siakas, K., Balstrup, B., Georgiadou, E., & Berki, new idea or a recycled concept? Communications
E. (2005b, April). Global software development: of the Association for Information Systems (AIS),
The dimension of culture, IADIS (International 3(14), 1-23.
Association for development of the Information
Stapleton, J. (1997). DSDM: A framework for busi-
Society). International Virtual Multi Conference
ness centred development. Addison-Wesley.
on Computer Science and Information Systems
(MCCSIS 2005)—SEA (Software Engineering Tolvanen, J.-P. (1998). Incremental method engi-
and Applications). neering with modeling tools. PhD thesis, Jyvaskyla
Studies in Computing, University of Jyvaskyla.
Siakas, K. V., Berki, E., & Georgiadou, E.
(2003). CODE for SQM: A model for cultural Vitalo, R. L., Butz, F., & Vitalo, J. (2003). Kaizen
and organisational diversity evaluation. EuroSPI desk reference standard. Lowrey Press.
2003 (European Software Process Improvement
Zahran, S. (1998). Software process improve-
Conference) (pp. IX, 1-11). Graz, Austria.
ment: Practical guidelines for business success.
Reading, MA: Addison-Wesley.

54
Agile Quality or Depth of Reasoning? Applicability vs. Suitability with Respect to Stakeholders’ Needs

APPEndIx A: AcronYMs And dEscrIPtIon


AMDD Agile Model Driven Development
ASD Adaptive Software Development
CBD Component-Based Development
CMM Capability Maturity Model
DSDM Dynamic Systems Development Method
ETHICS Effective Technical and Human Implementation of Computer-
Based Work Systems
FDD Feature Driven Development
IE Information Engineering
IS Information Systems
ISD Information Systems Development
ISDM Information Systems Development Methodology
IT Information Technology
ICT Information and Communications Technology
JSD Jackson Structured Development
NCC National Computing Centre
OMT Object Modelling Technique
SSADM Structured Systems Analysis and Design Method
SSM Soft Systems Method
STRADIS Structured Analysis and Design of Information Systems
TQM Total Quality Management
VDM Vienna Development Method
XP Extreme Programming
Z Z Specification

APPEndIx b: tHE MEtAEdIt+ tooL ArcHItEcturE


(MEtAPHor WEb sItE)

Instance of
Draw W indow
Metaedit+

Matrix Edito r

Repository
Br owser
Re pository
Meta engine
Work S pace
Transformation
Tool
Network
Hy pertext Tool
Metamodelling
Tools

Query Editor

Meta engine

55
56

Chapter III
What’s Wrong with
Agile Methods?
Some Principles and Values
to Encourage Quantification

Tom Gilb
Independent Consultant, Norway

Lindsey Brodie
Middlesex University, UK

AbstrAct

Current agile methods could benefit from using a more quantified approach across the entire imple-
mentation process (that is, throughout development, production, and delivery). The main benefits of
adopting such an approach include improved communication of the requirements, and better support for
feedback and progress tracking. This chapter first discusses the benefits of quantification, then outlines
a proposed approach (Planguage), and finally describes an example of its successful use (a case study
of the “Confirmit” product within a Norwegian organization, “FIRM”).

IntroductIon sons why a project was funded (that is, metrics


stating the required business benefits, such as
Agile software methods (Agile Alliance, 2006) business advancement, better quality of service,
have insufficient focus on quantified performance and financial savings). This means projects can-
levels (that is, metrics stating the required quali- not directly control the delivery of benefits to
ties, resource savings, and workload capacities) users and stakeholders. In turn, a consequence
of the software being developed. Specifically, of this is that projects cannot really control the
there is often no quantification of the main rea- corresponding costs of getting the main benefits.

Copyright © 2007, Idea Group Inc., distributing in print or electronic forms without written permission of IGI is prohibited.
What’s Wrong with Agile Methods? Some Principles and Values to Encourage Quantification

Figure 1. A statement made by Lord Kelvin on the importance of measurement (http://zapatopi.net/kel-


vin/quotes.html)

"In physical science the first essential step in the direction of learning any subject is to find
principles of numerical reckoning and practicable methods for measuring some quality
connected with it. I often say that when you can measure what you are speaking about, and
express it in numbers, you know something about it; but when you cannot measure it, when you
cannot express it in numbers, your knowledge is of a meagre and unsatisfactory kind; it may be
the beginning of knowledge, but you have scarcely in your thoughts advanced to the state of
Science, whatever the matter may be.”
Lord Kelvin, 1893

In other words, if you don’t estimate quantified that the explicit notion of quantification be added
requirements, then you won’t be able to get a to agile concepts.
realistic budget for achieving them. See Figure See Figure 2 for a list of the benefits to agile
1 for a scientist’s (Lord Kelvin’s) opinion on the development of using quantification.
need for numerical data!
Further, quantification must be utilized
throughout the duration of an agile project, not dEFInInG QuALItY
just to state requirements but to drive design, as-
sess feedback, and track progress. To spell this The main focus for discussion in this chapter will
last point out, quantification of the requirements be the quality characteristics, because that is where
(what do we want to control?) is only a first step most people have problems with quantification.
in getting control. The next steps, based on this A long held opinion of one of the authors of this
quantification, are design estimation (how good chapter (Tom Gilb) is that all qualities are capable
do we think our solutions are?) and measure- of being expressed quantitatively (see Figure 3).
ment of the delivered results (how good were A Planguage definition of “quality” is given in
the solutions in practice?). The key issue here is Figure 4. Planguage is a planning language and
the active use of quantified data (requirements, a set of methods developed by Tom Gilb over the
design estimates, and feedback) to drive the project last three decades (Gilb, 2005). This next part of
design and planning. the chapter will outline the Planguage approach
One radical conclusion to draw, from this lack to specifying and using quantitative requirements
of quantification, is that current conventional to drive design and determine project progress.
agile methods are not really suitable for devel-
opment of industrial products. The rationale for
this being that industry is not simply interested QuAntIFYInG rEQuIrEMEnts
in delivered “functionality” alone; they probably
already have the necessary business functions at Planguage enables capture of quantitative data
some level. Projects must produce competitive (metrics) for performance and resource require-
products, which means projects must deliver spe- ments. A scalar requirement, that is, either a
cific performance levels (including qualities and performance or resource requirement, is speci-
savings). To address this situation, it is essential fied by identifying a relevant scale of measure

57
What’s Wrong with Agile Methods? Some Principles and Values to Encourage Quantification

Figure 2. What can we do better in agile development (or “at all”) if we quantify requirements

• Simplify re is less need for copious


documentation as the developers are focused on a clearer, simpler ‘ message’ );
• Communicate quality goals much better to all parties (that is, users, customers, project
management, developers, testers, and lawyers);
• Contract f ). R eward teams for results
achieved. T his is possible as success is now measurable;
• Motivate technical people to focus on real business results;
• E valuate solutions/designs/architectures against the
• Measure evolutionary project progress towards quality goals and get early & continuous
improved estimates for time to completion;
• Collect numeric historical data about designs, processes, organizational structures for future

improvements and to benchmark against similar organizations!

and stating the current and required levels on calculated. Because the values are converted into
that scale. See Figure 5, which is an example of percentages, then simple arithmetic is possible to
a performance requirement specification. Notice calculate the cumulative effect of a design idea
the parameters used to specify the levels on the (sum of performance and sum of cost) and the
scale (that is, Past, Goal, and Fail). performance to cost ratio (see Table 1). You can
also sum across the designs (assuming the designs
are capable of being implemented together and
EVALuAtInG dEsIGns that their impacts don’t cancel each other out) to
see how much design you have that is addressing
Impact estimation (IE) is the Planguage method an individual requirement.
for evaluating designs. See Table 1, which shows Table 1 also shows how you can take into
an example of a simple IE table. The key idea of account any uncertainties in your estimates. An
an IE table is to put the potential design ideas additional feature, not shown here, is to assess the
against the quantified requirements and estimate credibility of each estimate by assigning a cred-
the impact of each design on each of the require- ibility factor between 0.0 and 1.0. Each estimate
ments. If the current level of a requirement is can then be multiplied by its credibility factor to
known (its baseline, 0%), and the target level is moderate it.
known (its goal or budget depending on whether While such simple arithmetic does not repre-
a performance requirement (an objective) or a sent the complete picture, it does give a convenient
resource requirement respectively, 100%), then means of quickly identifying the most promising
the percentage impact of the design in moving design ideas. Simply filling in an IE table gives a
towards the performance/resource target can be

Figure 3. Tom Gilb’s opinion that all qualities can be expressed numerically

The Principle of “Quality Quantification”


All qualities can be expressed quantitatively, “qualitative” does not mean unmeasurable.
Tom Gilb

58
What’s Wrong with Agile Methods? Some Principles and Values to Encourage Quantification

Figure 4. Planguage definition of “quality”

Definition of Quality
Quality is characterized by these traits:
• A quality describes ‘how well’ a function is done. Qualities each describe the partial
effectiveness of a function (as do all other performance attributes).
• Relevant qualities are either valued to some degree by some stakeholders of the system - or
they are not relevant. Stakeholders generally value more quality, especially if the increase is free,
or lower cost than the stakeholder-perceived value of the increase.
• Quality attributes can be articulated independently of the particular means (the designs and
architectures) used for reaching a specific quality level, even though achievement of all quality
levels depend on the particular designs used to achieve quality.
• A particular quality can potentially be a described in terms of a complex concept, consisting of
multiple elementary quality concepts, for example, ‘Love is a many-splendored thing!’
• Quality is variable (along a definable scale of measure: as are all scalar attributes).
• Quality levels are capable of being specified quantitatively (as are all scalar attributes).
• Quality levels can be measured in practice.
• Quality levels can be traded off to some degree; with other system attributes valued more by
stakeholders.
• Quality can never be perfect (no fault and no cost) in the real world. There are some valued
levels of a particular quality that may be outside the state of the art at a defined future time and
circumstance. When quality levels increase towards perfection, the resources needed to support
those levels tend towards infinity.
(Gilb 2005)

much better understanding of the strengths and • That a system is developed in a series of
weaknesses of the various designs with respect small increments (each increment typically
to meeting all the requirements. taking between 2% and 5% of the total project
Table 1 simply shows estimates for potential timescale to develop).
design ideas. However, you can also input the ac- • That each increment is delivered for real use
tual measurements (feedback) after implementing (maybe as Beta or Field trial) by real “us-
the design ideas. There are two benefits to this: ers” (any stakeholder) as early as possible
you learn how good your estimates were for the (to obtain business benefits and feedback,
design ideas implemented, and you learn how as soon as possible).
much progress you have made towards your target • That the feedback from implementing the
levels. You can then use all the IE table data as a Evo steps is used to decide on the contents
basis to decide what to implement next. of the next Evo step.
• That the highest value Evo steps are delivered
earliest, to maximize the business benefit.
EVoLutIonArY dELIVErY
Note that “delivery” of requirements is the key
The final Planguage method we will discuss is consideration. Each delivery is done within an Evo
evolutionary project management (Evo). Evo step. It may, or may not, include the building or
demands include the following:

59
What’s Wrong with Agile Methods? Some Principles and Values to Encourage Quantification

Figure 5. Example showing Planguage parameters used to specify a performance requirement: “Screen
Usability.”
Tag: Screen Usability.
Scale: The average number of errors per thousand defined [Transactions] made by system users.
Meter: System to maintain counts for the <different types of error messages> sent to screen.
Past [Order Entry]: 531 ← As measured by Order Entry Department using existing system.
Goal [Order Entry]: < 200 ← Sales Manager.
Fail [Order Entry]: > 400 ← Sales Manager.

Table 1. An example of a simple IE table (Gilb, 2005)


Design Ideas-> Idea 1 Idea 2 Sum for Sum of
Impact Impact Requirement Percentage Safety
Estimates Estimates (Sum of Uncertainty Deviation
Requirements: Percentage Values
Goals and Budgets Impacts)

Reliability 1950hr 1140hr


300 <-> 3000 hours MTBF (1650hr) (840hr)
±0 ±240 92% ±9% -108%
61%±0 31%±9%
Usability 19min. 14min.
20 <-> 10 minutes (1min.) (6 min.)
±4 ±9 70% ±130% -130%
10%±40% 60%±90%
Maintenance 1.1M $/Y 100K S/Y
1.1M <-> 100K/year US$ (0 K$/Y) (1 M$/Y)
±180K ±720K 100% ±90% -50%
0%± 18% 100%±72%
Sum of Performance 71% 191%
Capital 500K 100K
0 <-> 1 million US$ (500K) (100K)
±200K ±200K 60% ±40% -10%
50%±20 10%±20
Sum of Costs 50% 10%
Performance to Cost Ratio 1.42 19.10
(71/50) (191/10)

creation of the increment (some Evo steps may be some increments that have longer lead-times
simply be further rollout of existing software). for development, and so their development will
Development of necessary components will need to start early in anticipation of their future
occur incrementally, and will be continuing in use. A project manager should always aim to “buf-
parallel while Evo steps are being delivered to fer” his developers in case of any development
stakeholders. Most development will only start problems by having in reserve some components
when the decision has been taken to deliver it as ready for delivery.
the next Evo step. However, there probably will

60
What’s Wrong with Agile Methods? Some Principles and Values to Encourage Quantification

Planguage Approach to change • Reliable:


• Scale: Mean Time Between Failure.
It is important to note that the quantified require- • Goal: 1 month.
ments, designs, and implementation plans are
not “frozen,” they must be subject to negotiated 3. Define approximately four budgets for your
change over time. As Beck points out, “Everything most limited resources (for example, time,
in software changes. The requirements change. people, money, and equipment).
The design changes. The business changes. The 4. Write up these plans for the goals and bud-
technology changes. The team changes…The gets (Try to ensure this is kept to only one
problem isn’t change, per se,…the problem, page).
rather, is the inability to cope with change when 5. Negotiate with the key stakeholders to for-
it comes” (Beck, 2000). mally agree the goals and budgets.
Planguage’s means of dealing with change 6. Draw up a list of initial design ideas: En-
are as follows: sure that you decompose the design ideas
down into the smallest increments that can
• Performance and resource requirements are be delivered (these are potential Evo steps).
quantified to allow rapid communication of Use impact estimation (IE) to evaluate your
any changes in levels. design ideas’ contributions towards meeting
• IE tables allow dynamic reprioritization of the requirements. Look for small incre-
design ideas and help track progress towards ments with large business value. Note any
targets. dependencies, and draw up an initial rough
• Evo enables all types of change to be catered Evo plan, which sequences the Evo steps. In
for “in-flight” as soon as possible. There is practice, decisions about what to deliver in
regular monitoring of the best next Evo step the next Evo step will be made in the light
to take. of feedback (that is when the results from
the deliveries of the previous Evo steps are
known). Plan to deliver some value (that
dEscrIPtIon oF tHE is, progress towards the required goals) in
PLAnGuAGE ProcEss weekly (or shorter) increments (Evo steps).
Aim to deliver highest possible value as
To summarize and show how the methods (for soon as possible.
quantifying requirements, evaluating designs, 7. Deliver the project in Evo steps.
and evolutionary delivery) described earlier in
this chapter fit together, here is a description of • Report to project sponsors after each Evo
the Planguage process for a project: step (weekly or shorter) with your best
available estimates or measures, for each
1. Gather from all the key stakeholders the performance goal, and each resource
top few (5 to 20) most critical goals that budget. On a single page, summarize
the project needs to deliver. Give each goal the progress to date towards achieving
a reference name (a tag). the goals and the costs incurred.
2. For each goal, define a scale of measure and • Discuss with your project sponsors and
a “final” goal level. For example: stakeholders what design ideas you

61
What’s Wrong with Agile Methods? Some Principles and Values to Encourage Quantification

should deliver in the next Evo step. This quently, FIRM used these methods in the develop-
should be done in the light of what has ment of their Confirmit product. The results were
been achieved to date and what is left impressive, so much so that they decided to write
to do. Maximizing the business benefit up their experiences (Johansen, 2004). In this
should be the main aim. section, some of the details from this Confirmit
product development project are presented.
8. When all goals are reached: “Claim success
and move on.” Free remaining resources for use of Planguage Methods
more profitable ventures.
First, 25 quantified requirements were speci-
fied, including the target levels. Next, a list of
cAsE studY oF tHE potential design ideas (solutions) was drawn up
“conFIrMIt” Product (see Figure 8 for an example of an initial design
idea specification).
Tom Gilb and his son, Kai taught the Planguage The impacts of the potential design ideas on
methods to FIRM (future information research the requirements were then estimated. The most
management), a Norwegian organization. Subse- promising design ideas were included in an Evo

Figure 6. Planguage’s 10 values for an agile project based around Beck’s four values for XP (Beck,
2000, p. 29)

Ten Planguage Values for an Agile Project


Simplicity
1. Focus on real stakeholder values.
Communication
2. Communicate stakeholder values quantitatively.
3. Estimate expected results and costs for weekly steps.
Feedback
4. Generate useful results weekly, to stakeholders, in their environment.
5. Measure all critical aspects of the attempt to generate incremental results.
6. Analyze deviation from initial estimates.
Courage
7. Change plans to reflect weekly learning.
8. Immediately implement valued stakeholder needs, next week.
Don’t wait, don’t study (‘analysis paralysis’), and don’t make excuses. Just Do It!
9. Tell stakeholders exactly what you will deliver next week.
10. Use any design, strategy, method, process that works quantitatively well - to get your
results. Be a systems engineer, not just a programmer. Do not be limited by your ‘craft’
background in serving your paymasters.

62
What’s Wrong with Agile Methods? Some Principles and Values to Encourage Quantification

Figure 7. Planguage policy for project management

Planguage Project Management Policy


• The project manager and the project will be judged exclusively on the relationship of
progress towards achieving the goals vs. the amounts of the budgets used.
• The project team will do anything legal and ethical to deliver the goal levels within the
budgets.
• The team will be paid and rewarded for benefits delivered in relation to cost.
• The team will find their own work process and their own design.
• As experience dictates, the team will be free to suggest to the project sponsors (stakeholders)
adjustments to “more realistic levels” of the goals and budgets.

plan, which was presented using an impact esti- 2. The team selected the design ideas they
mation (IE) table (see Tables 2 and 3, which show believed would help them reach the quality
the part of the IE table applying to Evo Step 9. requirement levels in the next cycle.
Note these tables also include the actual results 3. The team implemented their chosen design
after implementation of Evo Step 9). The design ideas and measured the results.
ideas were evaluated with respect to “value for 4. The results were input into the IE table.
clients” vs. “cost of implementation.”. The ones Each next Evo step was then decided based
with the highest value-to-cost ratio were chosen for on the results achieved after delivery of the
implementation in the early Evo steps. Note that subsequent step.
value can sometimes be defined by risk removal
(that is, implementing a technically challenging Note, the impacts described for Confirmit 8.0
solution early can be considered high value if (the baseline (0%) “Past” levels) are based on
implementation means that the risk is likely to direct customer feedback and internal usability
be subsequently better understood). The aim was tests, productivity tests, and performance tests
to deliver improvements to real external stake- carried out at Microsoft Windows ISV laboratory
holders (customers, users), or at least to internal in Redmond USA. The actual results were not
stakeholders (for example, delivering to internal actually measured with statistical accuracy by
support people who use the system daily and so doing a scientifically correct large-scale survey
can act as “clients”). (more intuitive methods were used).
An IE table was used as a tool for controlling
the qualities; estimated figures and actual mea- the results Achieved
surements were input into it.
On a weekly basis: Due to the adoption of Evo methods, there were
focused improvements in the product quality lev-
1. A subset of the quality requirements (the 25 els. Table 4 gives some highlights of the 25 final
quality requirements defined initially, for quality levels achieved for Confirmit 8.5. Table 5
delivery after 12 weeks to customers) was gives an overview of the improvements by func-
selected to work on by one of four parallel tion (that is, product component) for Confirmit
teams. 9.0. No negative impacts are hidden. The targets
were largely all achieved on time.

63
What’s Wrong with Agile Methods? Some Principles and Values to Encourage Quantification

Figure 8. A brief specification of the design idea “Recoding”

Recoding:
Type: Design Idea [Confirmit 8.5].
Description: Make it possible to recode a marketing variable, on the fly, from Reportal.
Estimated effort: four team days.

Table 2. A simplified version of part of the IE table shown in Table 3. It only shows the objective, “pro-
ductivity” and the resource, “development cost” for Evo Step 9, “recoding” of the marketing research
(MR) project. The aim in this table is to show some extra data and some detail of the IE calculations.
Notice the separation of the requirement definitions for the objectives and the resources. The Planguage
keyed icon “<->” means “from baseline to target level.” On implementation, Evo Step 9 alone moved
the productivity level to 27 minutes, or 95% of the way to the target level

EVO STEP 9: DESIGN IDEA: “Recoding”


Estimated Scale Estimated Actual Actual
Level % Impact Scale Level % Impact
REQUIREMENTS
Objectives
Usability.Productivity
65 <-> 25 minutes
65 – 20 = 50% 65 - 38 = 95%
Past: 65 minutes. 45 minutes 27 minutes
Tolerable: 35 minutes.
Goal: 25 minutes.
Resources
Development Cost
0 <-> 110 days 4 days 3.64% 4 days 3.64%

The customers responded very favorably (see Impact on the developers


Figure 9).
On the second release (Confirmit 9.0) using Use of Evo has resulted in increased motivation
Planguage, and specifically the Evo method, the and enthusiasm amongst the FIRM developers
Vice President (VP) of marketing proudly named because it has opened up “empowered creativity”
the Evo development method on the FIRM Web (Trond Johansen, FIRM Project Director). The
site (see Figure 10. A line executive bragging developers can now determine their own design
about a development method is somewhat ex- ideas and are not subject to being dictated the
ceptional!). design ideas by marketing and/or customers who
Details of the quantified improvements were often tend to be amateur technical designers.
also given to their customers (see Figure 11, which Daily, and sometimes more often, product
is an extract from the product release for Confirmit builds, called continuous integration (CI), were
9.0 published on the organization’s Web site). introduced. Evo combined with CI, is seen as

64
What’s Wrong with Agile Methods? Some Principles and Values to Encourage Quantification

Table 3. Details of the real IE table, which was simplified in Table 2. The two requirements expanded in
Table 1 are highlighted in bold. The 112.5 % improvement result represents a 20-minute level achieved
after the initial 4-day stint (which landed at 27 minutes, 95%) . A few extra hours were used to move
from 27 to 20 minutes, rather than use the next weekly cycle.

Current Improvements Goals Step 9


Status Design = ‘Recoding’
Estimated impact Actual impact
Units Units % Past Tolerable Goal Units % Units %
Usability.Replaceability (feature count)
1.00 1.0 50.0 2 1 0
Usability.Speed.New Features Impact (%)
5.00 5.0 100.0 10 15 5
10.00 10.0 66.7 20 15 5
40.00 0.0 0.0 40 30 10
Usability.Intuitiveness (%)
0.00 0.0 0.0 0 60 80
Usability.Productivity (minutes)
20.00 45.0 112.5 65 35 25 20.00 50.00 38.00 95.00

Development resources
101.0 91.8 0 110 4.00 3.64 4.00 3.64

Table 4. Improvements to product quality levels in Confirmit 8.5

DESCRIPTION OF REQUIREMENT / WORK TASK PAST CURRENT


STATUS

Usability.Productivity: Time for the system to generate a survey. 7200 sec 15 sec
Usability.Productivity: Time to set up a typical specified Market Research (MR) 65 min 20 min
report.
Usability.Productivity: Time to grant a set of End-users access to a Report set and 80 min 5 min
distribute report login info.
Usability.Intuitiveness: The time in minutes it takes a medium experienced 15 min 5 min
programmer to define a complete and correct data transfer definition with Confirmit
Web services without any user documentation or any other aid.
Workload Capacity.Runtime.Concurrency: Maximum number of simultaneous 250 users 6000 users
respondents executing a survey with a click rate of 20 seconds and a response time
< 500 milliseconds, given a defined (Survey-Complexity) and a defined (Server
Configuration, Typical).

65
What’s Wrong with Agile Methods? Some Principles and Values to Encourage Quantification

Table 5. Some detailed results by function (product component) for Confirmit 9.0
FUNCTION PRODUCT DEFINITION (quantification) CUSTOMER
QUALITY VALUE
Authoring Intuitiveness Probability that an inexperienced user can Probability increased
intuitively figure out how to set up a defined by 175%
simple survey correctly. (30% to 80%)
Authoring Productivity Time in minutes for a defined advanced Time reduced by
user with full knowledge of Confirmit 9.0 38%
functionality to set up a defined advanced
survey correctly.
Reportal Performance Number of responses a database can contain if Number of responses
the generation of a defined table should be run increased by 1400%
in 5 seconds.
Survey Engine Productivity Time in minutes to test a defined survey and Time reduced by
identify four inserted script errors, starting 83% and error
from when the questionnaire is finished tracking increased
to the time testing is complete and ready by 25%
for production. (Defined Survey: Complex
Survey, 60 questions, comprehensive
JScripting.)
Panel Performance Maximum number of panelists that the system Number of panelists
Management can support without exceeding a defined time increased by 1500%
for the defined task with all components of the
panel system performing acceptably.
Panel Scalability Ability to accomplish a bulk-update of X Number of panelists
Management panelists within a timeframe of Z seconds. increased by 700%
Panel Intuitiveness Probability that a defined inexperienced user Probability increased
Management can intuitively figure out how to do a defined by 130%
set of tasks correctly.

Figure 9. An example of pilot customer (Microsoft) feedback


“I just wanted to let you know how appreciative we are of the new ‘entire report’ export
functionality you recently incorporated into the Reportal. It produces a fantastic looking report,
and the table of contents is a wonderful feature. It is also a HUGE time saver.”

a vehicle for innovation and inspiration. Every Initial Difficulties in Implementing


week, the developers get their work out onto the Planguage
test servers and receive feedback.
By May 2005, FIRM had adopted the approach Even though Planguage was embraced, there were
of using a “Green Week” once monthly. In a parts of Planguage that were initially difficult to
Green Week, the internal stakeholders are given understand and execute at first. These included:
precedence over the client stakeholders and can
choose what product improvements they would • Defining good requirements (“Scales” of
like to see implemented. The FIRM developers measure) sometimes proved hard (they only
chose to focus on the evolutionary improvement had one day training initially, but after the
of about 12 internal stakeholder qualities (such first release saw the value in a week’s train-
as testability and maintainability). ing!).

66
What’s Wrong with Agile Methods? Some Principles and Values to Encourage Quantification

Figure 10. Comments by FIRM’s VP of marketing, Kjell Øksendal

“FIRM, through evolutionary development, is able to substantially increase customer value by


focusing on key product qualities important for clients and by continuously asking for their
feedback throughout the development period. Confirmit is used by the leading market research
agencies worldwide and Global 1000 companies, and together, we have defined the future of
online surveying and reporting, represented with the Confirmit 9.0.”

Figure 11. Confirmit 9.0 release announcement from the FIRM Web site (http://www.firmglobal.com).
It gives detail about the method and the quantified product results

News release

2004-11-29: Press Release from FIRM

New version of Confirmit increases user productivity up to 80 percent

NOVEMBER 29th, 2004: FIRM, the world’s leading provider of online survey & reporting software, today
announced the release of a new version of Confirmit delivering substantial value to customers including increased
user productivity of up to 80 percent.

FIRM is using Evolutionary (EVO) development to ensure the highest focus on customer value through early and
continuous feedback from stakeholders. A key component of EVO is measuring the effect new and improved
product qualities have on customer value. Increased customer value in Confirmit 9.0 includes:

* Up to 175 percent more intuitive user interface*


* Up to 80 percent increased user productivity in questionnaire design and testing*
* Up to 1500 percent increased performance in Reportal and Panel Management*

• It was hard to find “Meters” (that is, ways was mainly a test synchronization problem
of measuring numeric qualities, to test the they quickly overcame).
current developing quality levels), which • Testing was sometimes “postponed” in order
were practical to use, and at the same time to start the next step. Some of these test
measured real product qualities. postponements were then not in fact done
• Sometimes it took more than a week to de- in later testing.
liver something of value to the client (this

67
What’s Wrong with Agile Methods? Some Principles and Values to Encourage Quantification

Lessons Learned with respect to • Demonstrate new functionality automati-


Planguage, Especially the Evo cally with screen recording software or early
Method test plans. This makes it easier for internal
and external stakeholders to do early test-
Some of the lessons learned about the use of ing.
Planguage, and especially the Evo method, in- • Tighter integration between Evo and the test
cluded: process is necessary.

• Planguage places a focus on the measurable conclusion of the case study


product qualities. Defining these clearly and
testably requires training and maturity. It is The positive impacts achieved on the Confirmit
important to believe that everything can be product qualities has proved that the Evo process
measured and to seek guidance if it seems is better suited than the waterfall process (used
impossible. formerly) to developing the Confirmit product.
• Evo demands dynamic re-prioritization of Overall, the whole FIRM organization em-
the next development steps using the ratio braced Planguage, especially Evo. The first re-
of delivering value for clients vs. the cost lease, Confirmit 8.5, showed some of Planguage’s
of implementation. Data to achieve this is great potential. By the end of November 2004
supplied by the weekly feedback. The great- with the second release (Confirmit 9.0), there was
est surprise was the power of focusing on confirmation that the Evo method can, consistently
these ratios. What seemed important at the and repetitively, produce the results needed for
start of the project may be replaced by other a competitive product. Releases 9.5 and 10.0 of
solutions based on gained knowledge from Confirmit continued this pattern of successful
previous steps. product improvements delivered to the customers
• An open architecture is a pre-requisite for (as of November 2005).
Evo. It is expected that the next versions of Confirmit
• Management support for changing the will show even greater maturity in the understand-
software development process is another ing and execution of Planguage. The plan is to
pre-requisite, but this is true of any software continue to use Planguage (Evo) in the future.
process improvement.
• The concept of daily builds, CI, was valuable
with respect to delivering a new version of cHAPtEr suMMArY
the software every week.
• It is important to control expectations. “Be Use of quantified requirements throughout the
humble in your promises, but overwhelm- implementation of a project can provide many
ing in your delivery” is a good maxim to benefits as has been demonstrated by the FIRM
adopt. organization’s use of Planguage (including
• There needed to be increased focus on Evo).
feedback from clients. The customers will- The key messages of this chapter can be sum-
ing to dedicate time to providing feedback marized in 12 Planguage principles (see Figure 12).
need identifying. Internal stakeholders (like By adopting such principles, agile methods would
sales and help desk staff) can give valuable be much better suited for use in the development
feedback, but some interaction with the of industrial products.
actual customers is necessary.

68
What’s Wrong with Agile Methods? Some Principles and Values to Encourage Quantification

Figure 12. Twelve Gilb Planguage principles for project management/software development

Twelve Planguage Principles


1. Control projects by a small set of quantified critical results (that is, not stories, functions,
features, use cases, objects, etc.). Aim for them to be stated on one page!
2. Make sure those results are business results, not technical.
3. Align your project with your financial sponsor’s interests!
4. Identify a set of designs. Ensure you decompose the designs into increments of the smallest
possible deliverables.
5. Estimate the impacts of your designs, on your quantified goals.
6. Select designs with the best performance to cost ratios; do them first.
7. Decompose the workflow and/or deliveries, into weekly (or 2% of budget) time boxes.
8. Give developers freedom, to find out how to deliver those results.
9. Change designs, based on quantified experience of implementation (feedback).
10. Change requirements, based in quantified experience (new inputs).
11. Involve the stakeholders, every week, in setting quantified goals.
12. Involve the stakeholders, every week, in actually using increments.

rEFErEncEs Johansen, T. (2004). FIRM: From waterfall to


evolutionary development (Evo) or how we rap-
Agile Alliance. (2006). Retrieved June 2006, from idly created faster, more user-friendly, and more
http://www.agilealliance.com/ productive software products for a competitive
multi-national market. Proceedings of Euro-
Beck, K. (2000). Extreme programming ex- pean Software Process Improvement (EuroSPI),
plained: Embrace change. Addison-Wesley. Trondheim, Norway, November 10-12, 2004. In T.
Gilb, T. (2005). Competitive engineering: A Dingsøyr (Ed.), Lecture Notes in Computer Sci-
handbook for systems engineering. Requirements ence 3281, Springer 2004. See also Proceedings
engineering, and software engineering using of INCOSE 2005 (Johansen and Gilb 2005) and
Planguage. Elsevier Butterworth-Heinemann. FIRM Website, http://www.confirmit.com/news/
release_20041129_confirmit_9.0_mr.asp/ (Last
Accessed: June 2006).

69
What’s Wrong with Agile Methods? Some Principles and Values to Encourage Quantification

Section II
Quality within
Agile Development

70
71

Chapter IV
Requirements Specification
using User Stories
V. Monochristou
IT Consultant, GNOMON, Informatics, S. A., Greece

M. Vlachopoulou
University of Macedonia, Greece

AbstrAct

Collecting and analyzing user requirements is undoubtedly a really complicated and often problematic
process in software development projects. There are several approaches, which suggest ways of manag-
ing user’s requirements; some of the most well-known are IEEE 830 software requirements specification
(SRS), use cases, interaction design scenarios, etc. Many software experts believe the real user require-
ments emerge during the development phase. By constantly viewing functional sub-systems of the whole
system and participating, in fact, in all phases of system development, customers/users can revise their
requirements by adding, deleting, or modifying them. However, in order for this to become possible, it
is important to adopt a totally different approach than the traditional one (waterfall model approach),
concerning not only the management of user’s requirements, but also the entire software development
process in general. Agile methodologies represent this different approach since the iterative and in-
cremental way of development they propose includes user requirements revision mechanisms and user
active participation throughout the development of the system. The most famous approach concerning
requirements specification among the supporters of the agile methodologies is probably user stories.
User stories and their main characteristics are thoroughly demonstrated in this chapter. After reading
this chapter, the authors hope that the reader may have gained all the basic understanding regarding
the use of user stories.

Copyright © 2007, Idea Group Inc., distributing in print or electronic forms without written permission of IGI is prohibited.
Requirements Specification using User Stories

IntroductIon • Even if the developers identify all the re-


quirements from the beginning, many of
Collecting and analyzing user requirements the necessary details will appear during the
is undoubtedly a really complicated and often development of the system.
problematic “process” in software development • Even if all the necessary details could be
projects. There are several approaches, which known up-front, humans are incapable of
suggest ways of managing user’s requirements; comprehending so many details.
some of the most well known are IEEE 830 soft- • Even if humans were capable of compre-
ware requirements specification (SRS), use cases, hending all the details, product and project
interaction design scenarios, etc. changes occur.
The success of the final product depends • People make mistakes.
mainly on the success of the previous “process.”
But how is this “success” defined? Some suggest Many software experts believe that the real user
that the main indicator of success is the compliance requirements emerge during the development of
of the final product with the initially documented a system. By constantly viewing functional sub-
requirements of the customer/user. However, is systems of the whole system, and participating in
it plausible to document the real requirements of fact in all phases of system development, a user
the customer/user when the entire specification can revise his or her requirements by adding, de-
“process” starts and ends before the software leting, or modifying them. However, in order for
development has even started? In addition, this to become possible, it is important to adopt
after completing this “process,” these up-front a totally different approach than the traditional
documented requirements are “locked” without one (waterfall model approach), concerning not
any chance of revision due to the fact that they only the management of user’s requirements, but
are often used as the main part of contractual also the entire software development process as a
agreements. whole. Agile methodologies represent this differ-
A 2001 study performed by M. Thomas (2001) ent approach since the iterative and incremental
in the UK analyzing 1,027 projects showed that way of development they propose includes user
82% of failed projects report the use of waterfall requirements revision mechanisms and user ac-
practices as number one cause of failure, includ- tive participation throughout the development of
ing detailed, up-front requirements. Moreover, the system.
a Standish group study presented at XP2002
Conference by Jim Johnson reports that when Rather than making one all-encompassing set
requirements are specified early in the lifecycle, of decisions at the outset of a project, we spread
45% of features are never used, 19% are rarely the decision-making across the duration of the
used, and 16% are sometimes used. project. (Cohn, 2004)
Since 1986, Parnas and Clements (1986) al-
leged that it is extremely difficult to write down User stories is probably the most famous ap-
all the requirements of a system up-front and then proach concerning requirements specification
to develop it perfectly. Mainly this is because: among the supporters of the agile methodologies.
User stories and their main characteristics are
• Users and customers do not usually distin- thoroughly demonstrated in this chapter.
guish exactly from the beginning what they It has to be stressed that due to their recent
want. appearance, the available bibliography concern-
ing the user stories is not so extensive. One of the

72
Requirements Specification using User Stories

most detailed and solid analysis on user stories set up procedures that limit requirements changes
is Cohn’s (2004) User Stories Applied: For Agile after the sign-off. (Fowler, 2005)
Software Development, a book that was the in-
spiration and also the main source of knowledge By using the traditional approach, require-
and understanding for this chapter. ments documents produced are (Davies, 2005):

• Unidirectional: Documents are a one-way


bAcKGround communication medium. After capturing the
requirements, usually through interviews,
the traditional Approach: information flows from author (usually a
common Pitfalls business analyst) to reader (customer/user).
Customer/user has little or no opportunity to
“Οn traditional software development projects feedback (asks questions, contributes ideas
we talk about capturing the requirements as if we and insights). On the other hand, documents
are engaged in a hunt to cage some wild beasts may not be as precise as they should be
that lurk in the jungle” (Cohn, 2004). Davies causing misleads to the development team.
(2005) further alleges that “Requirements are When working under time-pressure, the
not out there in the project space and waiting to development team may have to make its own
be captured.” assumptions on the intended meaning, and
A traditional requirements specification docu- this can lead to the development of wrong
ment describes the functionalities of a desired functionalities in the software system.
software system and acts as both means of com- • Selective: Documents usually include the
munication and data storage. The overall goal author’s (usually a business analyst) per-
of this document is to provide all the necessary sonal perspective on the system. Following
information to the development team so as to traditional development process, it is as-
implement an executable software system, which sumed that the development team does not
complies with written user requirements. need to know much about the users’ needs
The traditional approach (based mainly on and the business environment affecting the
the waterfall software life cycle) is to specify system development since requirements are
the requirements for the whole system up front. chosen purely on business grounds. The
That means that both customer/user and the development team is limited to the techni-
development team have to gain a complete cal implementation of the system rather
understanding of the final system in the begin- than contributing ideas on how to achieve
ning of the development phase. Moreover, these business values.
requirements are “locked” and can not be altered • Freezing: The traditional approach is to
during the implementation of the system. In this specify the requirements for the whole
case, requirements documents are used either as a system up-front and then “lock” the require-
contract model or as a tool of solving any disputes ments. This approach does not take into
or misunderstandings. account the constantly and rapidly altered
technological and business environment.
The idea behind requirements engineering is to As Davis (2005) says, “When we freeze
get a fully understood picture of the requirements requirements early, we deny the chance to
before you begin building the software, get a adapt the system to a changing context.”
customer sign-off to these requirements, and then

73
Requirements Specification using User Stories

Fowler (2005) mentions the “unpredictability the Agile Approach


of requirements,” According to this, requirements
are always changing and this is the norm for three Agile methods are based on quite a different ap-
main reasons: proach that includes:

1. Difficulties on estimation: Resulting main- • Iterative development (small versions of the


ly from the fact that software development system with a subset of the required features
is a design activity, and thus hard to plan in short development cycles).
and estimate the cost, but also from the fact • Customer collaboration (customer in fact
that it depends on which individual people participates in all phases of software imple-
are involved. Therefore, it is hard to predict mentation).
and quantify. • Constant communication (daily face-to-
2. Software’s intangible nature: The real face communication between project team
value of a software feature is discovered members).
when the user sees and probably uses early • Adaptability (last minute changes are al-
versions of the software. At this time, the lowed).
customer/user is more likely to understand
what features are valuable and which ones It is also important to mention that one of the
are not. It is more than obvious that this agile manifesto’s principles states: “Welcome
“process” can cause changes in the initially changing requirements, even late in development.
agreed requirements. Agile processes harness change for the customer’s
3. Business’s environment changing nature: competitive advantage.”
Today, and especially during the last decade, This principle is one of the most important
business environments and the fundamental arguments against agile methodologies. The crit-
business forces are changing too fast, re- ics insist that something like this is practically
sulting in constant changes to the software impossible to be effective in a software project
features. “What might be a good set of because any important change that needs to be
requirements now, is not a good set in six done in a final stage is simply impossible; and
months time. Even if the customers can fix even if it was possible, the total cost and time
their requirements, the business world isn’t required would be increased excessively.
going to stop for them” (Fowler, 2005). From their point of view, “agilists” argue that
since the requirements are not crystal-clear at
Supporters of the agile software development the beginning of any project but they essentially
methods strongly believe that development teams emerge during development, the appropriate
should take into consideration the unpredictability “environment” needs to be created so that the
of requirements. As predictability of requirements acceptance of new or modified requirements (even
may be a rare reality (with the exception of some in final stages) should be possible.
projects for organisations [e.g., NASA, Army] Using agile methods, system features are built
where predictability is vital), they insist that a iteratively and incrementally. Small versions of
more adaptive approach should be followed. the system are continuously presented to the
customer/user, so as to use his or her feedback to
refine the system in the next iteration. Following

74
Requirements Specification using User Stories

this process, “agilists” believe that user require- • Training on the techniques: Everyone in the
ments emerge during the project. development team, including project stake-
Iterative development allows the development holders, should have a basic understanding
team to deal with changes in requirements. This of the requirements modeling techniques.
presupposes that plans are short term and refer This implies that stakeholders should gain,
to a single iteration. At the end of each iteration, primarily, a broad understanding why these
the team, with the participation of the customer, techniques are utilized and in which way.
plans the next iteration and the required features/ • Adoption of stakeholder terminology:
requirements to be included in that iteration. Technical terminology and jargon should
The agile requirements approach includes a be avoided as it may prove to be difficult for
number of practices that differentiate it from the stakeholders to comprehend. Stakeholders’
traditional one. Based on Ambler (2005a), the participation cannot be fully accomplished
agile approach embraces among others: if their terminology (business terminology)
is not used. As Constantine and Lockwood
• Active stakeholder participation: The (1999) say, “avoid geek-speak.”
stakeholder participates in the requirements
process by writing and prioritizing require- At this point, it is very important to mention
ments, and by providing domain knowledge that applying agile methods in a project for the
and information to the developers. “Your first time implies a cultural change for most
project stakeholders are the requirements organisations. The adoption of agile methods
experts” (Ambler, 2005a). presupposes a new way of project management
• Take a breadth-first approach: Instead and every day business operations for the cus-
of the big modeling up-front (BMUF) ap- tomer, totally different from the traditional one.
proach, agilists suggest that it is better to at- Without the genuine support of senior manage-
tempt to obtain a wider picture of the system ment, active stakeholder participation will likely
in the beginning, trying to quickly gain an not be successful, jeopardizing the success of the
overall understanding of the system. Details overall project.
can be added later when it is appropriate.
• Lean documentation: Instead of compre-
hensive documentation that requires a lot usEr storIEs
of effort and has doubtable results, agilists
consider that a more lean approach, where A short description
documentation is as simple as it can pos-
sibly be, is more appropriate for software User stories are one of the primary development
development. In fact, agilists suggest that artifacts for extreme programming (XP) project
the development team should create docu- teams. They are brief descriptions of features
mentation only when it is necessary, and containing just enough information for the de-
with the precondition that “the benefit of velopers to produce a reasonable estimate of the
having documentation is greater than the effort to implement it.
cost of creating and maintaining it” (Ambler, XP creator Beck (2000) defines a user story
2005b). as: “One thing the customer wants the system to
• Small requirements: Small requirements do. Stories should be estimable at between one
are much easier to understand, estimate, to five ideal programming weeks. Stories should
prioritize, build, and therefore manage. be testable. Stories need to be of a size that you

75
Requirements Specification using User Stories

can build a few of them in each iteration” (Beck Using Jeffries terminology (2001), stories in
& Fowler, 2000). XP have three components: Cards (their physi-
User stories are unstructured sentences written cal medium), Conversation (the discussion sur-
by the customer with a title and a short paragraph rounding them), and Confirmation (tests that
describing the purpose of the story, without techni- verify them).
cal terms, aiming to define what a proposed system Typically, the stories are written on 8×13cm
needs to do for them. They focus on user/business paper index cards, although an electronic copy may
needs, goals, and benefits. be used. Lately, some software tools like XPlan-
An interesting definition is also the one given ner, VersionOne, TargetProcess, Rally, and Select
by Wake (2003): “A pidgin language is a simpli- Scope Manager, have appeared, but also in-house
fied language, usually used for trade, that allows tools based on Microsoft Access are referenced.
people who can’t communicate in their native lan- On the other hand, more generic software such
guage to nonetheless work together. User stories as spreadsheets and defect trackers can be used.
act like this. We don’t expect customers or users Some examples of user stories follow:
to view the system the same way that program- Story card 2 includes also some indicative
mers do; stories act as a pidgin language where acceptance tests.
both sides can agree enough to work together
effectively.” user stories and “the Planning
Another way to view a user story is that it’s Game”
a reminder for a future conversation between
the customer and developers. This conversation As it is mentioned previously, user stories are
takes place usually during iteration planning used for summarizing user’s required features
meeting where the customer/user together with in extreme programming (XP). According to
the development team are discussing the details Wake (2002, p. 2), an XP project has three main
of the stories chosen to be included in the cur- phases:
rent iteration.
Furthermore, in every user story, one or 1. “A release planning phase, where the
more acceptance tests are written down, so as customer writes stories, the programmers
to verify that the user story has been correctly estimate them, and the customer chooses the
implemented. order in which stories will be developed;

Figure 1. Example story card 1

A doctor can seach for a Patient’s Medical Record (PMR) by Name, Personal ID
Number, and National Security Number.

Figure 2. Example story card 2

A doctor can edit a PMR only by inserting an extra passwork.

• Try to open a PMR by leaving the password field empty


• Try to open a PMR by using an invalid password

76
Requirements Specification using User Stories

2. An iteration phase, where the customer 2002). Story points can also be estimated
writes tests and answers questions, while in terms of an ideal hour of work, an ideal
the programmers program; and week of work, or as a measure of their rela-
3. A release phase, where the programmers tive complexity (i.e., story A is 2 times more
install the software and the customer ap- complex than story B).
proves the result.” • Development team estimates how much
effort (story points) can be completed in a
More specifically, user stories are a central single iteration (given time interval). The
part of the “Planning game,” one of the 12 core term velocity is used in this case. It has to
practices of XP, whose purpose is to rapidly be stressed that the team’s velocity defines
develop a high-level plan for the next release or the total productivity (in terms of story
iteration. The customer and development team points) of a specific development team in
cooperate to produce the maximum business a particular iteration, excluding possible
value as rapidly as possible. The planning game overtimes, extra developer’s effort, and so
takes place at various levels (i.e., release planning on.
game, iteration planning game). “In the release • Customer decides which stories to include
planning game, the goal is to define the set of fea- in the release by prioritizing them. With the
tures required for the next release. It is centered necessary information from the developers,
around user stories. The customer writes stories, customer prioritizes the stories according
the programmers estimate the stories, and the to the chosen technique. According to the
customer plans the overall release. The iteration MoSCoW rules technique applied in DSDM,
planning game is similar. The customer chooses features could be prioritized as:
the stories for the iteration and the programmers
estimate and accept the corresponding tasks.” Must-have features, which are essential

(Wake, 2002, p. 8) to the system and cannot be left out.
The basic steps during the planning game are Should-have features, which are im-

always the same: portant to the system but the project’s
success does not rely on these. Due to
• Customer writes user stories to describe time constraints some of them could be
the desired features/requirements. It is left out of the release.
possible, especially in the beginning, for Could-have features, which will be

the development team to help or even to left out if time runs out, without any
suggest new stories to the customer during impact.
an initial story writing workshop. However, Won’t have this time features, which

“… responsibility for writing stories resides are desired ones that are shifted to the
to the customer and cannot be passed to the next release.
developers” (Cohn, 2004).
• Development team estimates the required Furthermore, Beck (2000) suggests that stories
effort for each user story to turn into working can also be sorted by means of:
code in terms of story points. Usually, “the
estimates are in terms of ideal engineering • “Value: Business sorts the stories into three
days--days where there are no interruptions, piles: (1) those without which the system will
no software or hardware glitches, and the not function, (2) those that are less essential
implementation moves smoothly” (Hayes,

77
Requirements Specification using User Stories

Figure 3. The planning game


the Planning Game
2
blablabla blablabla
blablablablablabla blablablablablabla 3
blablablablablabla
blablabla blablablablablabla
blablabla
blablablablablabla blablablablablabla
blablablablablabla
blablablablablabla blablablablablabla
blablablablablabla 8
blablablablablabla
blablabla blablablablablabla
blablabla
blablablablablabla blablablablablabla
blablablablablabla
blablablablablabla blablablablablabla
blablablablablabla 4
blablablablablabla
blablabla blablablablablabla
blablabla
blablablablablabla blablablablablabla
blablablablablabla
blablablablablabla 4 blablablablablabla
blablablablablabla 9
blablabla blablablablablabla estimates story points and blablabla blablablablablabla
writes stories blablabla
blablablablablabla
blablabla
blablablablablabla
blablablablablabla
blablablablablabla blablablablablabla
blablablablablabla
team’s velocity blablablablablabla
blablablablablabla
7
blablablablablabla
blablablablablabla 4
blablabla blablablablablabla blablabla blablablablablabla
blablablablablabla blablabla blablablablablabla blablabla
blablablablablabla
blablablablablabla blablablablablabla blablablablablabla
blablablablablabla 2 blablablablablabla
blablablablablabla
blablabla blablablablablabla
blablablablablabla blablablablablabla
blablabla blablablablablabla
blablablablablabla
blablablablablabla blablablablablabla blablablablablabla blablablablablabla
blablablablablabla
blablablablablabla blablablablablabla blablablablablabla
blablablablablabla 5 blablablablablabla
blablablablablabla
blablabla blablablablablabla blablablablablabla
blablabla blablablablablabla
blablablablablabla blablablablablabla
Customer blablablablablabla
blablablablablabla
blablablablablabla
blablabla Development blablablablablabla
blablablablablabla
blablablablablabla
blablabla
3
blablablablablabla blablablablablabla
blablablablablabla
blablablablablabla
blablablablablabla
blablabla
Team blablablablablabla
blablablablablabla
blablablablablabla
blablabla
6
blablablablablabla blablablablablabla
blablablablablabla
blablablablablabla blablablablablabla
blablablablablabla
blablablablablabla blablablablablabla
blablablablablabla blablablablablabla
blablablablablabla blablablablablabla

7
blablabla Iteration 1
blablablablablabla 2
blablablablablabla
blablabla
blablablablablabla
blablablablablabla
blablablablablabla 5
blablablablablabla
blablabla
4 9 blablablablablabla
blablabla blablabla blablablablablabla
blablablablablabla
blablablablablabla
blablablablablabla 7 blablablablablabla
blablablablablabla 3 blablablablablabla
blablabla blablablablablabla
blablabla blablablablablabla
blablablablablabla blablablablablabla
blablablablablabla
blablablablablabla 2 blablablablablabla
blablablablablabla blablablablablabla 6
blablabla blablablablablabla
blablabla
prioritizes stories and blablablablablabla blablablablablabla
plan the iterations
Customer
blablablablablabla
blablablablablabla 5 blablablablablabla
plans the release blablablablablabla
blablabla
blablablablablabla
blablablablablabla 4
blablablablablabla blablabla
blablablablablabla blablablablablabla
blablablablablabla 6 blablablablablabla blablablablablabla 4
blablablablablabla
blablabla
blablablablablabla blablablablablabla
blablabla Iteration 2
blablablablablabla
blablablablablabla blablablablablabla
blablablablablabla blablablablablabla
blablablablablabla 6
blablablablablabla blablablablablabla
blablabla
blablablablablabla blablablablablabla
Customer blablablablablabla
blablablablablabla
blablablablablabla
blablablablablabla
blablablablablabla
2
blablabla
blablablablablabla 9
blablablablablabla
blablabla
blablablablablabla
Development
blablablablablabla
blablablablablabla
blablablablablabla
blablabla
3 Iteration 3
blablablablablabla
Team blablablablablabla
blablablablablabla
blablablablablabla
blablablablablabla
blablablablablabla

but provide significant business value, and Although user stories are small by their
(3) those that would be nice to have. “nature,” “projects are generally well served by
• Risk: Development sorts the stories into disaggregating them into even smaller tasks.”
three piles: (1) those that they can estimate This happens firstly because it is more likely that
precisely, (2) those that they can estimate a story will be implemented by more than one
reasonably well, and (3) those that they developer/pair, and secondly because of the fact
cannot estimate at all.” that stories “are not to-do lists for developers”
(Cohn, 2004).
Independently of the technique, the final goal is The acronym SMART has been suggested by
to sort the stories in a way that the business value Wake (2003) for describing the characteristics of
gained will be maximized as much as possible. good tasks. More detailed, tasks should be:

• Finally, the whole team (customer and the • Specific: It should be clear enough what is
development team together) plan the current involved in a task.
iteration by defining the constituent tasks of • Measurable: Tasks should be measurable in
each story chosen in this iteration, and by al- the sense that there are measures “proving”
locating one developer/pair of programmers their completion.
for each task. At this meeting (the iteration • Achievable: The developer undertaking
planning meeting), the chosen stories will a specific task should expect to be able to
be discussed in detail and the tasks will accomplish it. That means that the devel-
be estimated in order to avoid over-alloca- oper should have the necessary technical
tion. “qualifications” to do the task.

78
Requirements Specification using User Stories

• Relevant: Although stories are disaggregat- 3. Valuable to users or customers: As user


ing into tasks for the benefit of developers, “a stories are written by customers/users, they
customer should still be able to expect that have to describe features that are valuable
every task can be explained and justified” to them. Stories that are only valued by
(Wake, 2003). developers and therefore mainly focused
• Time-Boxed: Tasks should be limited to a on technological and programming aspects
specific duration. It is not expected to have should be avoided. “Developers may have
an accurate estimation, but it is important (legitimate) concerns, but these framed in a
to have a rough indication of the duration so way that makes the customer perceive them
that developers may know when they should as important” (Wake, 2003).
start to worry.
Cohn (2004) points out: “It is very possible that
The following figure shows the way “The the ideas behind these stories are good ones but
planning game” works: they should instead be written so that the benefits
to the customers or the user are apparent. This
It has to be stressed that during the planning will allow the customer to intelligently prioritize
game and before the next iteration, due to the these stories into the development schedule.”
“knowledge” the customer and the team obtain
throughout the previous iterations, it is possible 4. Estimatable: It is essential for stories to
that new stories will emerge, whereas some other be estimatable in a way that developers
stories will be modified or even canceled. can estimate the size of the story (in terms
of story points). The better the developers
Main Attributes for Good stories estimate the story points the better the
customer will prioritize and schedule the
There are six main attributes that a story has to story’s implementation.
fulfill in order to be characterized as good. Wake
(2003) has suggested the acronym INVEST for Being not estimatable can be critically af-
these six attributes. A good story has to be: fected by:

1. Independent: User stories should not • The size and the complexity of a story.
have interdependencies between them. • Insufficient domain knowledge.
Otherwise, it is likely to face problems and • Insufficient technical knowledge and team’s
difficulties not only in prioritization and experience.
planning but also in estimation.
2. Negotiable: When writing user stories, it has 5. Small: “A good story captures the essence,
to be kept in mind that they are negotiable. not the details. Over time, the card may
As mentioned previously, user stories are acquire notes, test ideas, and so on, but we
short descriptions of the desired features don’t need these to prioritize or schedule
from the customer’s perspective, and not de- stories” (Wake, 2003).
tailed requirements themselves. The details
of each story are negotiated in conversations A story must have the right size in order to
between the customer and the development be easy to estimate, plan, and prioritize. A small
team during development. story is more likely to get a more accurate esti-
mation. Stories should represent time between a

79
Requirements Specification using User Stories

few man-days of work up to a few man-weeks one generic type of user. What about users that
of work. The usage of index cards, except where do not belong to the generic type of user?
the story is likely to include conversation details, The use of user roles, personas, or even extreme
notes, and acceptance tests, helps to keep the character technique can prove to be extremely
story small. helpful in writing better stories and mainly in
There is also an interesting opinion about the minimizing the possibility of omitting important
size of the title of a good story: “We like to enforce stories.
the 5-word rule when writing stories. If your title
contains more than five words, then it probably A user role is a collection of defining attributes
needs refactoring. (…) it is a good exercise to pick that characterize a population of users and their
out stories that violate this rule and re-examine intended interactions with the system.” (Cohn,
them.” (Industrial Logic, 2004) 2004, p. 32). Moreover, “a user role is a particular
kind of relationship between some users and a
6. Testable: A good story should be testable. system. (…) A role is an abstraction, a collection of
“Writing a story card carries an implicit characteristic needs, interests, expectations, and
promise: I understand what I want well behaviors. (Constantine & Lockwood, 2006)
enough that I could write a test for it” (Wake,
2003). Some examples of user roles could be the
following:
Acceptance tests included in the story card
should be executed so as to verify that the user • Doctor: A user that uses the system in order
story has been correctly implemented. By pass- to see past medical data necessary for his
ing these tests, it is considered that the story has prediction, and/or to insert new data after
been successfully developed. the medical examination has finished.
Acceptance tests are most useful when auto- • Appointments Secretary: A user that uses
mated. Considering the fact that following agile the system in order to reserve doctors’ ap-
methods, software is developed incrementally, pointments hours, upon patients requests,
automated tests can help the development team and to create patient medical record insert-
to test constantly and rapidly every change. ing demographical details for first time
Finally, it is normal that there will be some user patients.
stories that cannot be automated. For example, “… • Nurse: A user that uses the system in order
a user story that says, “A novice user is able to to see and/or insert data concerning the
complete common workflows without training” medical condition, as well as the possible
can be tested but cannot be automated. Testing this special nutrition and medication instructions
story will likely involve having a human factors given by the doctors.
expert design a test that involves observation of
a random sample of representative novice users” During the process of identifying the vari-
(Cohn, 2004). ous user roles of a system, it is usual to discover
overlaps, interconnections, and relationships
user roles, Personas, and among user roles. Sometimes, “one role may be
Extreme characters a specialization of another more general role,
one role may be composed of other roles, and
Most of the times, requirements are written with roles may otherwise depend on each other.”
the assumption that the system will be used by (Constantine et al., 2006). In order to avoid this,

80
Requirements Specification using User Stories

Cohn (2004) proposes that the following steps • The user’s level of expertise with the do-
may help a team to identify and select a useful main.
set of user roles: • The user’s general level of proficiency with
computers and software.
• Brainstorming an initial set of user roles: • The user’s level of proficiency with the
In a meeting where both the customer and software being developed.
as many developers as possible take part, • The user’s general goal for using the soft-
all the participants start to write down the ware. Some users are after convenience,
user roles they picture. Every time a new others favor a rich experience, and so on.”
user role is found, the author informs the (Cohn, 2004, p. 37)
whole group. When it becomes difficult to
find new roles, the meeting is over. Usually, A sample user role card appears in Figure 4.
such a meeting should not exceed 15-20 Cooper (1999) has proposed a variation on user
minutes. Although this meeting may not roles called Personas. “Rather than abstracting the
identify all of the user roles, it is sure that essential features of a relationship, personas are
the overwhelming majority are identified. described as if they were real, specific persons,
• Organizing the initial set: Once the brain- with personality, detailed history, and complete
storming meeting has finished, the group background.” (Constantine et al., 2006).
organizes the set of the user roles accord- A persona describes an imaginary named user
ing to their relationships and their possible of the system. The description includes fictitious
overlaps. details such as demographic details and personal-
• Consolidating roles: The user roles, which ity characteristics, or even a picture. In order for
the group decides, that are of great similarity the use of personas to be helpful for the project,
are consolidated into fewer, more generic it has to be assured that the personas chosen
ones. At the same time, user roles that have represent the system’s end-users.
nominal significance to the success of the A Persona example follows:
system are thrown away.
• Refining roles: Finally, the group describes Tom is a 45-year-old cardiologist with a lot of
each user role by defining its basic attributes. experience in his domain. He works in AAA
A user role card may ideally include the Hospital nine years. He is married and has two
following attributes: daughters. Although he is an early adopter of new
practices and novelties in his area of expertise,
• “The frequency with which the user will use his familiarity with computers is limited only on
the software. Web browsing and e-mail exchanging. However,

Figure 4. A sample user role card

User Role: Doctor

The user will be forced to use the system on a daily basis, in order to extract and insert medical data
to Patient Medical Records. He is not quite familiar with the use of computers in general, and up to
now he was not utilizing any software related to his occupation. Usefulness and friendliness of the
system is important, and no special training should be required.

81
Requirements Specification using User Stories

he is in favor of utilizing the software system being ments is definitely the user interview. In user
developed, as he recognizes its benefits. stories, the main goal is to interview real
users of the proposed system. Alternatively,
Although the creation of a persona “can be a when this is not possible, user proxies (see
fun exercise, the concrete detail can obscure fea- next paragraph “User Proxies”) replace real
tures of the underlying role that are essential for users.
good design” (Constantine et al., 2006). Moreover, Although most of the people are familiar
“there is a risk that using personas to represent with interviews and consider them a simple
the user will not make up for real-life feedback procedure, a really successful interview is
from an actual user. Using personas should, if a rare reality. The most difficult part is to
used, be seen as a complimentary to instead of get users real needs. This can happen only
a substitution of users” (Toxboe, 2005). Finally, if the questions help the user to express his
personas’ descriptions are often full of unneces- or her more in-depth opinions, thoughts,
sary details that do not contribute anything to and expectations from the system. In fact,
the development team and sometimes can also the interview should look like a friendly
be misleading. conversation without unnecessary severity.
Hence, a combination of using both user roles As Cohn (2004, p. 47) alleges, questions in
and personas for selected roles, particularly for interviews should be “Open-ended” and
some crucial (for the success of the project) roles, “Context-free.”
may be extremely useful. Following this combi- 2. Questionnaires: Questionnaires may also
nation may help the team to better describe the be used in cases where there is large number
primary user roles and consequently it is more of users and is essential to get answers on
possible to understand better the needs of the specific questions. Difficulties arise from the
system’s end-users. fact that questionnaires exclude the possibil-
Djajadiningrat, Gaver, and Frens (2000) went ity of exchanging information with the user.
a step further. They have proposed the use of ex- Therefore, questionnaires are inappropriate
treme characters. More specifically, they allege for writing new stories, but they can be used
that by considering some extreme characters (e.g., for specifying details in existing ones.
a drug dealer) as possible users of the system can 3. Observation: One additional interesting
lead to the appearance of stories that would be technique is to observe users’ “reactions”
difficult to picture otherwise. and collect their feedback when working
On the other hand, it is not clear whether these with the software. Of course, this technique
new stories are important to the system, or if the presupposes that a significant number of
number of the possible end-users “fit” to these real users are available for as long as it
stories is significant, in order for their develop- takes. If it is possible observation may be
ment to be cost-effective. extremely helpful, but unfortunately this is
not the case all the time. There are project
techniques for creating user stories time restrictions and difficulties in accessing
real users.
Four main techniques have been suggested for 4. Story-writing workshops: User stories
creating user stories: proponents consider this technique as the
most effective way for writing stories.
1. User Interviews: One of the most widely Development teams and users/customers
acceptable techniques for gathering require- take part in this workshop with the goal to

82
Requirements Specification using User Stories

write as many stories as they can, focus- although he may be one of the real users of
ing mainly on quantity and not on quality. the system, it is possible that his perception,
According to Cohn (2004, p. 49), “A good needs, and priorities from the system may
story-writing workshop combines the best be totally different from his subordinates.
elements of brainstorming and low-fidel- • IT manager: Again, in projects for internal
ity prototyping.” The steps that take place use, the IT manager of the customer could
during the workshop can be summarized as be assigned to be the user proxy. Special
following: attention should be given to the fact that
often, IT managers consider the introduction
• Primary user roles and/or personas are of new, sophisticated technology as higher
identified. priority.
• Main screen of the system is drawn and basic • Salespersons/marketing department:
actions of primary user roles/personas are Usually they understand the target market
described. and the real user needs more than anyone
• Primary stories are generated by the actions else. However, their priorities are mainly
described. affected by the overall “attractiveness” of
• Additional stories are generated by the the system and the consequent sales result.
conversation that follows. Salespersons are focused on the points they
know or assume they will convince the
Depending on the project, a combination of prospective customer/buyer of.
the techniques described in this section may be • Domain experts: May also be proved very
used, resulting in a more effective and compre- helpful resources, but their usefulness de-
hensive outcome. pends on whether their experience is simi-
lar to the level of expertise of the system
user Proxies implemented. Their experience may lead
to a more complicated system than it was
User stories’ final quality and effectiveness relies supposed to be.
largely on the participation of real users on the • Business/system analysts: Analysts are
customer team. However, on some projects, it is frequently used as user proxies and most of
difficult or even impossible to have “on call” real the times their involvement could be charac-
users that will write the stories. terized as successful for the project because
In this case, and according to Cohn (2004), “they have one foot in the technology world
the involvement of user proxies could prove to and one foot in the domain of the software”
be useful. User proxies are not real users, but for (Cohn, 2004, p. 61). However, some analysts
the duration of the project, they could be con- believe their experience and knowledge are
sidered as their representatives making all the quite enough, and therefore conversation
necessary decisions. Some indicative types of with users could be minimized. It is more
user proxies, which may be used instead of real than obvious that this perception may lead
users, are following: to wrong assumptions.

• Users’ manager: In projects that are for Conclusively, although the participation of
internal use instead of access to one or more real users may be ideal for writing good user
users, users’ manager may be the person stories, when this is impossible, the use of user
that is on-site. It has to be kept in mind that proxies, under some conditions, may also lead to

83
Requirements Specification using User Stories

the same result. More specifically, because of the are usability testing, performance testing, user
shortcomings that each user proxy has, using the interface testing, stress testing, etc.
right combination (depending on the project and Because of their large number and the neces-
the target users) of user proxies may eliminate sity for constant execution, agilists propose that
these shortcomings. acceptance tests should be automated as much as
On the other hand, the early release of a beta possible. Two of the most popular tools are FIT
version may open an additional communication and FitNesse.
path to real users, helping to “discover” the dif-
ference between real users’ perception and the user stories and Quality
initial user proxies’ view of the system.
Quality assurance in the requirements manage-
Acceptance testing ment process defined as the compliance with a
quality standard such as ISO, TickIT, etc., is one
In user stories, acceptance tests are part of the of the central critique points against user stories.
story. More specifically, tests are written in the In order to be more precise, quality assurance is
story card before the coding starts. one of the most controversial issues when utiliz-
Ideally, tests are specified by customer/us- ing agile methods.
ers. “The customers write tests story-by-story. As it was mentioned earlier in this chapter,
The question they need to ask themselves is, agilists believe that requirements emerge during
“What would have to be checked before I would the development phase of the system, therefore,
be confident that this story was done?” (Beck, the overall quality of the final system is critically
2000). However, most of the times, it is hard for dependent on the challenging task of uncovering
a customer to write acceptance tests without the the “real” customer requirements. User stories, ac-
assistance of a programmer or a tester. “That’s cording to their supporters, provide the appropri-
why an XP team of any size carries at least one ate framework toward this direction, contributing
dedicated tester. The tester’s job is to translate the thereby in the successful delivery of a final system
sometimes vague testing ideas of the customer into meeting nearly to the fullest the customer needs.
real, automatic, isolated tests.” (Beck, 2000). This way, high levels of customer satisfaction are
Tests are usually written as details when achieved, which subsequently is accounted by
customers and developers discuss a story for the many as the number one quality criterion.
first time, but mainly at the iteration planning In accordance to this, it is important to men-
meeting (before the iteration starts) when stories tion that the Institute of Electrical and Electronic
are discussed more explicitly. At this point, de- Engineers (IEEE) defines quality in a software
velopers may also write some additional stories system as “the degree to which a system, com-
in cases where they estimate by experience that ponent or process meets customer or user needs
the implementation may be complicated and ad- or expectations.”
ditional points should be tested. Extreme programming (XP) considers qual-
As the customer writes tests, it is more than pos- ity of the software produced to be the highest
sible that tests will cover only functional aspects priority. This is accomplished through a series
of the system. Although these tests are crucial of continuous testing at two basic levels:
for the success of the system, there are also some
aspects of the system that developers have to test. 1. At a first level, quality of the code is maxi-
According to Cohn (2004, p. 72), other important mized through test driven development
types of testing, which have to be considered and unit testing. “Each class implemented

84
Requirements Specification using User Stories

must have programmer-developed unit tests, Benefits and Limitations of


for everything that “could possibly break.” user stories
These tests are to be written during coding
of the class, preferably right before imple- There are many positive aspects concerning
menting a given feature. Tests are run as user stories in contrast with the traditional ap-
frequently as possible during development, proaches. Some of the user stories’ advantages
and all unit tests in the entire system must are mentioned next:
be running at 100% before any developer
releases his code” (Jeffries, 2006). • They favor face-to-face communication
2. At a second level of testing called func- instead of written requirements. Constant
tional testing, the quality of the system conversations between the development
from the business perspective is attempted team and the customer/users may help to
to be assured. This is achieved through the overcome written language inaccuracies,
constant customer/user participation who and help to maintain a close relationship with
writes the user stories and respectively ac- the customer. This close relationship results
ceptance tests with the help of the develop- in more effective knowledge transfer
ment team. Customer/user is the one that across the team and facilitates the active
verifies their accomplishment. According participation of the users in designing
to Crispin (2001), “If the customer is clear the behavior of the system. In this case, the
about his acceptance criteria and these are term “participatory design” is used (Kuhn
reflected accurately in the acceptance tests, & Muller, 1993; Schuler & Namioka, 1993)
we’re much more likely to achieve the level in contrast to the “traditional” approach
of quality the customer wants.” Moreover, where users are not part of the team and all
an acceptance test “helps verify that a story the decisions on the design of the system are
works correctly by documenting what inputs made by designers who only study users’
are supplied to a system and what outputs written requirements.
are expected” (Reppert, 2004). • Since stories are written by users, they
are more comprehensible to them than
In “Extreme Programming Explained,” Beck any other technique. Moreover, their small
(2000) describes these two levels of testing as size, their persistence to simplicity, and the
internal and external quality. “External quality avoidance of technical jargon enforce the
is quality as measured by the customer. Internal previous characteristic.
quality is quality as measured by the program- • They are suitable for iterative develop-
mers.” In fact, by using acceptance tests, the ment. “Stories work well for iterative devel-
external quality of the system is likely to be opment because of how easy it is to iterate
maximized. over the stories themselves. (…) I can write
Finally, Crispin’s (2001) view is an illustrative some stories, code, and test those stories, and
example of how quality is treated in XP, and gener- then repeat as often as necessary.” (Cohn,
ally in agile methods: “When I started working on 2004, p. 149). Stories may be written and
XP projects, I realized it wasn’t about MY quality revised while the development takes place
standards—it was the customers.” and knowledge of the team becomes more
specific.

85
Requirements Specification using User Stories

On the other hand, some of the limitations of use cases, and interaction design scenarios. The
user stories could be summarized as follows: main differences between user stories and these
approaches are described briefly in the following
• As it is mentioned previously, traditional paragraphs:
requirement documents are also used as a
contract model signed usually before the • IEEE 830-style approach implies that all the
development phase starts, and as a tool of requirements of the system will be written
solving any disputes or misunderstandings by analysts (with the assistance of some us-
that may emerge during the development. ers) who will “imagine” the planned system
Although contracts do not assure project even before the development starts. This
success, managers are accustomed to this approach does not take into consideration
since it is presumed that contracts can secure the benefit of users’ feedback once they see
them against any future problems. Therefore, part or an early version of the system. Every
it is difficult for them to accept a less “se- change in the initially agreed requirements
cure” approach where user’s requirements is con sidered as “change of scope” and
do not constitute the technical annex of a therefore should be avoided or in the worst
contract. case minimized.
• There are cases where requirements trace-
ability is obligatory because of internal Qual- Moreover, as customers/users hardly partici-
ity Systems (e.g., ISO 9001, TickIT). This pate actively in requirements specification (their
may require additional documentation and participation is usually limited to few interviews),
a more bureaucratic “attitude” that comes it is common that the requirements agreed do not
in sharp contrast with the agile approach. entirely cover user’s/business’ goals.
However, agilists insist that it is possible Finally, requirements documents “produced”
to reach the golden mean by adopting a are usually extremely large with many details.
lightweight solution that fulfils basic quality Producing such documents is not only time
system’s documentation requirements but consuming but it is likely that customers/users
also enables agility. may not understand all the details included in
• Although customer participation throughout the document.
the project decreases the risk of system to
end a failure, in some cases it may be dif- • According to Cohn (2004, p. 140) “Use cases
ficult or it may be a significant cost for the are written in a format acceptable to both
customer. customers and developers so that each may
• On large projects with large teams, com- read and agree to use cases. The purpose of
munication problems may occur, since face the use case is to document an agreement
to face conversations and meetings with the between the customer and the development
participation of the whole team may be hard team. Stories, on the other hand, are written
to organize on a constant basis. to facilitate release and iteration planning,
and to serve as placeholders for conversa-
user stories in comparison tions about the users’ detailed needs.”

Apart from user stories, the three more com- Another important difference is in their
mon approaches to user requirements are IEEE level of detail. As stories are written on index
830 software requirements specification (SRS), cards, their size is limited and therefore their

86
Requirements Specification using User Stories

development time is easier to be estimated (by A few data from research supporting this aspect
definition the implementation of a story should are distinctively cited:
be competed in a single iteration). In contrast, use
cases almost always cover a much larger scope • The Software Development Times Magazine
and their implementation is independent of any (July 2003 Issue) published the research re-
time considerations. sults of an Evans Data Corporation research,
Moreover, documentation “produced” during according to which a rate of 9% of North
use cases’ specification is kept after software re- America companies totally use XP method
lease to aid in software maintenance. On the other in their projects.
hand, user stories are not preserved as software • A Cutter Consortium research (Charette,
documentation and are often discarded after the 2001) conducted among 200 managing direc-
project ends. tors/IT managers constituting a respective
Finally, it is usual for use cases to include user sample from the point of the geographical
interface details that could lead to preconceptions allocation of the companies’ type and size,
in an early stage. recorded that during 2001, 21% of the par-
ticipants used agile methodologies to more
• Like the previous approaches, interaction than 50% of their projects. Additionally, in
design scenarios contain much more de- the year 2002, 34%, and in 2003, almost half
tails than user stories, focusing mainly on of the participants expected that more than
describing the personas (see section “User 50% of their projects would be conducted
Roles, Personas, and Extreme Characters”) using agile methodologies.
and their interaction with the system. More- • The research of Giga Information Group
over, they usually cover a much larger scope (Sliwa, 2002) in 2002 anticipated that in a
than stories. In fact, most of the times, one period of the following 18 months, 2/3 of
scenario may be equal to many stories. IT companies in the U.S. would mostly use
agile methods in their projects.

FuturE trEnds As most of the “agilists” strongly recom-


mend user stories as the appropriate technique
As it is cited many times in this chapter, user sto- for gathering user requirements, it is more than
ries are one of the primary development artifacts possible that the rise of agile methods will drift
for extreme programming (XP) project teams. the adoption of user stories.
Bibliography was used to bound user stories with
extreme programming since they originated as
part of XP. Today, many authors suggest that user CONCLUSION
stories could be used also with other agile methods.
Cohn for example, in “User Stories Applied: For User stories are not just another technique on man-
Agile Software Development” dedicates a whole aging user requirements. User stories as part of
chapter describing how user stories can be used agile methods propose a totally different approach
effectively with SCRUM. based on customer active participation through-
Moreover, the use of extreme programming is out the implementation of a system. A customer,
constantly growing while the adoption level of ag- with the help of the development team, writes the
ile methodologies in general is rapidly increased. requirements in his “language,” prioritizes them,

87
Requirements Specification using User Stories

and finally writes the acceptance tests. “Agilists” before adopting a more agile approach based on
believe that this constant customer participation user stories, it has to be taken into account that
increases drastically the possibility of delivering user stories have also limitations. “Due to the need
a system closer to the real user requirements. for direct communication, XP is only viable for
However, despite the many positive and in- small co-located teams with access to an onsite
novative (“revolutionary” for some) aspects of customer. Large distributed teams may need to
the user stories, development teams globally are rely on more documentation and adopt RUP or
still trusting and using traditional approaches other less agile processes.” (Davies, 2001)
with comprehensive documentation arguing
about the effectiveness of user stories. The main
reason behind this skepticism is the fact that, References
usually, written user’s requirements represent
the subject of signed contracts. These contracts Ambler, S. (2005a). Agile requirements best
operate as a means of solving any disputes or practices. Retrieved December 28, 2005, from
misunderstandings between the parties, and their http://www.agilemodeling.com/essays/agileRe-
absence frightens mainly the top management. quirementsBestPractices.htm
In addition to this, the adoption of user stories
Ambler, S. (2005b). Agile documentation: strate-
and agile methods principles in general, require
gies for agile software development. Retrieved
a change on the “company’s culture,” something
December 28, 2005, from http://www.agilemodel-
difficult to be accepted by large, bureaucratic
ing/com/essays/agileDocumentation.htm
organisations.
But, as in one of the four agile manifesto’s Beck, K. (2000). Extreme programming ex-
values quoted, “People and interactions over plained; embrace change. Reading, MA: Addison
processes and tools,” what is more important is Wesley.
the genuine, honest, and constant cooperation with
Beck, K., & Fowler, M. (2000b). Planning extreme
the customer; this targets to the development of
programming. Reading, MA: Addison Wesley.
relations of trust rather than the exact and absolute
compliance with the terms and conditions of a Charette, R. (2001). The decision is in agile versus
contract which, even though it is necessary, does heavy methodologies. Cutter Consortium, e-
not presuppose the success of a project. Project Management Advisory Service, Executive
Furthermore, in accordance with another Update, 2(19), 1-3.
agile manifesto’s value, “Responding to change
Cohn, M. (2004). User stories applied: For agile
over following a plan,” user stories and iterative
software development. Reading, MA: Addison-
development allow the development team to ac-
Wesley.
cept changes in users requirements derived from
experiences gained during development. Constantine, L. L., & Lockwood L. A. (1999).
Conclusively, although user stories appearance Software for use: A practical guide to the models
is very recent, and their use is not so extensive, and methods of usage-centered design. Reading,
it looks like they can solve many of the limita- MA: Addison-Wesley.
tions of the traditional approaches. And as user
requirements specification is considered as one of Constantine L. L., & Lockwood Ltd Website
the main factors of a project success, it is possible (2006). Frequently asked questions. Retrieved
that using user stories may enhance the success January 18, 2006, from http://www.foruse.com/
rate of software projects in general. Nevertheless, questions/index.htm#5

88
Requirements Specification using User Stories

Cooper, A. (1999). The inmates are running the Kuhn, S., & Muller, M. (1993). Introduction to
asylum. Indianapolis: SAMS. the special section on participatory design. Com-
munications of the ACM, 36(6), 24-28.
Crispin, L. (2001). Is quality negotiable? Retrieved
June 28, 2003, from www.xpuniverse.com/2001/ Parnas, D. L., & Clements, P. C. (1986). A rational
xpuPapers.htm design process: How and why to fake it. IEEE
Transactions on Software Engineering, 12(2),
Davies, R. (2001). The power of stories. Presented
251-257.
at XP2001 Conference, Sardinia.
Reppert, T. (2004). Don’t just break software make
Davies, R. (2005). Agile requirements. Methods
software. Better Software, 18-23.
& Tools, 13(3), 24-30, Fall 2005.
Schuler, D., & Namioka, A. (1993). Participatory
Djajadiningrat, J. P., Gaver, W. W., & Frens, J.
design: Principles and practices. Hillsdale, NJ:
W. (2000). Interaction relabelling and extreme
Erlbaum.
characters: Methods for exploring aesthetic in-
teractions. Symposium on Designing Interactive Sliwa, C. (2002). Users warm up to agile program-
Systems 2000 (pp. 66-71). ming. Computer World, 36(12), 8.
Fowler, M. (2005). The new methodology. Re- Stapleton, J. (2003). DSDM: Business focused
trieved December 29, 2005, from http://martin- development. Reading, MA: Addison-Wesley.
fowler.com/articles/newMethodology.html
Thomas, M. (2001). The modest software engineer.
Hayes, S. (2002). The problems of predictive Retrieved January 29, 2006, from www.safety-
development. Methods & Tools, 10(4), 22-26, club.org.uk/resources/164/MartynThomas.pdf
Winter, 2002.
Toxboe, A. (2005). Introducing user-centered
Jeffries, R. (2001). Essential XP: Card, conversa- design to eXtreme programming. Copenhagen
tion, confirmation. Retrieved December 29, 2005, Business School, Department of Informatics.
from http://www.xprogramming.com/xpmag/
Wake, W. C. (2002). Extreme programming ex-
EXPCardConversationConfirmation.htm
plored. Reading, MA: Addison Wesley.
Jeffries, R. (2006). XP questions and an-
Wake, W. C. (2003). INVEST in good stories and
swers—quality assurance. Retrieved April 12,
SMART tasks. Retrieved December 29, 2005, from
2006, from http://www.xprogramming.com/qa/
http://xp123.com/xplor/xp0308/index.shtml
xp_q_and_a_QA.htm
Industrial Logic Inc. Web site. (2004). Storytell-
ing. Retrieved January 17, 2006, from http://www.
industrialxp.org/storytelling.html

89
90

Chapter V
Handling of Software
Quality Defects in Agile
Software Development
Jörg Rech
Fraunhofer Institute for Experiemental Software Engineering (IESE), Germany

AbstrAct

Software quality assurance is concerned with the efficient and effective development of large, reliable,
and high-quality software systems. In agile software development and maintenance, refactoring is an
important phase for the continuous improvement of a software system by removing quality defects like
code smells. As time is a crucial factor in agile development, not all quality defects can be removed
in one refactoring phase (especially in one iteration). Documentation of quality defects that are found
during automated or manual discovery activities (e.g., pair programming) is necessary to avoid wasting
time by rediscovering them in later phases. Unfortunately, the documentation and handling of exist-
ing quality defects and refactoring activities is a common problem in software maintenance. To recall
the rationales why changes were carried out, information has to be extracted from either proprietary
documentations or software versioning systems. In this chapter, we describe a process for the recurring
and sustainable discovery, handling, and treatment of quality defects in software systems. An annotation
language is presented that is used to store information about quality defects found in source code and
that represents the defect and treatment history of a part of a software system. The process and annota-
tion language can not only be used to support quality defect discovery processes, but is also applicable
in testing and inspection processes.

Copyright © 2007, Idea Group Inc., distributing in print or electronic forms without written permission of IGI is prohibited.
Handling of Software Quality Defects in Agile Software Development

IntroductIon results in either incomplete or costly refactoring


phases.
The success of software organizations—espe- A common problem in software maintenance is
cially those that apply agile methods—depends on the lack of documentation to store this knowledge
their ability to facilitate continuous improvement required for carrying out the maintenance tasks.
of their products in order to reduce cost, effort, While software systems evolve over time, their
and time-to-market, but also to restrain the ever transformation is either recorded explicitly in a
increasing complexity and size of software sys- documentation or implicitly through a versioning
tems. Nowadays, industrial software development system. Typically, problems encountered or deci-
is a highly dynamic and complex activity, which sions made during the development phases get lost
is not only determined by the choice of the right and have to be rediscovered in later maintenance
technologies and methodologies, but also by the phases. Both expected and unexpected CAPP
knowledge and skills of the people involved. This (corrective, adaptive, preventive, or perfective)
increases the need for software organizations to activities use and produce important information,
develop or rework existing systems with high which is not systematically recorded during the
quality within short periods of time using auto- evolution of a system. As a result, maintenance
mated techniques to support developers, testers, becomes unnecessarily hard and the only coun-
and maintainers during their work. termeasures are, for example, to document every
Agile software development methods were problem, incident, or decision in a documentation
invented to minimize the risk of developing system like bugzilla (Serrano & Ciordia, 2005).
low-quality software systems with rigid process- The direct documentation of quality defects that
based methods. They impose as little overhead are found during automated or manual discovery
as possible in order to develop software as fast activities (e.g., code analyses, pair programming,
as possible and with continuous feedback from or inspections) is necessary to avoid wasting time
the customers. These methods (and especially by rediscovering them in later phases.
extreme programming (XP)) are based upon In order to support software maintainers
several core practices, such as simple design, in their work, we need a central and persistent
meaning that systems should be built as simply point (i.e., across the product’s life cycle) where
as possible and complexity should be removed, necessary information is stored. To address this
if at all possible. issue, we introduce our annotation language,
In agile software development, organizations which can be used to record information about
use quality assurance activities like refactoring quality characteristics and defects found in
to tackle defects that reduce software quality. source code, and which represents the defect and
Refactoring is necessary to remove quality de- treatment history of a part of a software system.
fects (i.e., bad smells in code, architecture smells, The annotation language can not only be used
anti-patterns, design flaws, negative design to support quality defect discovery processes,
characteristics, software anomalies, etc.), which but is also applicable for testing and inspection
are introduced by quick and often unsystematic processes. Furthermore, the annotation language
development. As time is a crucial factor in agile can be exploited for tool support, with the tool
development, not all quality defects can be re- keeping track and guiding the developer through
moved in one refactoring phase (especially in one the maintenance procedure.
iteration). But the effort for the manual discovery, Our research is concerned with the develop-
handling, and treatment of these quality defects ment of techniques for the discovery of quality

91
Handling of Software Quality Defects in Agile Software Development

defects as well as a quality-driven and experience- an annotation language to record information


based method for the refactoring of large-scale about quality defects and their history in source
software systems. The instruments developed code. Thereafter, a section is used to describe
consist of a technology and methodology to sup- the annotation language that is used to record
port decisions of both managers and engineers. the treatment history and decisions in the code
This support includes information about where, itself. Finally, we summarize several lessons
when, and in what configuration quality defects learned and requirements one should keep in mind
should be engaged to reach a specific configuration when building and using quality defect handling
of quality goals (e.g., improve maintainability or methods and notations in an agile environment.
reusability). Information from the diagnosis of At the end of this chapter, we summarize the
quality defects supports maintainers in select- described approach and give an outlook to future
ing countermeasures and acts as a source for work and trends.
initiating preventive measures (e.g., software
inspections).
This chapter targets the handling of quality bAckground
defects in object-oriented software systems and
services. It is concerned with the theory, method- This section is concerned with the background
ology, and technology for the handling of defects and related work in agile software engineering,
that deteriorate software qualities as defined in refactoring, and quality defects. It gives an over-
ISO 9126 (e.g., maintainability, reusability, or per- view of quality defect discovery, the documenta-
formance). We describe the relevant background tion of defects, as well as source code annotation
and related work concerning quality defects and languages.
quality defect handling in agile software proj-
ects, as well as existing handling techniques and Agile software development
annotation languages. The subsequent section
encompasses the morphology of quality defects Agile software development methods impose as
as well as their discovery techniques. As the core little overhead as possible in order to develop
of this chapter, we present the techniques for software as fast as possible and with continuous
handling quality defects after their discovery in feedback from the customers. Agile methods have
an agile and time-critical environment and define

Figure 1. Agile software development (here the XP process)

Spike user stories


Prototyping
test first (sQA)

Architectural
Release Development A cceptance small releases
spike
Planning Iteration Test

Next Iteration

spike Pair Programming unit testing / test


(sQA) first (sQA)

92
Handling of Software Quality Defects in Agile Software Development

in common that small releases of the software 4. Refactoring is necessary for removing
system are developed in short iterations in order to qualitative defects that are introduced by
create a running system with a subset of the func- quick and often unsystematic development.
tionality needed for the customer. Therefore, the Decision support during refactoring helps
development phase is split into several activities, the software engineer to improve the sys-
which are followed by small maintenance phases. tem.
In contrast to traditional, process-oriented SE,
where all requirements and use cases are elicited, In the highly dynamic processes used in
agile methods focus on few essential requirements agile methods, teams and organizations need
and incrementally develop a functional system in automated tools and techniques that support their
several short development iterations. work without consuming much time. Especially
Today, extreme programming (XP) (Beck, in the refactoring phase, where the software is
1999) is the best-known agile software devel- revised, automation can be used to detect qual-
opment approach. 0 shows the general process ity defects such as code smells (Fowler, 1999),
model of XP, which is closely connected to antipatterns (Brown, Malveau, McCormick, &
refactoring, basically being its cradle (Beck & Mowbray, 1998), design flaws (Riel, 1996), design
Fowler, 1999). characteristics (Whitmire, 1997), or bug patterns
These agile methods (and especially extreme (Allen, 2002). Techniques from KDD support the
programming (XP)) are based upon 12 principles refactoring of software systems (Rech, 2004),
(Beck, 1999). We mention four of these principles, and techniques from knowledge management
as they are relevant to our work. can foster experience-based refactoring (Rech
& Ras, 2004).
1. Planning Game is the collective planning of
releases and iterations in the agile develop- Quality defect discovery
ment process and is necessary for quickly
determining the scope of the next release. A central research problem in software mainte-
If the requirements for the next iteration nance is still the inability to change software easily
are coherent and concise, more focus can and quickly (Mens & Tourwe, 2004). To improve
be given to one topic or subsystem without the quality of their products, organizations often
making changes across the whole system. use quality assurance techniques to tackle defects
2. Small releases are used to develop a large that reduce software quality. The techniques for
system by first putting a simple system into the discovery of quality defects are based upon
production and then releasing new versions several research fields.
in short cycles. The smaller the change to the
system, the smaller the risk of introducing • Software Inspections (Aurum, Petersson,
complexity or defects that are overlooked & Wohlin, 2002; Ciolkowski, Laitenberger,
in the refactoring (or SQA) phases. Rombach, Shull, & Perry, 2002), and espe-
3. Simple design means that systems are built cially code inspections are concerned with
as simply as possible, and complexity in the the process of manually inspecting software
software system is removed, if at all possible. products in order to find potential ambigui-
The more understandable, analyzable, and ties as well as functional and non-functional
changeable a system is, the less functional- problems (Brykczynski, 1999). While the
ity has to be refactored or reimplemented specific evaluation of code fragments is
in subsequent iterations or maintenance
projects.

93
Handling of Software Quality Defects in Agile Software Development

probably more precise than automated external data sources are prone to get lost over
techniques, the effort for the inspection is several years of maintenance and infrastructure
higher, the completeness of an inspection changes. The only information that will not get
regarding the whole system is smaller, and lost is typically the source code itself.
the number of quality defects searched for
is smaller. refactoring
• Software testing (Liggesmeyer, 2003) and
debugging is concerned with the discovery Beside the development of software systems, the
of defects regarding the functionality and effort for software evolution and maintenance is
reliability as defined in a specification or estimated to amount to 50% to 80% of the overall
unit test case in static and dynamic environ- development cost (Verhoef, 2000). One step in the
ments. evolution and development of software systems
• Software product metrics (Fenton & Neil, is the process of reworking parts of the software
1999) are used in software analysis to mea- in order to improve its structure and quality (e.g.,
sure the complexity, cohesion, coupling, or maintainability, reliability, usability, etc.), but not
other characteristics of the software product, its functionality. This process of improving the in-
which are further analyzed and interpreted ternal quality of object-oriented software systems
to estimate the effort for development or to in agile software development is called refactor-
evaluate the quality of the software product. ing (Fowler, 1999). While refactoring originates
Tools for software analysis in existence today in from the agile world, it can, nevertheless, be
are used to monitor dynamic or static aspects used in plan-driven (resp. heavyweight) software
of software systems in order to manually engineering. In general, refactoring (Fowler,
identify potential problems in the architec- 1999; Mens et al., 2004) is necessary to remove
ture or find sources for negative effects on quality defects that are introduced by quick and
the quality. often unsystematic development.
The primary goal of agile methods is the
Furthermore, several specific techniques for rapid development of software systems that are
quality defect discovery already exist (Marinescu, continuously adapted to customer requirements
2004; Rapu, Ducasse, Girba, & Marinescu, 2004). without large process overhead. During the last
Most of the tools such as Checkstyle, FindBugs, few years, refactoring has become an important
Hammurapi, or PMD analyze the source code part in agile processes for improving the structure
of software systems to find violations of project- of software systems between development cycles.
specific programming guidelines, missing or Refactoring is able to reduce the cost, effort, and
overcomplicated expressions, as well as poten- time-to-market of software systems. Develop-
tial language-specific functional defects or bug ment, maintenance, and reengineering effort
patterns. Nowadays, the Sotograph can identify are reduced by restructuring existing software
“architectural smells” that are based on metrics systems (on the basis of best practices, design
regarding size or coupling (Roock & Lippert, heuristics, and software engineering principles),
2005). especially in the process of understanding (the
But the information from these techniques impact of new changes in) a system. A reduction
and the resulting CAPP or refactoring activities of effort also reduces the length of projects and
are typically lost after some time if they are not therefore, cost and time-to-market. Furthermore,
documented in external documents or defect man- refactoring improves product quality and there-
agement systems (e.g., bugzilla). And even these fore is able to reduce the complexity and size of

94
Handling of Software Quality Defects in Agile Software Development

software systems. Especially in agile software defect documentation


development, methods as well as tools to sup-
port refactoring are becoming more and more Today, various repositories exist for document-
important (Mens, Demeyer, Du Bois, Stenten, ing of information about defects, incidents, or
& Van Gorp, 2003). other issues regarding software changes. This
However, performing manual discovery of information can be stored in configuration man-
quality defects that should be refactored result agement systems (e.g., CVS, SourceSafe), code
in either very short or costly refactoring phases. reuse repositories (e.g., ReDiscovery, InQuisiX),
While several automations for refactoring have or defect management systems.
already been developed (e.g., “extract method” The last category is also known as bug tracking
refactoring), the location, analysis, and removal (Serrano et al., 2005), issue tracking (Johnson &
is still an unsystematic, intuitive, and manual Dubois, 2003), defect tracking (Fukui, 2002), or
process. Today, several techniques and methods source code review systems (Remillard, 2005).
exist to support software quality assurance (SQA) They enable a software engineer to record in-
on higher levels of abstraction (e.g., requirement formation about the location, causes, effects, or
inspections) or between development iterations reproducibility of a defect. Typical representatives
(e.g., testing). Organizations use techniques like of defect management systems are open-source
refactoring to tackle quality defects (i.e., bad variants such as Bugzilla (Serrano et al., 2005),
smells in code (Beck & Fowler, 1999), architecture Scarab (Tigris, 2005), Mantis (Mantis, 2005),
smells (Roock et al., 2005), anti-patterns (Brown or TRAC (TRAC, 2005). Commercial versions
et al., 1998), design flaws (Riel, 1996; Whitmire, include Tuppas (Tuppas, 2005), Census from
1997), and software anomalies (IEEE-1044, 1995), Metaquest (MetaQuest, 2005), JIRA from At-
etc.) that reduce software quality. lassian (Atlassian, 2005), or SSM from Force10
Refactoring does not stop after discovery; (Force10, 2005). These tools are predominantly
even if we had solved the problem of discover- used in defect handling to describe defects on
ing every quality defect possible, the information the lower abstractions of software systems (i.e.,
about the defect, the rationales of whether it is source code) (Koru & Tian, 2004) separated from
removed (or not), and the refactorings used have the code.
to be documented in order to support maintainers Defect classification schemes (Freimut, 2001;
and reengineers in later phases. If one knows how Pepper, Moreau, & Hennion, 2005) like ODC (Or-
to remove a specific quality defect or a group of thogonal Defect Classification) (Chillarege, 1996)
quality defects, one still needs support, as it is not are used, for example, in conjunction with these
clear where and under which conditions refactor- tools to describe the defects and the activity and
ing activities should be used. Furthermore, product status a defect is involved in. The ODC process
managers need support to organize chains of refac- consists of an opening and closing process for
torings and to analyze the impact of changes due to defect detection that uses information about the
refactorings on the software system. Analogously, target for further removal activities. Typically,
quality managers and engineers need information removal activities are executed, but changes,
to assess the software quality, identify potential decisions, and experiences are not documented
problems, select feasible countermeasures, and at all—except for small informal comments when
plan the refactoring process as well as preventive the software system is checked into a software
measures (e.g., code inspections). repository like CVS.

95
Handling of Software Quality Defects in Agile Software Development

From our point of view, the direct storage of tion provided in the source code and its JavaDoc
information about defects, decisions about them, tags.
or refactorings applied in the code (as a central Typical content of code annotations is, for
point of information) via annotation languages example, used to describe the:
such as JavaDoc (Kramer, 1999), doxygen (van
Heesch, 2005), or ePyDoc (Loper, 2004) seems • Purpose of a class, field, or method.
to be a more promising solution. The next section • Existence of (functional) defects or work-
describes the relevant background and related arounds.
work for annotation languages, which are used • Examples of using the code fragment.
to record historical information about the evolu-
tion of a code fragment (e.g., a method, class, In the following sections and tables, we de-
subsystem, etc.). scribe the tags currently available for annotating
source code using JavaDoc. JavaDoc is a name
source code Annotation Languages for an annotation language as well as the name
of a tool from Sun Microsystems to generate
Annotation languages such as JavaDoc (Kramer, API documentation and is currently the industry
1999), ePyDoc (ePyDoc, 2005), ProgDOC (Simo- standard for documenting software systems in
nis & Weiss, 2003), or Doxygen (van Heesch, 2005) Java. The tool uses the tags from the JavaDoc
are typically used to describe the characteristics language to generate the API documentation in
and functionality of code fragments (i.e., classes, HTML format. It provides an API for creating
methods, packages, etc.) in the source code itself doclets and taglets, which allows extending the
or in additional files. Today several extensions, system with one’s own tags (via taglets) and the
especially to JavaDoc, are known that enable us documentation with additional information (via
to annotate which patterns (Hallum, 2002; Tor- doclets).
chiano, 2002), aspects (Sametinger & Riebisch, As listed in 0, JavaDoc currently consists of
2002), or refactorings (Roock & Havenstein, 19 tags that might be used to describe distin-
2002) were or will be used on the source code, guished information (e.g., such as return values
and which help us to describe characteristics such of a method) or to format text passages (e.g., to
as invariants, pre-/ post-conditions, or reviewer emphasize exemplary source code). The standard
names (JSR-260, 2005; Tullmann, 2002). These tags appear as “@tag” and might include inline
extensions to the annotation language are called tags, which appear within curly brackets “{@
taglets. They are used by doclets in the extraction tag}.” Inline tags only appear within, respectively
using, for example, the JavaDoc program. These behind, standard tags or in the description field
tools collect the distributed information blocks (e.g., “@pat.name … {@pat.role …}”).
and generate a (online) documentation rendered Developers can use the JavaDoc tags when
in HTML or another file format (e.g., PDF) for documenting source code in a special comment
better viewing. Typically, these documentations block by starting it with “/**” and ending it with
describe the application program interface (API) “*/.” A tag is indicated by using an “@” (“at”) sign
as a reference for software engineers. Similarly, right before the tag name. An example of a JavaDoc
tools and notations like Xdoclet offer additional comment used for a method is in Box 1.
tags that are used to generate many artifacts such As an extension to JavaDoc, four refactoring
as XML descriptors or source code. These files tags were developed in Roock et al. (2002) as
are generated from templates using the informa- described in 0.

96
Handling of Software Quality Defects in Agile Software Development

Box 1.
/** Start of JavaDoc comment
* Sorts an array using quicksort Description of the method
* @author John Doe Indicate the author
* @param productArray Describe a parameter
* @return Array The sorted array Describe the return value
*/ End of JavaDoc comment

Table 1. General tags of the JavaDoc annotation language


Tag Description Origin Type
@author May appear several times and indicates who has created or modified the JavaDoc 1.0 Context
code.
@param Describes one parameter of a method (or template class). JavaDoc 1.0 Function
@return Describes the returned object of a method. JavaDoc 1.0 Function
@throws Describes the (exception-) objects that are thrown by this method. JavaDoc 1.2 Function
@exception Synonym for @throws. JavaDoc 1.0 Function
@version States the version of this code structure. JavaDoc 1.0 Context
@since States the version since when this code was implemented and available JavaDoc 1.1 Context
to others.
@deprecated Indicates that this code structure should not be used anymore. JavaDoc 1.0 Status
@see Adds a comment or link to the “See also” section of the documentation. JavaDoc 1.0 Reference
May link to another part of the documentation (i.e., code).
@serialData Comments the types and order of data in a serialized form. JavaDoc 1.2 Context
@serialField Comments a ObjectStreamField. JavaDoc 1.2 Context
@serial Comments default serializable fields. JavaDoc 1.2 Context
<@code> Formats text in code font (similar to <code>). JavaDoc 1.5 Format
<@docRoot> Represents the relative path to the root of the documentation. JavaDoc 1.3 Reference
<@inherit- Copies the documentation from the nearest inherited code structure. JavaDoc 1.4 Reference
Doc>
<@link> Links to another part of the documentation (i.e., code structure) as the JavaDoc 1.2 Reference
@see tag but stays inline with the text and is formated as “code.”
<@linkPlain> Identical to <@link> but is displayed in normal text format (i.e., not JavaDoc 1.4 Reference
code format).
<@literal> Displays text without interpreting it as HTML or nested JavaDoc. JavaDoc 1.5 Format
<@value> The value of a local static field or of the specified constant in another JavaDoc 1.4 Reference
code.

Table 2. Refactoring tags by Roock et al. (2002)


Tag Description
@past Describes the previous version of the signature.
@future Describes the future signature of the element.
@paramDef States the default value expected for a parameter. The syntax is @paramDef <parameter> =
<value>.
@default Defines the default implementation of an abstract method.

97
Handling of Software Quality Defects in Agile Software Development

Table 3. Pattern tags by Torchiano (2002)


Tag Description
@pat.name States the standard name of the pattern as defined in (Gamma, Richard, Johnson, & Vlissides,
1994) (and other).
<@pat.role> Inline-tag of pat.name that describes the part of the pattern that is represented by this element
(e.g., “Leaf” in a composite pattern).
@pat.task Describes the task performed by the pattern or its role.
@pat.use Describes the use of the pattern or a role, typically by a method.

Table 4. Other tags


Tag Description
@contract Defines bounds of a parameter (or other value). Syntax is “@contract <requires> <min> <=
<parameter> <= <max>.”
@inv, @invariant States an invariant. Syntax is “@inv <boolean expression>.”
@pre States the precondition for a method.
@post States the postcondition for a method. This includes information about side effects (e.g.,
changes to global variables, fields in an object, changes to a parameter, and return values (ex-
cept if stated in @return).
@issue Indicates a new requirement or feature that could be implemented. Syntax is @issue [descrip-
tion ...].
@reviewedBy Indicates a code review for the associated class/interface was completed by a reviewer. Syntax
is @reviewedby <name> <date> [notes ...].
@license Indicates the copyright license used for this code fragment. Syntax is @license [description ...].
@category Annotates the element with a free attribute / category. @category <category>.
@example @example <description>.
@tutorial Link to a tutorial.
@index Defines the text that should appear in the index created by JavaDoc.
@exclude States that this element should not be included in the API by the JavaDoc command.
@todo Indicates that further work has to be done on this element.
@internal Comments to this element that are internal to the developer or company.
@obsolete Used if deprecated elements are actually removed from the API.
@threadSafe Indicates whether this element is threadsafe.
@pattern Formally describes a pattern existence with the syntax @pattern <pattern name>.<instance
name> <role name> <text>.
@aspect Describes an aspect existence with the syntax @aspect <name> <text>.
@trace Describes a pattern existence with the syntax @trace <name> <text>.

98
Handling of Software Quality Defects in Agile Software Development

Table 5. Annotation languages in comparison

# of Refactoring
Extension Test Info Inspection Info Pattern Info
Language Tags Info
Standard 19 No No No No
Roock et Semi-Formal
5 No No Informal (4)
al. (1)
Torchiano Semi-Formal
10 No No No
(3)
JavaDoc 1.5
Samet-
3 No No Informal (3) No
inger et al.
Tullmann 4 No Informal (1) No No
Kramer 3 Informal (3) No No No
JSR-260 9 No No No No

To note the existence of patterns in a software 3. Informal: An unstructured and possibly


system as well as the task and role as described in ambiguous specification of content.
the pattern definitions, several tags were developed
by Torchiano (2002) and are listed in 0. In summary, the tags used in JavaDoc and its
Furthermore, several other groups of annota- extensions can be used to describe characteristics
tions exist for various purposes. The following tags of the source code on a relatively granular or semi-
are from Roock et al. (2002) (@contract), Kramer formal level. The processing of these annotations
(1998) (@inv, @pre, @post), Tullmann (2002) (@ can be used to generate API documentations with
issue, @todo, @reviewedBy, @license), Samet- additional information about patterns, aspects,
inger et al. (2002) (@pattern, @aspect, @trace), or signature changes. The recording of quality
and JSR-260 (2005) (@category, @example, @ defects discovered and refactorings applied as
tutorial, @index, @exclude, @todo, @internal, well as rationales or experiences about their ap-
@obsolete, @threadSafe). plication can only be accomplished using free
The characteristics of source code annotation text in the API description.
languages can be differentiated by the number of Furthermore, these annotation languages and
tags and the formality of their expressiveness. their extensions have different target areas in the
We differentiate between three categories of field of software quality assurance in order to store
formality: information about tests, inspections, patterns, and
refactorings. 0 shows a comparison of several
1. Formal: An explicit and unambiguous speci- annotation languages in relevant areas.
fication of the content. A formal tag might
include an informal section like a descrip- Quality defects and Quality defect
tion or note to the formal part (e.g., the tag discovery
“param” in JavaDoc has an informal part
to describe the meaning of the parameter). The main concern of software quality assurance
In particular, the formal part of a tag must (SQA) is the efficient and effective development of
be processable by a computer. large, reliable, and high-quality software systems.
2. Semi-formal: A structured or formal rep- In agile software development, organizations use
resentation that is ambiguous or not directly techniques like refactoring to tackle “bad smells in
processable by a computer. code” (Beck et al., 1999), which reduce software

99
Handling of Software Quality Defects in Agile Software Development

qualities such as maintainability, changeability, • Architectural Smells: Very similar to code


or reusability. Other groups of defects that do smells are architectural smells that describe
not attack functional, but rather non-functional problems on the design level. Yet, the 31
aspects of a software system are architecture architectural smells described in Roock et
smells (Roock & Lippert, 2004), anti-patterns al. (2005) do not only apply on the design
(Brown et al., 1998), design flaws (Riel, 1996; level but also on the code level. They typi-
Whitmire, 1997), and software anomalies in cally describe problems regarding classes in
general (IEEE-1044, 1995). object-oriented software and interrelations
In this chapter, we use the umbrella term between them.
quality defects (QD) for any defect in software • Anti-Patterns: Design patterns (Gamma
systems that has an effect on software quality et al., 1994) and anti-patterns (Brown et
(e.g., as defined in ISO 9126), but does not directly al., 1998) represent typical and reoccurring
affect functionality. Whether the quality defect is patterns of good and bad software architec-
automatically discoverable (Dromey, 1996, 2003) tures and were the start of the description
or not (Lauesen & Younessi, 1998), an annotation of many patterns in diverse software phases
language and method that can be used to support and products. While patterns typically state
the handling of quality defects should record in- and emphasize a single solution to multiple
formation about quality characteristics and qual- problems, anti-patterns typically state and
ity defects in order to represent their status and emphasize a single problem to multiple solu-
treatment history. This section will elaborate on tions. An anti-pattern is a general, proven,
this concept and describe several quality defects, and non-beneficial problem (i.e., bad solu-
their interrelation, symptoms, and effects. tion) in a software product or process. It
Today, various forms of quality defects exist strongly classifies the problem that exhibits
with different types of granularity. Some target negative consequences and provides a solu-
problems in methods and classes, while others tion. Built upon similar experiences, these
describe problems on the architecture or even anti-patterns represent “worst-practices”
process levels. In this chapter, we only focus on about how to structure or build a software
quality defects on the code level. The representa- architecture. An example is the “lava flow”
tives on this level are: anti-pattern, which warns about developing
a software system without stopping some-
• Code Smells: The term code smell is an times and reengineering the system. The
abbreviation of “bad smells in code,” which larger and older such a software system
were described in Beck et al. (1999). Today, gets, the more dead code and solidified (bad)
we have many code smells that are semi-for- decisions it carries along.
mally described and can be used for manual • Bug Patterns: These patterns are concerned
inspection and discovery. There are at least with functional aspects that are typically
38 known code smells with 22 in Fowler found in debugging and testing activities. In
(1999), 9 new ones in Wake (2003), 5 new Allen (2002), 15 bug patterns are described,
ones in Kerievsky (2005), and 2 in Tourwe which describe underlying bugs in a software
and Mens (2003). Code smells are indicators system.
for refactoring and typically include a set • Design Flaws and (Negative) Design Char-
of alternative refactoring activities in their acteristics: Whitmire (1997) describes nine
description, which might be used to remove distinct and measurable characteristics of an
them. object-oriented design. These characteristics

100
Handling of Software Quality Defects in Agile Software Development

such as “similarity” describe the degree to and break his reading flow. The most obvi-
which two or more classes or domain-level ous method for discovering long methods
abstractions are similar in terms of their is the metric number of lines (LOC) per
structure, function, behavior, or purpose. method. But the question of which method
• Design Heuristics: Design heuristics pro- is too long and constitutes a problem is not
vide support on how to construct software easily answered. This must either be speci-
systems and, in a way, define quality defects fied or found by detecting anomalies from
by their absence. They range from the “in- the standard distribution. Nevertheless,
formation hiding” principle to guidelines a method exceeding this threshold value
such as “Eliminate irrelevant classes from must not necessarily be shortened if other,
your design.” There are 61 design heuristics more important, quality constraints would
described in Riel (1996) and 14 principles be negatively affected.
described in Roock et al. (2005). 2. Shotgun Surgery: This denotes the problem
that several classes are always changed in
As listed, there are many quality defects of the same group, for example, if the system
various granularities and they are described in is adapted to a new database scheme and
different forms. To give a more concrete idea the same two classes are changed each time.
of quality, we describe two of them in the fol- The expandability of the system is thus
lowing: constrained, and if one class is forgotten
during a change, it is more likely to fail.
1. Long Method: In object-oriented program- The discovery of shotgun surgery is very
ming, one should pay attention to the fact difficulty and requires either change metrics
that methods are not too long. The longer or specified rules.
a method, the more difficult it is to be un-
derstood by a developer. Comprehensibility While these problems might not represent
and readability are negatively affected by the problems that have a directly tangible effect on
length of a method and thus negatively affect quality, they might become problematic in future
maintainability and testability. Moreover, evolution or refactoring activities and should be
a short understandable method typically removed as fast as possible—if the time is avail-
needs less comments than a long one. An- able. These are only two of many described qual-
other advantage of short methods is the fact ity defects. Nevertheless, they show that quality
that a developer does not constantly scroll defects describe problems on different levels of

Figure 2. Conceptual model of the quality defect ontology (software product level)

P revention
prevents

fosters causes causes


P re-dis pos ition C aus e Defect S ymptom
Solved by

T reatment

101
Handling of Software Quality Defects in Agile Software Development

Table 6. Examples for software engineering techniques


Example 1 Example 2
Predisposition Data processing system Lack of good architecture/design
Cause Large data processing algorithms Distributed functionality
Defect “Long method” “Shotgun surgery”
Side-effects of defect Increase analyzability effort Increased maintenance effort
Symptom Many lines of code Recurrent changes to the same units
Treatment Extract method Inline class(es)
Side-effects of treatment Increased subroutine calls (worsens Divergent change
performance)
Prevention Optimize algorithm (phase) Pattern-based architecture

complexity and might occur in parallel in one In the example on the right side, the predisposi-
situation (i.e., in one code fragment). tion “bad architecture” causes a “cluttered func-
0 depicts the general model for the concepts tionality,” which results in a “shotgun surgery”
that are used to describe quality defects and that defect. This quality defect can be discovered by
are linked to them. A software system might have the symptom of “recurring changes to the same
predispositions that foster or enable the creation set of software units” and might be removed by
of quality defects. These defects themselves have the “inline class” refactoring. A prevention of this
causes that are responsible for the defects being problem would be a “good” systematic architecture
integrated into the system. The quality defects with clear separation of functionality (e.g., in the
might have a negative as well as a positive ef- form of a pattern-based architecture).
fect on specific qualities and are perceivable via
specific symptoms. Finally, the defects are solved Handling of Quality defects
or removed via specific treatments after they are
discovered, or the causes might be prevented by Typically, during agile development with short
special preventive measures. iterations, several quality defects are introduced
In software engineering (SE) and especially into the software system and are discovered es-
in the case of quality defects for a software prod- pecially in the refactoring phase. To facilitate the
uct, the context of a defect can be described as annotation of source code and the processing of
listed in 0.

Figure 3. The quality defect discovery and handling process model

Quality QM Quality Effects


M odel Dev.

M ark
Code

SW Code & Discover Plan A nalyze A nnotation Document A nalyze


Dev. V ersions Defects Removal Defect Language Change Cause

QDD QD Refactor
Techniques M odel Code

Quality defect Handling


Prevention

102
Handling of Software Quality Defects in Agile Software Development

quality defect removal, a mechanism to store the • Mark Code: If a potential quality defect
information from the QDD process is required. is unavoidable or its removal would have
a negative impact on an important quality
the Handling Process (e.g., performance), this decision is recorded
in the affected part of the software system
In the following, the general process of quality to prevent future analysis of this part.
defect discovery and refactoring is depicted. 0 • Document Change: After the refactoring or
shows the process model that is either initiated marking, the software system is annotated
during software development or during a special with specific tags about the change or deci-
maintenance (resp. refactoring) activity. sion, and the experience about the activity
In the execution of the process, the following is recorded within an experience database
sub-processes are performed: (i.e., a database in an experience factory
(Basili, Caldiera, & Rombach, 1994b) for
• Discover Defects: Manual or automatic storing, formalizing, and generalizing
quality defect discovery techniques are experiences about software development
used to analyze the source code and ver- and refactoring activities (e.g., to construct
sions thereof from the software repository. defect patterns from multiple similar defect
Potential quality defects are identified and descriptions)).
the affected code (of the most current ver- • Analyze Cause: Statistics, information, and
sion) is annotated. experiences about the existence of quality
• Plan Removal: Based on the discovered defects in the software systems are fed back
quality defects (annotated with a special into the early phases of the software develop-
tag) and a previously defined quality model, ment process to prevent or at least reduce
a sequential plan for the refactoring of the their reoccurrence. Preventive measures
software system (or part thereof) is con- include, for example, software requirement
structed. inspections or goal-oriented training of
• Analyze Defects: The software engineer employees. Furthermore, information about
processes the list of potential quality de- dependencies between qualities, quality de-
fects based on their priority, analyzes the fects, and refactorings are fed back into the
affected software system (or part thereof), quality model development process in order
and decides if the quality defect is truly to continuously improve the techniques for
present and if the software system can be quality model development.
modified without creating too many new
quality defects. decision support in Handling
• Refactor Code: If the quality defect is to
be removed from the software system, the In order to support decisions about what to refac-
engineer is briefed about the existing qual- tor in a software system, we developed several
ity defects and their rationales as well as methods and techniques. The following questions
about available refactorings, their impact act as the guiding theme for the development and
on software quality, and previously made enactment of decision-making (i.e., the “plan
experiences with the kind of quality defect removal” or “refactor code” phase) as well as
and refactoring at hand. understanding (i.e., the “analyze defect” or “docu-
ment change” phase) in refactoring phases:

103
Handling of Software Quality Defects in Agile Software Development

• Decision problem 1: Which quality defects decision support in software


should be refactored and which might stay refactoring
in the system?
• Decision problem 2: In which sequence Our approach encompasses several methods for
should one refactor multiple quality defects supporting the decision of where, when, and in
in order to minimize effort? what sequence to refactor a software system as
• Comprehension problem 1: How does one depicted in 0. Beginning from the left upper corner
understand and detect the quality defect in and going counterclockwise, knowledge about
the concrete situation? quality defects from defect discovery processes
• Comprehension problem 2: How does one is used to retrieve experiences associated with
understand the refactoring in the concrete similar defects from previous refactorings. These
situation and its effect on the software sys- experiences are used to handle quality defects in
tem? the defect removal phase. Additionally, suitable
• Decision problem 3: Which refactoring experiences are augmented by so-called micro-
should one use if multiple ones are avail- didactical arrangements (MDA) (Ras, Avram,
able? Waterson, & Weibelzahl, 2005), which initiate
• Comprehension problem 3: Which infor- learning processes and aim at improving the
mation should one record after refactoring understandability, applicability, and adaptability
or marking for later evolution, maintenance, of the experience in the specific context.
or reengineering activities? As shown in 0, we define six phases, based on
• Decision problem 4: Did the understanding the quality improvement paradigm (QIP) (Basili,
of the problem or the refactoring result in Caldiera, & Rombach, 1994a), for the continuous
valuable experience that should be recorded handling of quality defects. In contrast to the qual-
to support later activities (possibly by oth- ity defect handling process as depicted in 0, these
ers)? phases are not concerned with quality defects in
• Comprehension problem 5: How should a specific product, but with the learning process
one record the experience? about the quality defects themselves and their

Figure 4. Experience-based semi-automatic reuse of refactoring experiences


Project n

micro-didactical
Project 1 defect removal
Daily Arrangement (mdA)
Phase
Work e.g., augmented
e.g., Refactoring
refactoring experiences

software documents Pedagogical Agent


e.g., Code, Designs, …
pattern
learning Refactoring learning
goal experience elements
Defect Discovery

software Validation software Verification software diagnosis


e.g., Code Testing e.g., Inspections e.g., Code Analysis, refactoring
Mining Experiences
LEb Pb
Finding bugs, code smells, defect flaws, ... Creation of MDAs SE-Ontology

defects selected
selection of Experience
e.g., Bugs, refactoring
e.g., Inspections
Code smells experience

104
Handling of Software Quality Defects in Agile Software Development

effect on the software qualities. 0 represents the our work and continuously improve the model of
realizations of phase 2 (“discover defect”), phase 3 relationships between quality, refactorings, and
(“plan removal”), and phase 4 (the “quality defect quality defects.
handling” block). As indicated previously, the KDD sub-pro-
In 0, we first start with the definition of the cesses are grouped in phase 2. We select source
quality model consisting of qualities that should code from a specific build, preprocess the code,
be monitored and improved. For example, this and store the results in the code warehouse, ana-
may result in different goals (i.e., quality as- lyze the data to discover quality defects, discover
pects), as reusability demands more flexibility deviations from average behavior, cluster code
or “openness,” while maintainability requires blocks with severe or multiple quality defects,
more simplicity. Phase 2 is concerned with the and represent discovered and prioritized quality
measurement and preprocessing of the source code defects to the user.
to build a basis for quality defect discovery (i.e.,
“discover defects”). Results from the discovery An Example of ds for Qdd
process (i.e., quality defects) are represented and
prioritized to plan the refactoring in phase 3 (i.e., For example, we may detect a method in an ob-
“plan removal”). Here, the responsible person has ject-oriented software system that has a length of
to decide which refactorings have to be executed 300 LOC. As described in Fowler (1999), this is
(i.e., “analyze defect”) in what configuration and a code smell called long method. A long method
sequence, in order to minimize work (e.g., change is a problem especially in maintenance phases, as
conflicts) and maximize the effect on a specific the responsible maintainer will have a hard time
quality. In phase 4, the refactoring itself is (or is understanding the function of this method.
not) applied to the software system (i.e., “Refactor One suitable refactoring for the mentioned
Code” or “Mark Code”) by the developer, which code smell might be the refactoring simply called
results in an improved product. Phase 5 compares extract method: the source code of the long
the improved product with the original product to method is reviewed to detect blocks that can be
detect changes and their impact on the remaining encapsulated into new (sub-)methods. Experiences
system (i.e., “analyze cause”). Finally, in phase with the extract method refactoring are used to
6, we document the experiences and data about support the decision on where, when, how, and
the refactoring activity, changes to the software if the refactoring has to been implemented. For
system, and other effects in order to learn from example, the developer might remark that every
block of code that has a common meaning, and
could be commented respectively, could also be
Figure 5. Quality-driven refactoring extracted into several smaller methods. Further-
more, the developer might note that the extraction
1. define
Qualities of (sub-) methods, from methods implementing
complex algorithms, can affect the performance
6. report 2. Analyze
change Product requirements of the software system and therefore
might not be applicable.
Additionally, the generation of new methods
refactoring
Experiences

5. monitor
Quality
3. Plan
refactoring
might create another smell called “large class”
(i.e., the presence of too many methods in a class),
4. refactor which might complicate the case even further.
Product
Finally, the new experiences are annotated by

105
Handling of Software Quality Defects in Agile Software Development

the developer and stored in the refactoring ex- the software documentation such as design
perience base. documents).
While this example only touches a simple
quality defect and refactoring, more complex In our case, an annotation language that is
refactorings influence inheritance relations or targeted at supporting the handling of quality
introduce design patterns (Fowler, 1999). defects should encompass several key aspects.
The requirements for such an annotation language
An Annotation Language to support should cover uses such as:
Quality defect Handling
• Annotate change for later understanding by
This section describes, defines, and explains a the same and other readers (e.g., maintain-
language that will be used to annotate code frag- ers).
ments that are either contaminated by quality • Mark fragment that a quality defect is de-
defects or checked by a software engineer and tected but can or must stay in the system.
cleared of quality defects. As described in the • Note membership in a larger quality defect
background section, several annotation languages or refactoring activity that encompassed
for the annotation of source code already exist multiple code fragments for later impact
that are not adequate. This new language is used analyses.
to keep decisions about quality defects persistent • Annotate quality aspects for later reuse,
and over time builds a “medical history” of the etc.
source code fragment (e.g., a class). • Tag additional information in the code
fragment freely or based on a classification
goals and characteristics of (e.g., “problematic class,” “quicksort algo-
Annotation Languages rithm,” “part of subsystem X”) to support
later reuse or maintenance/reengineering
All annotation languages represent a basis for activities (similar to social software or Web
describing additional information about the 2.0 approaches).
software system directly at the code level. Target
groups (or users) for the documentation/annota- We identified the following information blocks
tion language are: of an annotation language that should be recorded
with an annotation language and that are based
• Developers, who want to use the source on the six knowledge types from knowledge
code and acquire information via the API management (Mason, 2005):
descriptions (e.g., for software libraries).
• Testers, who want to develop test cases and • Know-what: Record the currently present
need information about the pre- and post- quality defects that were found manually or
conditions as well as the functionality to be automatically.
tested. • Know-how: Record the transformation
• Maintainers, who want to evolve the system history (similar to the medical history of a
and need information about existing qual- human patient).
ity defects, rationales for their persistence • Know-why: Record the rationales why a
(e.g., refactoring would cause loss of perfor- refactoring was applied or why a quality
mance), or past refactorings (e.g., to update defect is still present in order to prevent

106
Handling of Software Quality Defects in Agile Software Development

recurrent defect analysis or refactoring at- occurrence of two or more tags should be
tempts. independent from one another.
• Know-where: Record the location in the
annotated code as well as associated code Beside the additional documentation of the
fragments that where changed as well. software system, the annotation language will
• Know-who: Record the tool or person (i.e., increase the semantic coupling between code
developer or maintainer) who applied the fragments and reduce the presence of quality
refactoring. defects such as “shotgun surgery.”
• Know-when: Record the time or version
when the quality defect was found or the RAL: The Refactoring Annotation Language
refactoring was applied. This could also be
used to define a trigger when a refactoring The refactoring annotation language (RAL)
has to be applied (e.g., if several other (larger) is used to record the currently existing quality
refactorings or design decision have to be characteristics, symptoms, defects, and refac-
made). toring of a code fragment regarding a specific
• Context: Record the frame of reference quality model. Furthermore, it is used to store the
or context in which the quality defect was rationales and treatment history (e.g., sequence
discovered. This includes especially the of refactorings).
quality model used to decide which quality In the following tables, the core set of tags
defect has a higher priority over other quality from RAL are described based on the JavaDoc
defects. syntax and using existing JavaDoc and supportive
tags, that are used in the description and will be
The following requirements for tags and other described after the core tags. Information blocks
constructs in such an annotation language to sup- starting with a double cross “#” indicate an ID or
port refactoring and maintenance activities are: standardized term from an external, controlled
vocabulary or taxonomy.
• Unambiguous: The names of tags, quality A symptom tag as defined in 0 describes a
defects, refactorings, or other reoccurring metric or characteristic of the code fragment and
terms should be unique and used consistently is used as an indicator for the statistical or rule-
throughout the system. based identification of quality defects. The tag
• Machine-readable: The syntax of tags acts as an annotation of a specific symptom from
should be formal, exact, and consistent to a controlled vocabulary in order to have a unique
avoid confusion and enable the interpreta- identifier and a reference for further information
tion and usage by supporting systems (e.g., about the symptom. The since tag from JavaDoc
defect discovery tools). is used to identify the version based on which the
• Local completeness: The power of the quality symptom was first calculated.
syntax should be large enough to cover all The quality defect as defined in 0 represents a
existing cases. Full comprehensiveness is code smell, antipattern, etc. present in this code
probably not possible except by allowing fragment. It is used to annotate a specific quality
informal free text attributes. defect from a controlled vocabulary in order to
• Flexibility: The syntax should not limit the have a unique identifier and reference for more
extension by new tags or tag attributes. information about a specific quality defect type
• Independence: Tags should describe infor- and potential treatments. The since tag from Ja-
mation that is mutually exclusive, and the

107
Handling of Software Quality Defects in Agile Software Development

Table 7. The @symptom tag

Tag Syntax @symptom <#Symptom-ID> <@value value> <@since #version>


Example @symptom “LOC” @value “732” @since 1.2

Table 8. The @defect tag


Tag Syntax @defect <#QD-ID> <@since #version> <@status #Status> <@rationale text>
Example @defect “Long Method” @since 1.2 @status “untreated”

Table 9. The @refactoring tag


Tag Syntax @refactoring <#Refactoring-ID> <@rationale text> <@status #Status> <@link fragment> <@
author name>
Example @refactoring “Extract Method” “Applied as quality model rates maintainability higher than per-
formance” @status “treated” @link “ExtractedMethod” @author “John Doe”

Table 10. The @quality-model tag

Tag Syntax: @quality-model Name <@see file>


Example @quality-model “QM-Dep1-Project2” @see <A href=http://www.sw-quality.de/QM-Dep1-Project2.pdf>

Table 11. Support tags


Tag Description
“@status #status” indicates the current status of the superior tag or source code using the vocabulary
@status
“discovered,” “inWork,” “treated,” or (deliberately) “untreated.”
@rationale “@rationale text” declares a rationale about the existence or status of the superior tag or source code.

vaDoc is used to identify the version where the The supportive tags used in the previous tag
quality defect was first noticed. descriptions are given in 0.
A refactoring tag as defined in 0 is a descrip- Depending on the processor that would render a
tion of a single refactoring that was applied for quality documentation from these tags, some tags
removing one or more quality defects. Optionally, might be used only once and inherited by lower
a project-internal URI to other code fragments levels. For example, the quality model tag needs
directly affected by the refactoring (e.g., if two only be stated once (e.g., for the whole project)
classes interchange a method during the same or twice (e.g., for the client and server part) in a
refactoring) can be stated. software system.
The quality model tag as defined in 0 is used RAL is primarily used to annotate source
as a reference to the quality model that defines code. Therefore, in order to annotate documents
which quality characteristics are important, what of higher abstraction, like UML-based design
priority or decision model lies beneath, and which documents (e.g., platform-independent models in
quality defects are relevant to a specific part of the MDA) using the XMI Format or formal require-
software system. Optionally, it refers to a URI of ment documents, similar languages (probably
a file containing the specific (machine-readable) based on other languages such as JavaDoc) need
quality model. to be defined.

108
Handling of Software Quality Defects in Agile Software Development

Handling Quality defects using rAL • Product or quality managers of the software
system might use the information to:
Software annotation languages like JavaDoc or • Evaluate the quality based on information
Doxygen and extensions like RAL can now be used extracted via the tags about the amount or
to document the functionality, structure, quality, distribution of quality defects.
and treatment history of the software system at • Analyze specific dates or groups of persons
the code level. The formal basis of the language that might have introduced specific kinds
enables tools to read and write this information of quality defects and might need further
automatically to generate special documents or training.
trigger specific actions.
The core tags @symptom, @defect, and @
refactoring build on top of each other and summAry And outLook
might be recorded by several different tools. This
enables the intertwined cooperation of different Agile software development methods were
tools, each with a specific focus, such as to cal- invented to minimize the risk of developing
culate metrics or to discover quality defects. For low-quality software systems with rigid process-
example, one tool might measure the source code based methods. They impose as little overhead
and its versions to extract numerical and histori- as possible in order to develop software as fast
cal information and write it into @symptom tags as possible and with continuous feedback from
(e.g., lines of code). Another tool might analyze the customers. To assure quality, agile software
this information to infer quality defects (e.g., development organizations use activities such
“long method”) that are recorded in @defect as refactoring between development iterations.
tags. Finally, a tool might offer refactorings to a Refactoring, or the restructuring of a software
developer or a maintainer during his work and system without changing its behavior, is neces-
note applied refactorings or rationales in explicit sary to remove quality defects (i.e., bad smells in
@refactoring tags. code, architecture smells, anti-patterns, design
Developers and maintainers of a software flaws, software anomalies, etc.) that are introduced
system are supported in the handling of quality by quick and often unsystematic development.
defects in the following activities: However, the effort for the manual discovery of
these quality defects results in either incomplete or
• Repetitive refactoring of a specific kind costly refactoring phases. Furthermore, software
of quality defect (e.g., “large method”), as quality assurance methods seem to ignore their
they do not have to switch between different recurring application.
defects or refactoring concepts. In this chapter, we described a process for the
• Reuse of knowledge about the refactoring of recurring and sustainable discovery, handling, and
specific quality defects to judge new quality treatment of quality defects in software systems.
defects. We described the complexity of the discovery
• Recapitulation of the change history of the and handling of quality defects in object-oriented
code fragment to update software documen- source code to support the software refactoring
tation such as design documents. process. Based on the formal definition of qual-
• Retrieval of information about persons who ity defects, we gave examples of how to support
developed or refactored this part of the sys- the recurring and sustainable handling of quality
tem and should know about its purpose and defects. The annotation language presented is
functionality. used to store information about quality defects

109
Handling of Software Quality Defects in Agile Software Development

found in source code and represents the defect and the developers, testers, and maintainers should
treatment history of a part of a software system. be burdened with as little additional effort as
The process and annotation language can not possible.
only be used to support quality defect discovery Therefore, the more formal the descriptions
processes, but also has the potential to be applied of an annotation language are and the more in-
in testing and inspection processes. formation can be extracted from the code and
Recapitulating, we specified an annotation development environment (e.g., from the refactor-
language that can be used in agile software main- ing techniques), the less information is required
tenance and refactoring to record information from the developers.
about quality defects, refactorings, and rationales
about them. Similar annotation languages such as
JavaDoc or doxygen as well as third party exten- outLook
sions are not able to encode this information in a
machine-readable and unambiguous format. The trend in research is to increase automation of
The proposed framework including the the mentioned processes in order to support the
handling process promises systematic and semi- developers with automated refactoring or defect
automatic support of refactoring activities for discovery systems.
developers, maintainers, and quality managers. We expect to further assist software engineers
The approach for recording quality defects and and managers in their work and in decision mak-
code transformations in order to monitor refactor- ing. One current research task is the development
ing activities will make maintenance activities of taglets and doclets to generate specific evolution
simpler and increase overall software quality. documents. Furthermore, we are working on the
Likewise, the user monitors daily builds of the analysis and synthesis of discovery techniques
software to detect code smells, identical quality with statistical and analytical methods based
defects, or groups thereof, and initiates repetitive on textual, structural, numerical, and historical
refactoring activities, minimizing effort caused information.
by task switches. Although we can record and use this infor-
mation in several applications, we currently do
not know if the amount of information might
rEQuIrEmEnts for QuALIty overwhelm or annoy the developer and main-
dEfEct HAndLIng In AgILE sE tainer. If dozens of quality defects are found and
additional refactorings are recorded, this might
When building systems and languages for quality be confusing and should be hidden (e.g., in an
defect handling in agile software development, editor of the IDE) from the developer. Very old
several requirements should be kept in mind. information (e.g., from previous releases of the
The annotation language in the form of a code software) might even be removed and stored in
annotation language like JavaDoc or in the form an external document or database.
of an external documentation such as a Defect
Tracking system or a Wiki should be integrated
into the programming language used and into the rEfErEncEs
development environment. If it is not integrated,
the information might easily be lost due to the Allen, E. (2002). Bug patterns in Java. New York;
high workload and time constraints in agile de- Berkeley, CA: Apress.
velopment. Especially in an agile environment,

110
Handling of Software Quality Defects in Agile Software Development

Atlassian. (2005). JIRA Web site. Retrieved Dromey, R. G. (1996). Cornering the chimera.
October 6, 2005, from http://www.atlassian. IEEE Software, 13(1), 33-43.
com/software/jira/
Dromey, R. G. (2003). Software quality—Pre-
Aurum, A., Petersson, H., & Wohlin, C. (2002). vention versus cure? Software Quality Journal,
State-of-the-art: Software inspections after 25 11(3), 197-210.
years. Software testing. Verification and Reli-
ePyDoc. (2005). Epydoc Web site. Retrieved May
ability, 12(3), 133-154.
10, 2005, from http://epydoc.sourceforge.net/
Basili, V. R., Caldiera, G., & Rombach, D. (1994a).
Fenton, N. E., & Neil, M. (1999). Software metrics:
The goal question metric approach. In Encyclope-
Successes, failures, and new directions. Journal
dia of software engineering (1st ed., pp. 528-532).
of Systems and Software, 47(2-3), 149-157.
New York: John Wiley & Son.
Force10. (2005). Software support management
Basili, V. R., Caldiera, G., & Rombach, H. D.
system (SSM) Web site. Retrieved October 6, 2005,
(1994b). Experience factory. In J. J. Marciniak
from http://www.f10software.com/
(Ed.), Encyclopedia of software engineering (Vol.
1, pp. 469-476). New York: John Wiley & Sons. Fowler, M. (1999). Refactoring: Improving the de-
sign of existing code (1st ed.). Addison-Wesley.
Beck, K. (1999). eXtreme programming eX-
plained: Embrace change. Reading, MA: Ad- Freimut, B. (2001). Developing and using defect
dison-Wesley. classification schemes (Technical Report No.
IESE-Report No. 072.01/E). Kaiserslautern:
Beck, K., & Fowler, M. (1999). Bad smells in code.
Fraunhofer IESE.
In G. Booch, I. Jacobson, & J. Rumbaugh (Eds.),
Refactoring: Improving the design of existing Fukui, S. (2002). Introduction of the software
code (1st ed., pp. 75-88). Addison-Wesley Object configuration management team and defect track-
Technology Series. ing system for global distributed development.
Paper presented at the 7th European Conference
Brown, W. J., Malveau, R. C., McCormick, H. W.,
on Software Quality (ECSQ 2002), Helsinki,
& Mowbray, T. J. (1998). AntiPatterns: Refactor-
Finland, June 9-13, 2002.
ing software, architectures, and projects in crisis.
New York: John Wiley & Sons, Inc. Gamma, E., Richard, H., Johnson, R., & Vlis-
sides, J. (1994). Design patterns: Elements of
Brykczynski, B. (1999). A survey of software
reusable object-oriented software (3rd ed., Vol.
inspection checklists. Software Engineering
5). Addison-Wesley.
Notes, 24(1), 82-89.
Hallum, A. M. (2002). Documenting patterns.
Chillarege, R. (1996). Orthogonal defect classifica-
Unpublished Master Thesis, Norges Teknisk-
tion. In M. R. Lyu (Ed.), Handbook of software
Naturvitenskapelige Universitet.
reliability engineering (pp. xxv, 850 p.). New
York: IEEE Computer Society Press. IEEE-1044. (1995). IEEE guide to classification
for software anomalies. IEEE Std 1044.1-1995.
Ciolkowski, M., Laitenberger, O., Rombach, D.,
Shull, F., & Perry, D. (2002). Software inspections, Johnson, J. N., & Dubois, P. F. (2003). Issue track-
reviews, and walkthroughs. Paper presented at the ing. Computing in Science & Engineering, 5(6),
24th International Conference on Software Engi- 717, November-December.
neering (ICSE 2002), New York, USA, Soc.

111
Handling of Software Quality Defects in Agile Software Development

JSR-260. (2005). Javadoc Tag Technology Up- Mens, T., Demeyer, S., Du Bois, B., Stenten,
date (JSR-260). Retrieved October 6, 2005, from H., & Van Gorp, P. (2003). Refactoring: Current
http://www.jcp.org/en/jsr/detail?id=260 research and future trends. Electronic Notes in
Theoretical Computer Science, 82(3), 17.
Kerievsky, J. (2005). Refactoring to patterns.
Boston: Addison-Wesley. Mens, T., & Tourwe, T. (2004). A survey of soft-
ware refactoring. IEEE Transactions on Software
Koru, A. G., & Tian, J. (2004). Defect handling
Engineering, 30(2), 126-139.
in medium and large open source projects. IEEE
Software, 21(4), 54-61. MetaQuest. (2005). Census Web site. Retrieved
October 6, 2005, from http://www.metaquest.
Kramer, D. (1999, September 12-14). API docu-
com/Solutions/BugTracking/BugTracking.html
mentation from source code comments: A case
study of Javadoc. Paper presented at the 17th Inter- Pepper, D., Moreau, O., & Hennion, G. (2005,
national Conference on Computer Documentation April 11-12). Inline automated defect classifica-
(SIGDOC 99), New Orleans, LA. tion: A novel approach to defect management.
Paper presented at the IEEE/SEMI Advanced
Kramer, R. (1998). iContract—The Java(tm)
Semiconductor Manufacturing Conference and
Design by Contract(tm) Tool. In Technology of
Workshop, Munich, Germany.
object-oriented languages and systems, TOOLS
26 (pp. 295-307). Santa Barbara, CA: IEEE Rapu, D., Ducasse, S., Girba, T., & Marinescu,
Computer Society. R. (2004). Using history information to improve
design flaws detection. Paper presented at the 8th
Lauesen, S., & Younessi, H. (1998). Is software
European Conference on Software Maintenance
quality visible in the code? IEEE Software, 15(4),
and Reengineering, Tampere, Finland.
69-73.
Ras, E., Avram, G., Waterson, P., & Weibelzahl,
Liggesmeyer, P. (2003). Testing safety-critical
S. (2005). Using Weblogs for knowledge sharing
software in theory and practice: A summary. IT
and learning in information spaces. Journal of
Information Technology, 45(1), 39-45.
Universal Computer Science, 11(3), 394-409.
Loper, E. (2004). Epydoc: API documentation
Rech, J. (2004). Towards knowledge discovery
extraction in python. Retrieved from http://epydoc.
in software repositories to support refactoring.
sourceforge.net/pycon-epydoc.pdf
Paper presented at the Workshop on Knowledge
Mantis. (2005). Mantis Web site. Retrieved Octo- Oriented Maintenance (KOM) at SEKE 2004,
ber 6, 2005, from http://www.mantisbt.org/ Banff, Canada.
Marinescu, R. (2004, September 11-14). Detec- Rech, J., & Ras, E. (2004). Experience-based
tion strategies: Metrics-based rules for detecting refactoring for goal-oriented software quality
design flaws. Paper presented at the 20th Inter- improvement. Paper presented at the 1st Interna-
national Conference on Software Maintenance, tional Workshop on Software Quality (SOQUA
Chicago, IL. 2004), Erfurt, Germany.
Mason, J. (2005). From e-learning to e-knowl- Remillard, J. (2005). Source code review systems.
edge. In M. Rao (Ed.), Knowledge management IEEE Software, 22(1), 74-77.
tools and techniques (pp. 320-328). London:
Riel, A. J. (1996). Object-oriented design heuris-
Elsevier.
tics. Reading, MA: Addison-Wesley.

112
Handling of Software Quality Defects in Agile Software Development

Roock, S., & Havenstein, A. (2002). Refactor- on Software Maintenance (ICSM), Montreal,
ing tags for automatic refactoring of framework Que., Canada.
dependent applications. Paper presented at the
Tourwe, T., & Mens, T. (2003). Identifying refac-
Extreme Programming Conference XP 2002,
toring opportunities using logic meta program-
Villasimius, Cagliari, Italy.
ming. IEEE Computer, Reengineering Forum;
Roock, S., & Lippert, M. (2004). Refactorings in Univ. Sannio. In Proceedings 7th European
großen Softwareprojekten: Komplexe Restruktu- Conference on Software Maintenance and Reen-
rierungen erfolgreich durchführen (in German). gineering, Los Alamitos, CA (xi+2420 2091-2100).
Heidelberg: dpunkt Verlag. IEEE Comput. Soc.
Roock, S., & Lippert, M. (2005). Refactoring in TRAC. (2005). TRAC Web site. Retrieved October
large software projects. John Wiley & Sons. 6, 2005, from http://projects.edgewall.com/trac/
Sametinger, J., & Riebisch, M. (2002, March Tullmann, P. (2002). Pat’s taglet collection.
11-13). Evolution support by homogeneously Retrieved October 6, 2005, from http://www.
documenting patterns, aspects, and traces. tullmann.org/pat/taglets/
Paper presented at the 6th European Conference
Tuppas. (2005). Tuppas Web site. Retrieved
on Software Maintenance and Reengineering,
October 6, 2005, from http://www.tuppas.com/
Budapest, Hungary.
Defects.htm
Serrano, N., & Ciordia, I. (2005). Bugzilla,
van Heesch, D. (2005). Doxygen—a documenta-
ITracker, and other bug trackers. IEEE Software,
tion system. Retrieved from http://www.doxygen.
22(2), 11-13.
org/
Simonis, V., & Weiss, R. (2003, July 9-12).
Verhoef, C. (2000, September 5-7). How to
PROGDOC—a new program documentation
implement the future? Paper presented at the
system. Paper presented at the 5th International
Proceedings of the 26th EUROMICRO Confer-
Andrei Ershov Memorial Conference (PSI 2003)
ence (EUROMICRO2000), Maastricht, The
Perspectives of System Informatics, Novosibirsk,
Netherlands.
Russia.
Wake, W. C. (2003). Refactoring workbook (1st
Tigris. (2005). Scarab Web site. Retrieved October
ed.). Pearson Education.
6, 2005, from http://scarab.tigris.org/
Whitmire, S. A. (1997). Object-oriented design
Torchiano, M. (2002, October 3-6). Documenting
measurement. New York: John Wiley & Sons.
pattern use in Java programs. Paper presented at
the Proceedings of the International Conference

113
114

Chapter VI
Agile Quality Assurance
Techniques for GUI-Based
Applications
Atif Memon
University of Maryland, USA

Qing Xie
Accenture Technology Labs, USA

AbstrAct

This chapter motivates the need for new agile model-based testing mechanisms that can keep pace with
agile software development/evolution. A new concentric loop-based technique, which effectively utilizes
resources during iterative development, is presented. The tightest loop is called crash testing, which
operates on each code check-in of the software. The second loop is called smoke testing, which operates
on each day’s build. The third and outermost loop is called the “comprehensive testing” loop, which
is executed after a major version of the software is available. Because rapid testing of software with a
graphical-user interface (GUI) front-end is extremely complex, and GUI development lends itself well
to agile processes, the GUI domain is used throughout the chapter as an example. The GUI model used
to realize the concentric-loop technique is described in detail.

IntroductIon through a window, a trash can, and the physical


layout in a room. Objects of a GUI include ele-
Agile software development has had a significant ments such as windows, pull-down menus, but-
impact on the development of software applica- tons, scroll bars, iconic images, and wizards. A
tions that contain a graphical user interface (GUI). software user performs events to interact with the
GUIs are by far the most popular means used to GUI, manipulating GUI objects as one would real
interact with today’s software. A GUI uses one objects. For example, dragging an item, discard-
or more metaphors for objects familiar in real ing an object by dropping it in a trash can, and
life such as buttons, menus, a desktop, the view selecting items from a menu are all familiar events

Copyright © 2007, Idea Group Inc., distributing in print or electronic forms without written permission of IGI is prohibited.
Agile Quality Assurance Techniques for GUI-Based Applications

available in today’s GUI. These events may cause testing. A related problem is to determine the
changes to the state of the software that may be coverage of a set of test cases (Memon, Soffa, &
reflected by a change in the appearance of one or Pollack, 2001c). For conventional software, cov-
more GUI objects. erage is measured using the amount and type of
Recognizing the importance of GUIs, software underlying code exercised. These measures do not
developers are dedicating an increasingly large work well for GUI testing because what matters
portion of software code to implementing GUIs- is not only how much of the code is tested, but in
-up to 60% of the total software code (Mahajan how many different possible states of the software
& Shneiderman, 1996; Myers, 1993a, 1995a, each piece of code is tested. An important aspect
1995b; Myers & Olsen, 1994). The widespread of GUI testing is verification of its state at each
use of GUIs is leading to the construction of step of test case execution (Memon, Pollack, &
increasingly complex GUIs. Their use in safety- Soffa, 2000a). An incorrect GUI state can lead
critical systems is also growing (Wick, Shehad, to an unexpected screen, making further execu-
& Hajare, 1993). tion of the test case useless since events in the
GUI-based applications lend themselves to test case may not match the corresponding GUI
the core practices of agile development, namely elements on the screen. Thus, the execution of
simple planning, short iteration, and frequent the test case must be terminated as soon as an
customer feedback. GUI developers work closely error is detected. Also, if verification checks are
with customers iteratively enhancing the GUI not inserted at each step, it may become difficult
via feedback. Although agile processes apply to identify the actual cause of the error. Finally,
perfectly to GUI software, integration testing regression testing presents special challenges for
of the GUI for overall functional correctness GUIs because the input-output mapping does
remains complex, resource intensive, and ad not remain constant across successive versions
hoc. Consequently, GUI software remains largely of the software (Memon & Soffa, 2003e; Myers,
untested during the iterative development cycle. Olsen, & Bonar, 1993b). Regression testing is
Adequately testing a GUI is required to help especially important for GUIs since GUI devel-
ensure the safety, robustness, and usability of an opment typically uses an agile model (Kaddah,
entire software system (Myers, Hollan, & Cruz, 1993; Kaster, 1991; Mulligan, Altom, & Simkin,
1996). Testing is, in general, labor and resource 1991; Nielsen, 1993).
intensive, accounting for 50-60% of the total cost The most common way to test a GUI is to wait
of software development (Gray, 2003; Perry, 1995). until the iterative development has ended and the
GUI testing is especially difficult today because GUI has “stabilized.” Testers then use capture/re-
GUIs have characteristics different from those of play tools (Hicinbothom & Zachary, 1993) such
traditional software, and thus, techniques typically as WinRunner (http://mercuryinteractive.com)
applied to software testing are not adequate. (Memon, 2003a) to test the new major GUI version
Testing the correctness of a GUI is difficult release. A tester uses these tools in two phases:
for a number of reasons. First of all, the space of a capture and then a replay phase. During the
possible interactions with a GUI is enormous, in capture phase, a tester manually interacts with
that each sequence of GUI events can result in a the GUI being tested, performing events. The tool
different state, and each GUI event may need to records the interactions; the tester also visually
be evaluated in all of these states (Memon, Pol- “asserts” that a part of the GUI’s response/state
lack, & Soffa, 1999, 2000b). The large number of be stored with the test case as “expected output”
possible states results in a large number of input (Memon & Xie, 2004c; Memon, Banerjee, &
permutations (White, 1996) requiring extensive Nagarajan, 2003d). The recorded test cases are

115
Agile Quality Assurance Techniques for GUI-Based Applications

replayed automatically on (a modified version model-based GUI testing techniques with the
of) the GUI using the replay part of the tool. The needs of agile software development. The key
“assertions” are used to check whether the GUI idea of this process is to create concentric test-
executed correctly. Another way to test a GUI ing loops, each with specific GUI testing goals,
is by programming the test cases (and expected requirements, and resource usage. Instances
output) using tools (Finsterwalder, 2001; White, of three such loops are presented. The tightest
2001) such as extensions of JUnit including loop called the crash testing loop operates on
JFCUnit, Abbot, Pounder, and Jemmy Module each code check-in (e.g., using CVS) of the GUI
(http://junit.org/news/extension/gui/index.htm). software (Xie & Memon, 2005). It is executed
The previous techniques require a significant very frequently and hence is designed to be very
amount of manual effort, typically yielding a small inexpensive. The goal is to perform a quick-and-
number of test cases. The result is an inadequately dirty, fully automatic integration test of the GUI
tested GUI (Memon, Nagarajan, & Xie, 2005a). software. Software crashes are reported back to
Moreover, during iterative development, develop- the developer within minutes of the check-in.
ers waste time fixing bugs that they encounter in The second loop is called the smoke testing loop,
later development cycles; these bugs could have which operates on each day’s GUI build (Memon
been detected earlier if the GUI had been tested et al., 2005a; Memon & Xie, 2004b; Memon &
iteratively. Xie, 2005b; Memon, Banerjee, Hashish, & Na-
The agile nature of GUI development requires garajan, 2003b). It is executed nightly/daily and
the development of new GUI testing techniques hence is designed to complete within 8-10 hours.
that are themselves agile in that they quickly test The goal of this loop is to do functional “refer-
each increment of the GUI during development. ence testing” of the newly integrated version of
This chapter presents a process with supporting the GUI. Differences between the outputs of the
tools for continuous integration testing of GUI- previous (yesterday’s) build and the new build are
based applications; this process connects modern reported to developers. The third, and outermost

Figure 1. Different loops of continuous GUI integration testing

Comprehensive GUI Testing


Smoke Testing

Crash Testing

Daily
DailyBuild
Buildi i Daily
DailyBuild
Build33

CVS
Check-inj

Daily
DailyBuild
Buildi i
Daily
DailyBuild
Build100
100

Major
MajorVersion
VersionRelease
Releasen n

116
Agile Quality Assurance Techniques for GUI-Based Applications

loop is called the “comprehensive GUI testing” bAckground


loop. It is executed after a major version of the
GUI is available. The goal of this loop is to con- software testing
duct comprehensive GUI integration testing, and
hence is the most expensive. Major problems in We now give an overview of software testing
the GUI software are reported. An overview of techniques. The goal of testing is to detect the
this process is shown in Figure 1. The small octa- presence of errors in programs by executing the
gons represent frequent CVS code check-ins. The programs on well-chosen input data. An error is
encompassing rectangles with rounded corners said to be present when either (1) the program’s
represent daily increments of the GUI. The large output is not consistent with the specifications, or
rectangle represents the major GUI version. The (2) the test designer determines that the specifica-
three loops discussed earlier are shown operating tions are incorrect. Detection of errors may lead to
on these software artifacts. changes in the software or its specifications. These
A novel feature of the continuous testing changes then create the need for re-testing.
process is a GUI model that is obtained by using Testing requires that test cases be executed on
automated techniques that employ reverse engi- the software under test (SUT) and the software’s
neering (Memon, Banerjee, & Nagarajan, 2003c). output be compared with the expected output by
This model is then used to generate test cases, cre- using a test oracle. The input and the expected
ate descriptions of expected execution behavior, output are a part of the test suite. The test suite is
and evaluate the adequacy of the generated test composed of tests each of which is a triple <iden-
cases. Automated test executors “play” these test tifier, input, output>, where identifier identifies
cases on the GUI and report errors. the test, input is the input for that execution of
The specific contributions of this work in- the program, and output is the expected output
clude: for this input (Rothermel & Harrold, 1997). The
entire testing process for software systems is done
1. Three distinctive product- and stakeholder- using test suites.
oriented, novelty (agile) approaches, and Information about the software is needed to
techniques that may be applied to the broad generate the test suite. This information may be
class of event-driven software applica- available in the form of formal specifications or
tions. derived from the software’s structure leading to
2. Comprehensive theoretical and practical the following classification of testing.
coverage of testing in the context of agile
quality. • Black-box testing (also called functional
testing (Beizer, 1990) or testing to specifica-
The remainder of this chapter will present an tions): A technique that does not consider the
overview of existing approaches used for GUI actual software code when generating test
testing and describe the continuous testing pro- cases. The software is treated as a black-box.
cess, including the three concentric testing loops, It is subjected to inputs and the output is veri-
the GUI model used for automated testing, and fied for conformance to specified behavior.
future trends. Test generators that support black-box test-
ing require that the software specifications

117
Agile Quality Assurance Techniques for GUI-Based Applications

be given as rules and procedures. Examples such as mouse clicks, menu selections, and
of black-box test techniques are equivalence object manipulation actions.
class partitioning, boundary value analysis, • Generate Expected Output: Test oracles
and cause-effect graphing. generate the expected output, which is used
• W hite-box testing (also called glass-box to determine whether or not the software ex-
testing (Beizer, 1990) or testing to code): A ecuted correctly during testing. A test oracle
technique that considers the actual imple- is a mechanism that determines whether or
mentation code for test case generation. For not the output from the software is equiva-
example, a path oriented test case generator lent to the expected output. In GUIs, the
selects a program’s execution path and gen- expected output includes screen snapshots
erates input data for executing the program and positions and titles of windows.
along that path. Other popular techniques • Execute Test Cases and Verify Output:
make use of the program’s branch structure, Test cases are executed on the software and
program statements, code slices, and control its output is compared with the expected
flow graphs (CFG). output. Execution of the GUI’s test case
is done by performing all the input events
No single technique is sufficient for complete specified in the test case and comparing the
testing of a software system. Any practical testing GUI’s output to the expected output as given
solution must use a combination of techniques to by the test oracles.
check different aspects of the program. • Determine if the GUI was Adequately
Tested: Once all the test cases have been
gui testing steps executed on the implemented software, the
software is analyzed to check which of its
Although GUIs have characteristics such as user parts were actually tested. In GUIs, such
events for input and graphical output that are dif- an analysis is needed to identify the events
ferent from those of conventional software and and the resulting GUI states that were tested
thus require the development of different testing and those that were missed. Note that this
techniques, the overall process of testing GUIs is step is important because it may not always
similar to that of testing conventional software. be possible to test in a GUI implementation
The testing steps for conventional software, ex- what is required by the coverage criteria.
tended for GUIs, follow:
After testing, problems are identified in the
• Determine What to Test: During this first software and corrected. Modifications then lead
step of testing, coverage criteria, which are to regression testing (i.e., re-testing of the changed
sets of rules used to determine what to test software).
in a software application, are employed. In
GUIs, a coverage criterion may require that • Perform Regression Testing: Regression
each event be executed to determine whether testing is used to help ensure the correct-
it behaves correctly. ness of the modified parts of the software as
• Generate Test Input: The test input is an well as to establish confidence that changes
important part of the test case and is con- have not adversely affected previously tested
structed from the software’s specifications parts. A regression test suite is developed
and/or from the structure of the software. that consists of (1) a subset of the original
For GUIs, the test input consists of events test cases to retest parts of the original

118
Agile Quality Assurance Techniques for GUI-Based Applications

software that may have been affected by Agile testing


modifications, and (2) new test cases to test
affected parts of the software, not tested by There are several feedback-based mechanisms
the selected test cases. In GUIs, regression to help manage the quality of software applica-
testing involves analyzing the changes to the tions developed using agile techniques. These
layout of GUI objects, selecting test cases mechanisms improve the quality of the software
that should be rerun, as well as generating via continuous, rapid QA during iterative im-
new test cases. provement. They differ in the level of detail of
feedback that they provide to targeted developers,
Any GUI testing method must perform all of their thoroughness, their frequency of execution,
the previous steps. As mentioned earlier, GUI test and their speed of execution. For example, some
designers typically rely on capture/replay tools to mechanisms (e.g., integrated with CVS) provide
test GUIs (Hicinbothom et al., 1993). The process immediate feedback at change-commit time by
involved in using these tools is largely manual running select test cases, which form the commit
making GUI testing slow and expensive. validation suite. Developers can immediately see
A few research efforts have addressed the the consequences of their changes. For example,
automation of test case generation for GUIs. A developers of NetBeans perform several quick
finite state machine (FSM) based modeling ap- (Web-enabled) validation steps when checking
proach is proposed by Clarke (1998). However, into the NetBeans CVS repository (http://www.
FSM models have been found to have scaling netbeans.org/community/guidelines/commit.
problems when applied to GUI test case genera- html). In fact, some Web-based systems such as
tion. Slight variations such as variable finite state Aegis (http://aegis.sourceforge.net/) will not allow
machine (VFSM) models have been proposed by a developer to commit changes unless all com-
Shehady and Siewiorek (1997). These techniques mit-validation tests have passed. This mechanism
help scalability but require that verification checks ensures that changes will not stop the software
be inserted manually at points determined by the from “working” when they are integrated into
test designer. the software baseline. Other, slower mechanisms
Test cases have been generated to mimic novice include “daily building and smoke testing” that
users (Kasik & George, 1996). The approach uses execute more thorough test cases on a regular (e.g.,
an expert to generate the initial path manually and nightly) basis at central server sites. Developers
then use genetic algorithm techniques to generate do not get instant feedback; rather they are e-
longer paths. The assumption is that experts take mailed the results of the nightly builds and smoke
a more direct path when solving a problem using tests. Another, still higher level of continuous QA
GUIs whereas novice users often take longer paths. support is provided by mechanisms such as Skoll
Although useful for generating multiple scripts, (Memon et al., 2004a) that continuously run test
the technique relies on an expert to generate the cases, for days and even weeks on several builds
initial script. The final test suite depends largely (stable and beta) of the evolving software using
on the paths taken by the expert user. The idea is user-contributed resources. All these mechanisms
using a task and generating an initial script may be are useful, in that they detect defects early dur-
better handled by using planning, since multiple ing iterative development. Moreover, since the
scripts may be generated automatically according feedback is directed towards specific developers
to some predetermined coverage criteria. (e.g., those who made the latest modifications),
QA is implicitly and efficiently distributed.

119
Agile Quality Assurance Techniques for GUI-Based Applications

tHE AgILE guI tEstIng • It is expected that new changes will be made
ProcEss to the GUI before the crash testing process
is complete. Hence, the crash testing process
Recent research in automated GUI testing has will be terminated and restarted each time
focused on developing techniques that use GUI a new change is checked-in. The crash test
models for testing. This section consolidates these cases should detect major problems in a
techniques to provide an end-to-end solution that short time interval.
addresses the challenges of agile GUI develop- • The test oracle simply needs to determine
ment. This section presents details of the overall whether the software crashed (i.e., termi-
process shown in Figure 1 and its loops. nated unexpectedly during test case execu-
Users interact with a GUI by performing events tion).
on some widgets such as clicking on a button,
opening a menu, and dragging an icon. During Details of the crash testing process have
GUI testing, test cases consisting of sequences been presented in earlier reported work (Xie et
of events are executed on the GUI. Earlier work al., 2005). An empirical study presented therein
demonstrated that simply executing each event in showed that the crash testing process is efficient
isolation is not enough for effective GUI testing in that it can be performed fully automatically,
(Memon et al., 2001c). Test oracles are used to and useful, in that it helped to detect major GUI
determine whether the test cases failed or passed integration problems. The feedback from crash
(Memon et al., 2000a). The agile concentric loops testing is quickly provided to the specific devel-
differ in the way they generate test cases and oper who checked in the latest GUI changes. The
test oracles. These differences lead to varying developer can debug the code and resubmit the
degrees of effort required by the test designer changes before the problems effect other develop-
during testing. Each of these loops, their goals, ers’ productivity.
and requirements are discussed in subsequent
sections. smoke testing

crash testing Smoke testing is more complex than crash testing


and hence requires additional effort on the part
The goal of crash testing is to create test cases of the test designer. It also executes for a longer
that can quickly test major parts of the GUI fully period of time. Moreover, the smoke testing pro-
automatically without any human intervention. cess is not simply looking for crashes—rather its
More specifically, crash testing generates and goal is to determine whether the software “broke”
executes test cases and oracles that satisfy the during its latest modifications. More specifically,
following requirements. GUI smoke testing has to produce test cases that
satisfy the following requirements:
• The crash test cases should be generated
quickly on the fly and executed. The test • The smoke test cases should be generated
cases are not saved as a suite; rather, a and executed quickly (i.e., in one night).
throwaway set of test cases that require no • The test cases should provide adequate cov-
maintenance is obtained. erage of the GUI’s functionality. As is the
• The test cases should broadly cover the case with smoke test cases of conventional
GUI’s entire functionality. software, the goal is to raise a “something
is wrong here” alarm by checking that GUI

120
Agile Quality Assurance Techniques for GUI-Based Applications

events and event-interactions execute cor- • The test oracle should also be generated from
rectly. the same model. Hence, the model should
• As the GUI is modified, many of the test encode the expected GUI behavior.
cases should remain usable. Earlier work • During test execution, the test cases should
showed that GUI test cases are very sensitive be capable of detecting all deviations from
to GUI changes (Memon, Pollack, & Soffa, the GUI specifications represented in the
2001a). The goal here is to design test cases model.
that are robust, in that a majority of them
remain unaffected by changes to the GUI. Earlier work used a specialized encoding of
• The smoke test suite should be divisible GUI events (in terms of preconditions and effects)
into parts that can be run (in parallel) on to generate test cases (Memon et al., 2001a) and
different machines. test oracles (Memon et al., 2000a). An AI Planner
• The test oracle should compare the current was used to generate the test cases. The test cases
version’s output with that of the previous revealed all deviations from the specifications.
version and report differences.
guI Model
Feasibility studies involving smoke testing
(Memon et al., 2005a; Memon et al., 2005b) As previously noted, all the test cases and oracles
showed that GUI smoke testing is effective at for the agile GUI testing process are generated
detecting a large number of faults. Testers have to automatically using model-based techniques. This
examine the test results and manually eliminate section describes the model and how it is used for
false positives, which may arise due to changes test automation.
made to the GUI. The combination of smoke and The representation of the model (called the
crash testing ensures that “crash bugs” will not be event-flow model) contains two parts. The first
transmitted to the smoke testing loop. Such bugs part encodes each event in terms of preconditions
usually lead to a large number of failed and unex- (i.e., the state in which the event may be executed),
ecuted test cases, causing substantial delays. and effects (i.e., the changes to the state after the
event has executed). The second part represents
comprehensive guI testing all possible sequences of events that can be ex-
ecuted on the GUI as a set of directed graphs. Both
Comprehensive GUI testing is the most expensive, these parts play important roles for various GUI
and hence the least frequent executed testing loop testing tasks. The preconditions/effects are used
during GUI evolution. Since GUI development for goal-directed test-case generation (Memon
is iterative, valuable resources are conserved by et al., 2001a) and test oracle creation (Memon et
employing a model-based approach for this loop. al., 2000a) for comprehensive testing. The second
Hence, this loop must produce test cases that part is used for graph-traversal based test-case
satisfy the following requirements: generation (Memon et al., 2005b) for smoke and
crash testing. The test oracle for smoke and crash
• The test cases should cover the entire func- testing does not need to be derived from the GUI
tionality of the GUI. model. In case of smoke testing, the oracle looks
• The test cases should be generated from a for differences between the previous and modi-
model of the GUI. As the GUI evolves, this fied GUIs. In case of crash testing, the oracle is
model is updated by the developers. hand-coded to look for software crashes.

121
Agile Quality Assurance Techniques for GUI-Based Applications

Modeling Events called Button1. One of its properties is called


Caption and its current value is “Cancel.”
An important part of the event-flow model is the
behavior of each event in terms of how it modifies The set of objects and their properties can be
the state of a GUI when it is executed. Intuitively, used to create a model of the state of the GUI.
the state of the GUI is the collective state of each
of its widgets (e.g., buttons, menus) and containers Definition: The state of a GUI at a particular
(e.g., frames, windows) that contain other widgets time t is the set P of all the properties of all the
(these widgets and containers will be called GUI objects O that the GUI contains.
objects). Each GUI object is represented by a set
of properties of those objects (background color, A complete description of the state would con-
font, caption, etc.). tain information about the types of all the objects
Formally, a GUI is modeled at a particular currently extant in the GUI, as well as all of the
time t in terms of: properties of each of those objects. For example,
consider the Open GUI shown in Figure 3(a). This
• Its objects O = {o1, o2, ..., om}, and GUI contains several objects, three of which are
• The properties P = {p1, p2, ..., pm} of those explicitly labeled; for each, a small subset of its
objects. Each property pi is represented as properties is shown. The state of the GUI, partially
a binary Boolean relation, where the name shown in Figure 3(b), contains all the properties
of the relation is the property name, the of all the objects in Open.
first argument is the object o1∈ O and the Events performed on the GUI change its state.
second argument is the value of the property. Events are modeled as state transducers.
Figure 2(a) shows the structure of properties.
The property value is a constant drawn from Definition: The events E = {e1, e2, ..., en} as-
a set associated with the property in question: sociated with a GUI are functions from one state
for instance, the property “background-color” of the GUI to another state of the GUI.
has an associated set of values, {white, yellow,
pink, etc.}. Figure 2(b) shows a button object Since events may be performed on different
types of objects, in different contexts, yielding
different behavior, they are parameterized with
objects and property values. For example, an
Figure 2(a). The structure of properties, and (b) event set-background-color( w, x ) may be defined in
A Button object with associated properties terms of a window w and color x. The parameters w
and x may take specific values in the context of a
particular GUI execution. As shown in Figure 4,
whenever the event set-background-color( w19, yel-
low ) is executed in a state in which window w19 is
open, the background color of w19 should become
yellow (or stay yellow if it already was), and no
other properties of the GUI should change. This
example illustrates that, typically, events can only
be executed in some states; set-background-color(
w19, yellow ) cannot be executed when window
w19 is not open.

122
Agile Quality Assurance Techniques for GUI-Based Applications

Figure 3(a). The Open GUI with three objects explicitly labeled and their associated properties, and
(b) the State of the Open GUI

Figure 4. An Event Changes the State of the GUI.

123
Agile Quality Assurance Techniques for GUI-Based Applications

It is of course infeasible to give exhaustive • Effects: background-color(wX, Col) where


specifications of the state mapping for each event. current and background-color are properties
In principle, as there is no limit to the number of of window objects.
objects a GUI can contain at any point in time,
there can be infinitely many states of the GUI. Of The previous representation for encoding op-
course in practice, there are memory limits on the erators is the same as what is standardly used in
machine on which the GUI is running, and hence the AI planning literature (Pednault, 1989; Weld,
only finitely many states are actually possible, but 1994; Weld, 1999). This representation has been
the number of possible states will be extremely adopted for GUI testing because of its power to
large. Hence, GUI events are represented using express complex actions.
operators, which specify their preconditions and
effects: generating test cases for the
comprehensive testing Loop
Definition: An operator is a triple <Name,
Preconditions, Effects> where: Test case generation for the comprehensive testing
loop leverages previous work on using AI planning
• Name identifies an event and its param- (Memon et al., 2001a). Because of this previous
eters. work, the operators are described in the PDDL
• Preconditions is a set of positive ground language that is used by AI planners. Planning
literals p(arg1, arg2), where p is a property is a goal-directed search technique used to find
(i.e., p∈P). Pre(Op) represents the set of sequences of actions to accomplish a specific task.
preconditions for operator Op. A literal is For the purpose of test-case generation, given a
a sentence without conjunction, disjunction task (encoded as a pair of initial and goal states)
or implication; a literal is ground when all and a set of actions (encoded as a set of operators),
of its arguments are bound; and a positive the planner returns a sequence of instantiated
literal is one that is not negated. An operator actions that, when executed, will transform the
is applicable in any state Si in which all the initial state to the goal state. This sequence is
literals in Pre(Op) are true. the test case. If no such sequence exists then the
• Effects is also a set of positive or negative operators cannot be used for the task and thus the
ground literals p(arg1, arg2), where p is a planner returns “no plan.”
property (i.e., p∈P). Eff(Op) represents the
set of effects for operator Op. In the resulting creating test oracle for the
state Sj, all of the positive literals in Eff(Op) comprehensive testing Loop
will be true, as will all the literals that were
true in Si except for those that appear as The comprehensive GUI testing loop contains
negative literals in Eff(Op). the most complex test oracle. A test oracle is a
mechanism that determines whether a piece of
For example, the following operator represents software executed correctly for a test case. The
the set-background-color event discussed earlier: test oracle may either be automated or manual;
in both cases, the actual output is compared to a
• Name: set-background-color(wX: window, Col: presumably correct expected output. Earlier work
Color) (Memon et al., 2000a) presented the design for
• Preconditions: current(wX,TRUE), back- a GUI test oracle; it contains three parts (1) an
ground-color(wX, oldCol), oldCol ≠ Col

124
Agile Quality Assurance Techniques for GUI-Based Applications

execution monitor that extracts the actual state the following state: background-color(w19, yellow),
of a GUI using reverse engineering technology current(w19,TRUE) (i.e., the background color of
(Memon et al., 2003c) as a test case is executed on window w19 would change from blue to yellow).
it, (2) an oracle procedure that uses set equality to During test-case execution, this expected state
compare the actual state with oracle information is used to check the correctness of the GUI’s
(i.e., the expected state), (3) the oracle informa- actual state.
tion for a test case <S0, e1; e2; ...; en> is defined Note that a literal that is not explicitly added
as a sequence of states S1; S2; ...; Sn such that Si or deleted in the operator’s effects remains un-
is the expected state of the GUI after event ei is changed (i.e., it persists in the resulting state). This
executed. persistence assumption built into the method for
Operators are used to obtain the oracle informa- computing the result state is called the “STRIPS
tion. Recall that the event-flow model represents assumption.” A complete formal semantics for
events as state transducers. The preconditions- operators making the STRIPS assumption has
effects-style of encoding the operators makes it been developed by Lifschitz (1986). It turns
fairly straightforward to derive the expected state. out that this persistence assumption makes the
Given the GUI in state Si –1, the next state Si (i.e., operators compact and easy to code since there
the expected state after event ei is executed) may is no need to consider unchanged widgets and
be computed using the effects of the operator Op their properties.
representing event ei via simple additions and de- Thus, given a test case for the comprehensive
letions to the list of properties representing state testing loop and the operators of the GUI, the
Si –1. The next state is obtained from the current expected state can be derived by iterative appli-
state Si –1 and Eff (Op) as follows: cation of the two previous steps. This expected
state is used to create a test oracle during test-
1. Delete all literals in Si –1 that unify with a case execution.
negated literal in Eff(Op), and
2. Add all positive literals in Eff(Op). Modeling Event Interactions

Going back to the example of the GUI in The goal is to represent all possible event inter-
Figure 4 in which the following properties are actions in the GUI. Such a representation of the
true before the event is performed: background- event interaction space is used for automated test
color(w19, blue), current(w19,TRUE). Application of case generation for the smoke and crash testing
the previous operator, with variables bound as loops. Intuitively, a graph model of the GUI is
set-background-color( w19, yellow ), would lead to constructed. Each vertex represents an event

Figure 5. The event Set Language opens a modal window

125
Agile Quality Assurance Techniques for GUI-Based Applications

Figure 6. The event Replace opens a modeless window

(e.g., click-on-Edit, click-on-Paste). In subsequent Definition: A modal window is a GUI win-


discussion for brevity, the names of events are dow that, once invoked, monopolizes the GUI
abbreviated (e.g., Edit and Paste). An edge from interaction, restricting the focus of the user to a
vertex x to vertex y shows that an event y can be specific range of events within the window, until
performed immediately after event x. This graph the window is explicitly terminated.
is analogous to a control-flow graph in which
vertices represent program statements (in some The language selection window is an example
cases basic blocks) and edges represent possible of a modal window in MS Word. As Figure 5
execution ordering between the statements. A state shows, when the user performs the event Set
machine model that is equivalent to this graph Language, a window entitled Language opens and
can be constructed—the state would capture the the user spends time selecting the language, and
possible events that can be executed on the GUI finally explicitly terminates the interaction by
at any instant; transitions cause state changes either performing OK or Cancel.
whenever the number and type of available events Other windows in the GUI that do not restrict
changes. For a pathological GUI that has no the user’s focus are called modeless windows; they
restrictions on event ordering and no windows/ merely expand the set of GUI events available to
menus, such a graph would be fully connected. the user. For example, in the MS Word software,
In practice, however, GUIs are hierarchical, and performing the event Replace opens a modeless
this hierarchy may be exploited to identify groups window entitled Replace (Figure 6).
of GUI events that may be modeled in isolation. At all times during interaction with the GUI,
One hierarchy of the GUI and the one used in this the user interacts with events within a modal
research is obtained by examining the structure dialog. This modal dialog consists of a modal
of modal windows (Standard GUI terminology; window X and a set of modeless windows that
see details at msdn.microsoft.com/library/en- have been invoked, either directly or indirectly
us/vbcon/html/vbtskdisplayingmodelessform. from X. The modal dialog remains in place until
asp and documents.wolfram.com/v4/AddOns/ X is explicitly terminated.
JLink/1.2.7.3.html.) in the GUI.
Definition: A modal dialog (MD) is an or-
dered pair (RF, UF) where RF represents a modal

126
Agile Quality Assurance Techniques for GUI-Based Applications

window in terms of its events and UF is a set readability of the event-flow graph, some edges
whose elements represent modeless windows have been omitted. Instead, labeled circles have
also in terms of their events. Each element of UF been used as connectors to sets of events. The
is invoked (i.e., window is opened) either by an legend shows the set of events represented by
event in RF or UF. each circle. For example, an edge from Save to
Note that, by definition, a GUI user cannot  is a compact represent of a collection of edges
interleave events of one modal dialog with events from the event Save to each element in the set
of other modal dialogs; the user must either represented by . At the top of the figure are the
explicitly terminate the currently active modal vertices, File, Edit, View, Insert, Format, and Help,
dialog or invoke another modal dialog to execute that represent the pull-down menu of MS Word-
events in different dialogs. This property of modal Pad. They are events that are available when the
dialogs enables the decomposition of a GUI into Main modal dialog is first invoked; they form the
parts—each part can be tested separately. As will set B. Once File has been performed in WordPad
be seen later, interactions between these parts are any of the events in  may be performed; there
modeled separately (as an integration tree) so that are edges in the event-flow graph from File to
the GUI can be tested for these interactions. each of these events. Note that Open is shown as a
Event interactions within a modal dialog may dashed oval. This notation is used for events that
be represented as an event-flow graph. Intuitively, open other modal dialogs; About and Contents are
an event-flow graph of a modal dialog represents also similar events. Hence, for this modal dialog
all possible event sequences that can be executed I = {all events shown with dashed ovals}. Other
in the dialog. Formally, an event-flow graph is events such as Save, Cut, Copy, and Paste are all
defined as follows. events that don’t open windows; they interact with
the underlying software.
Definition: An event-flow graph for a modal Once all the modal dialogs of the GUI have
dialog MD is a 4-tuple <V, E, B, I> where: been represented as event-flow graphs, the remain-
ing step is to identify interactions between modal
1. V is a set of vertices representing all the dialogs. A structure called an integration tree is
events in MD. Each v ∈ V represents an constructed to identify interactions (invocations)
event in MD. between modal dialogs.
2. E ⊆ V × V is a set of directed edges between
vertices. Event ej follows ei iff ej may be per- Definition: Modal dialog MDx invokes
formed immediately after ei. An edge (vx, modal dialog MDy if MDx contains an event ex
vy) ∈ E iff the event represented by vy follows that invokes MDy.
the event represented by vx.
3. B ⊆ V is a set of vertices representing those Intuitively, the integration tree shows the
events of MD that are available to the user invokes relationship among all the modal dialogs
when the modal dialog is first invoked. in a GUI. Formally, an integration tree is defined
4. B ⊆ V is the set of events that open other as:
modal dialogs.
Definition: An integration tree is a triple < N,
An example of an event-flow graph for the Main R, B >, where N is the set of modal dialogs in the
modal dialog (i.e., the modal dialog that is avail- GUI and R is a designated modal dialog called the
able to the user when the application is launched) Main modal dialog. B is the set of directed edges
of MS WordPad is shown in Figure 7. To increase showing the invokes relation between modal dia-

127
Agile Quality Assurance Techniques for GUI-Based Applications

Figure 7. Event-flow graph for the Main modal dialog of MS WordPad

logs (i.e., (MDx, MDy)∈B iff MDx invokes MDy, Developing the event-flow model manually
where MDx and MDy are both modal dialogs). can be tedious and error-prone. Therefore, a tool
Figure 8 shows an example of an integration called the “GUI Ripper” has been developed to
tree representing a part of the MS WordPad’s GUI. automatically obtain event-flow graphs and the
The vertices represent the modal dialogs of the MS integration tree. A detailed discussion of the tool
WordPad GUI and the edges represent the invokes is beyond the scope of this chapter; the interested
relationship between the modal dialogs. The tree reader is referred to previously published work
in Figure 8 has an edge from Main to FileOpen (Memon et al., 2003c) for details. In short, the GUI
showing that Main contains an event, namely Open Ripper combines reverse engineering techniques
(see Figure 7) that invokes FileOpen. with the algorithms presented in previous sections
This decomposition of the GUI makes the over- to automatically construct the event-flow graphs
all testing process intuitive for the test designer and integration tree. During “GUI Ripping,” the
since the test designer can focus on a specific part GUI application is executed automatically; the
of the GUI. Moreover, it simplifies the design application’s windows are opened in a depth-first
of the algorithms and makes the overall testing manner. The GUI Ripper extracts all the widgets
process more efficient. and their properties from the GUI. During the

128
Agile Quality Assurance Techniques for GUI-Based Applications

Figure 8. An integration tree for a part of MS WordPad

reverse engineering process, in addition to widget manually examined and corrected in the event-
properties, additional key attributes of each widget flow graphs and integration trees. The number of
are recovered (e.g., whether it is enabled, it opens operators is the same as the number of events in
a modal/modeless window, it opens a menu, it the GUI, since there is exactly one operator per
closes a window, it is a button, it is an editable executable event.
text-field). These attributes are used to construct
the event-flow graphs and integration tree. obtaining test cases for smoke and
As can be imagined, the GUI Ripper is not crash testing Loops
perfect (i.e., parts of the retrieved information
may be incomplete/incorrect). Common examples Test case generation for the smoke and crash test-
include (1) missing windows in certain cases (e.g., ing loops employ graph traversal of the event-flow
if the button that opens that window is disabled graph. More specifically, a GUI test case is of the
during GUI Ripping), (2) failure to recognize form <S0, e1; e2; ...; en>, where S0 is a state of the
that a button closes a window, and (3) incor- GUI in which the event sequence e1; e2; ...; en is
rectly identifying a modal window as a modeless executed. The simplest way to generate test cases
window or vise versa. The specific problems that is for a tester to start from one of the vertices in
are encountered depend on the platform used the set B of the main modal dialog’s event-flow
to implement the GUI. For example, for GUIs graph. Note that these events are available to a
implemented using Java Swing, the ripper is un- GUI user as soon as the GUI is invoked. The event
able to retrieve the contents of the “Print” dialog; corresponding to the chosen vertex becomes the
in MS Windows, is unable to correctly identify first event in the test case. The tester can then
modal/modeless windows. Recognizing that such use one of the outgoing edges from this vertex to
problems may occur during reverse engineering, perform an adjacent event. The tester can continue
tools have been developed to manually “edit” the this process generating many test cases. Note that
event-flow graphs and integration tree and fix a tester who uses a capture/replay tool to gener-
these problems. ate test cases is actually executing this process
A test designer also does not have to code manually without using our formal models.
each operator from scratch since the reverse en- As noted earlier, if performed manually (us-
gineering technique creates operator templates ing capture/replay tools), the previous process is
and fills-in those preconditions and effects that extremely labor intensive. With the event-flow
describe the structure of the GUI. Such precondi- model, numerous graph-traversal techniques may
tions and effects are automatically derived during be used to automate it. The order in which the
the reverse engineering process in a matter of events are covered will yield different types of
seconds. Note that there are no errors in these test cases. For smoke and crash testing, the tester
templates since the structure has already been must generate test cases that (1) cover all the events

129
Agile Quality Assurance Techniques for GUI-Based Applications

in the GUI at least once, and (2) cover all pairs of to software that can be modeled using state-
event-interactions at least once. In terms of event- machine models. Indeed a state machine model
flow graphs, all the edges should be covered by that is equivalent to an event-flow graph can be
the test cases, thereby ensuring that all events and constructed—the state would capture the possible
event interactions are covered. Similar types of events that can be executed on the GUI at any in-
such techniques have been used in previous work stant; transitions cause state changes whenever the
(Memon et al., 2004b). As mentioned earlier, the number and type of available events changes. Since
GUI model is not needed for test oracle creation such applications are also being developed using
for the smoke and crash testing loops. agile techniques, software testing research must
All the previous techniques have been put develop new agile mechanisms to test them.
together to realize the agile GUI testing process
shown in Figure 1.
concLusIon

FuturE trEnds This chapter outlined the need for an agile model-
based testing mechanism to keep up with agile
Although this chapter has presented the agile evolution of software. The example of GUI-based
testing concept in terms of GUIs, there is a clear applications was used throughout the chapter.
need to extend this work to other event-driven Three existing GUI testing techniques were com-
applications, which are becoming increasingly bined to develop a new process for model-based
popular; testing these applications faces many agile GUI testing. The new process was novel in
of the challenges mentioned earlier for GUIs. that it consisted of three iterative sub-processes,
Numerous researchers have already started to each with specific testing goals, resource demands,
model various classes of software using their and tester involvement. The model used to realize
event-driven nature. For example, Welsh, Culler, this process was discussed.
and Brewer (2001) have modeled Web applications Each of the three presented techniques has been
as a network of event-driven stages connected by evaluated in previously reported work and found
queues; Duarte, Martins, Domingos, and Preguia to be practical. The crash testing approach has
(2003) have described an extensible network based been applied on several open-source applications
event dissemination framework; Gu and Nahrstedt and used to report previously unknown faults in
(2001) have presented an event-driven middleware fielded systems; the entire process required a mat-
framework; Cheong, Liebman, Liu, and Zhao ter of hours with no human intervention (Xie et
(2003) have presented a model for event-driven al., 2005). The smoke testing technique has also
embedded systems; Sliwa (2003) has described been applied to perform testing of nightly builds
how event-driven architectures may be used to of several in-house GUI systems (Memon et al.,
develop complex component-based systems; 2005b). The comprehensive testing technique has
Holzmann and Smith (1999) have modeled device also been evaluated both for the first time (Memon
drivers as event-driven systems; and Carloganu et al., 2001a) and regression testing (Memon et
and Raguideau (2002) have described an event- al., 2003e).
driven simulation system. Researchers need to GUIs belong to the wider class of event-driven
extend the ideas presented in this chapter to the software. The increasing popularity of event-
general class of event-driven software. driven software applications, together with the
Similarly, although this work has been pre- increased adoption of agile development meth-
sented using event-flow graphs, it is applicable odologies fuels the need for the development of

130
Agile Quality Assurance Techniques for GUI-Based Applications

other, similar quality assurance techniques for Duarte, S., Martins, J. L., Domingos, H. J., &
this wider class. The software testing research Preguia, N. (2003). A case study on event dissemi-
community needs to understand emerging de- nation in an active overlay network environment.
velopment trends, and to develop new techniques Proceedings of the 2nd International Workshop on
that leverage the resources available during agile Distributed Event-Based Systems (pp. 1-8). New
development. The concepts presented in this York: ACM Press.
chapter take the first step towards providing such
Finsterwalder, M. (2001). Automating acceptance
agile testing techniques.
tests for GUI applications in an extreme program-
ming environment. Proceedings of the 2nd Inter-
national Conference on eXtreme Programming
AcknoWLEdgMEnts
and Flexible Processes in Software Engineering
(pp. 114-117). New York: Springer.
The authors thank the anonymous reviewers
whose comments played an important role in Gray, J. (2003). What next? A dozen informa-
reshaping this chapter. The authors also thank tion-technology research goals. Journal of ACM,
Bin Gan, Adithya Nagarajan, and Ishan Banerjee 50(1), 41-57.
who helped to lay the foundation for this research.
Gu, X., & Nahrstedt, K. (2001). An event-driven,
This work was partially supported by the US
user-centric, qos-aware middleware framework
National Science Foundation under NSF grant
for ubiquitous multimedia applications. Pro-
CCF-0447864 and the Office of Naval Research
ceedings of the 2001 International Workshop on
grant N00014-05-1-0421.
Multimedia Middleware (pp. 64-67). New York:
ACM Press.
rEFErEncEs Hicinbothom, J. H., & Zachary, W. W. (1993).
A tool for automatically generating transcripts
Beizer, B. (1990). Software testing techniques of human-computer interaction. Proceedings of
(2nd ed.). New York: International Thomson the Human Factors and Ergonomics Society 37th
Computer Press. Annual Meeting, Vol. 2 of SPECIAL SESSIONS:
Demonstrations (pp. 1042). Santa Monica, CA:
Carloganu, A., & Raguideau, J. (2002). Claire: An
Human Factors Society.
event-driven simulation tool for test and validation
of software programs. Proceedings of the 2002 Holzmann, G. J., & Smith, M. H. (1999). A practi-
International Conference on Dependable Systems cal method for verifying event-driven software.
and Networks (p. 538). Los Alamitos, CA: IEEE Proceedings of the 21st International Conference
Computer Society. on Software Engineering (pp. 597-607). Los
Alamitos, CA: IEEE Computer Society.
Cheong, E., Liebman, J., Liu, J., & Zhao, F. (2003).
Tinygals: A programming model for event-driven Kaddah, M. M. (1993). Interactive scenarios for
embedded systems. Proceedings of the 2003 ACM the development of a user interface prototype.
symposium on Applied Computing (pp. 698-704). Proceedings of the 5th International Conference
New York: ACM Press. on Human-Computer Interaction, Vol. 2 of I.
Software Interfaces (pp. 128-133). New York:
Clarke, J. M. (1998). Automated test generation
ACM Press.
from a behavioral model. Proceedings of the
11th International Software Quality Week. San
Francisco: Software Research, Inc.

131
Agile Quality Assurance Techniques for GUI-Based Applications

Kasik, D. J., & George, H. G. (1996). Toward smoke regression test cases for GUI-based soft-
automatic generation of novice user test scripts. ware. Proceedings of the International Confer-
Proceedings of the Conference on Human Fac- ence on Software Maintenance 2004 (ICSM’04)
tors in Computing Systems: Common Ground (pp. 8-17). Los Alamitos, CA: IEEE Computer
(pp. 244-251). New York: ACM Press. Society.
Kaster, A. (1991). User interface design and evalu- Memon, A. M., & Xie, Q. (2004c). Using tran-
ation: Application of the rapid prototyping tool sient/persistent errors to develop automated test
EMSIG. Proceedings of the 4th International Con- oracles for event-driven software. Proceedings of
ference on Human-Computer Interaction, Vol. 1 the International Conference on Automated Soft-
of Congress II: Design and Implementation of ware Engineering 2004 (ASE’04) (pp. 186-195).
Interactive Systems: USABILITY EVALUATION; Los Alamitos, CA: IEEE Computer Society.
Techniques for Usability Evaluation (pp. 635-
Memon, A. M., & Xie, Q. (2005b). Studying the
639). New York: ACM Press.
fault-detection effectiveness of GUI test cases for
Lifschitz, V. (1986). On the semantics of STRIPS. rapidly evolving software. IEEE Transactions on
In M. P. Georgeff & A. L. Lansky (Eds.), Reason- Software Engineering, 31(10), 884-896.
ing about actions and plans: Proceedings of the
Memon, A. M., Banerjee, I., Hashish, N., &
1986 Workshop (pp. 1-9). San Francisco: Morgan
Nagarajan, A. (2003b). DART: A framework for
Kaufmann.
regression testing nightly/daily builds of GUI ap-
Mahajan, R., & Shneiderman, B. (1996). Visual & plications. Proceedings of the International Con-
textual consistency checking tools for graphical ference on Software Maintenance (pp. 410-419).
user interfaces. Technical Report CS-TR-3639, Los Alamitos, CA: IEEE Computer Society.
University of Maryland, College Park, May.
Memon, A. M., Banerjee, I., & Nagarajan, A.
Memon, A. M. (2001b). A comprehensive frame- (2003c). GUI ripping: Reverse engineering of
work for testing graphical user interfaces (Doc- graphical user interfaces for testing. Proceed-
toral dissertation, University of Pittsburgh, 2001). ings of the 10th Working Conference on Reverse
Dissertation Abstracts International, 62, 4084. Engineering (pp. 260-269). Los Alamitos, CA:
IEEE Computer Society.
Memon, A. M. (2002). GUI testing: Pitfalls and
process. IEEE Computer, 35(8), 90-91. Memon, A. M., Banerjee, I., & Nagarajan, A.
(2003d). What test oracle should I use for ef-
Memon, A. M. (2003a). Advances in GUI testing.
fective GUI testing? Proceedings of the IEEE
In M. V. Zelkowitz (Ed.), Advances in Computers
International Conference on Automated Software
(Vol. 57). Burlington, MA: Academic Press.
Engineering (pp. 164-173). Los Alamitos, CA:
Memon, A. M., & Soffa, M. L. (2003e). Regression IEEE Computer Society.
testing of GUIs. Proceedings of the 9th European
Memon, A., Nagarajan, A., & Xie, Q. (2005a).
Software Engineering Conference (ESEC) and 11th
Automating regression testing for evolving GUI
ACM SIGSOFT International Symposium on the
software. Journal of Software Maintenance and
Foundations of Software Engineering (pp. 118-
Evolution: Research and Practice, 17(1), 27-64.
127). New York: ACM Press.
Memon, A. M., Pollack, M. E., & Soffa, M. L.
Memon, A. M., & Xie, Q. (2004b). Empirical
(1999). Using a goal-driven approach to generate
evaluation of the fault-detection effectiveness of

132
Agile Quality Assurance Techniques for GUI-Based Applications

test cases for GUIs. Proceedings of the 21st Inter- Myers, B. A. (1995a). State of the art in user
national Conference on Software Engineering interface software tools. Human-computer in-
(pp. 257-266). New York: ACM Press. teraction: Toward the year 2000. San Francisco:
Morgan Kaufmann Publishing.
Memon, A. M., Pollack, M. E., & Soffa, M. L.
(2000a). Automated test oracles for GUIs. Pro- Myers, B. A. (1995b). User interface software
ceedings of the ACM SIGSOFT 8th International tools. ACM Transactions on Computer-Human
Symposium on the Foundations of Software En- Interaction, 2(1), 64-103.
gineering (pp. 30-39). New York: ACM Press.
Myers, B. A., & Olsen, JR., D. R. (1994). User
Memon, A. M., Pollack, M. E., & Soffa, M. L. interface tools. Proceedings of ACM CHI’94
(2000b). Plan generation for GUI testing. Pro- Conference on Human Factors in Computing
ceedings of the 5th International Conference on Systems, TUTORIALS (Vol. 2, pp. 421-422). New
Artificial Intelligence Planning and Scheduling York: ACM Press.
(pp. 226-235). Menlo Park, CA: AAAI Press.
Myers, B. A., Hollan, J. D., & Cruz, I. F. (1996).
Memon, A. M., Pollack, M. E., & Soffa, M. L. Strategic directions in human-computer interac-
(2001a). Hierarchical GUI test case generation tion. ACM Computing Surveys, 28(4), 794-809.
using automated planning. IEEE Transactions on
Myers, B. A., Olsen, JR., D. R., & Bonar, J. G.
Software Engineering, 27(2), 144-155.
(1993b). User interface tools. Proceedings of ACM
Memon, A. M., Porter, A., Yilmaz, C., Nagara- INTERCHI’93 Conference on Human Factors in
jan, A., Schmidt, D. C., & Natarajan, B. (2004a). Computing Systems: Adjunct Proceedings, Tutori-
Skoll: distributed continuous quality assurance. als (p. 239). New York: ACM Press.
Proceedings of the 26th IEEE/ACM International
Nielsen, J. (1993). Iterative user-interface design.
Conference on Software Engineering (pp. 459-
IEEE Computer, 26(11), 32-41.
468). New York: ACM Press.
Pednault, E. P. D. (1989). ADL: Exploring the
Memon, A. M., Soffa, M. L., & Pollack, M. E.
middle ground between STRIPS and the situation
(2001c). Coverage criteria for GUI testing. Pro-
calculus. Proceedings of KR’89 (pp. 324-331). San
ceedings of the 8th European Software Engineer-
Francisco: Morgan Kaufmann Publisher.
ing Conference (ESEC) and 9th ACM SIGSOFT
International Symposium on the Foundations of Perry, W. (1995). Effective methods for software
Software Engineering (FSE-9) (pp. 256-267). testing. New York: John Wiley & Sons.
New York: ACM Press.
Rothermel, G., & Harrold, M. J. (1997). A safe,
Mulligan, R. M., Altom, M. W., & Simkin, D. K. efficient regression test selection technique. ACM
(1991). User interface design in the trenches: Some Transactions on Software Engineering and Meth-
tips on shooting from the hip. Proceedings of odology, 6(2), 173-210.
ACM CHI’91 Conference on Human Factors in
Shehady, R. K., & Siewiorek, D. P. (1997). A
Computing Systems, Practical Design Methods
method to automate user interface testing using
(pp. 232-236). New York: ACM Press.
variable finite state machines. Proceedings of the
Myers, B. A. (1993a). Why are human-computer 27th Annual International Conference on Fault-
interfaces difficult to design and implement? Tolerant Computing (pp. 80-88). Los Alamitos,
Technical Report CS-93-183, Carnegie Mellon CA: IEEE Computer Society.
University, School of Computer Science.

133
Agile Quality Assurance Techniques for GUI-Based Applications

Sliwa, C. (2003). Event-driven architecture White, L., Almezen, H., & Alzeidi, N. (2001).
poised for wide adoption. COMPUTERWORLD. User-based testing of GUI sequences and their
Retrieved May 12, 2005, from http://www.com- interactions. Proceedings of the 12th International
puterworld.com/softwaretopics/software/appdev/ Symposium Software Reliability Engineering
story/0,10801,81133,00.html (pp. 54-63). Los Alamitos, CA: IEEE Computer
Society.
Weld, D. S. (1994). An introduction to least com-
mitment planning. AI Magazine, 15(4), 27-61. Wick, D. T., Shehad, N. M., & Hajare, A. R.
(1993). Testing the human computer interface
Weld, D. S. (1999). Recent advances in AI plan-
for the telerobotic assembly of the space station.
ning. AI Magazine, 20(1), 55-64.
Proceedings of the 5th International Conference
Welsh, M., Culler, D., & Brewer, E. (2001). Seda: on Human-Computer Interaction, Special Ap-
An architecture for well-conditioned, scalable plications (Vol. 1, pp. 213-218). New York: ACM
internet services. Proceedings of the 18th ACM Press.
Symposium on Operating Systems Principles
Xie, Q., & Memon, A. M. (2005). Rapid crash
(pp. 230-243). New York: ACM Press.
testing for continuously evolving GUI-based
White, L. (1996). Regression testing of GUI event software applications. Proceedings of the Inter-
interactions. Proceedings of the International national Conference on Software Maintenance
Conference on Software Maintenance (ICSM’96) 2005 (pp. 473-482). Los Alamitos, CA: IEEE
(pp. 350-358). Los Alamitos, CA: IEEE Computer Computer Society.
Society.

134
Agile Quality Assurance Techniques for GUI-Based Applications

Section III
Quality within
Agile Process Management

135
136

Chapter VII
Software Configuration
Management in Agile
Development
Lars Bendix
Lund Institute of Technology, Sweden

Torbjörn Ekman
Lund Institute of Technology, Sweden

AbstrAct

Software configuration management (SCM) is an essential part of any software project and its impor-
tance is even greater on agile projects because of the frequency of changes. In this chapter, we argue
that SCM needs to be done differently and cover more aspects on agile projects. We also explain how
SCM processes and tools contribute both directly and indirectly to quality assurance. We give a brief
introduction to central SCM principles and define a number of typical agile activities related to SCM.
Subsequently, we show that there are general SCM guidelines for how to support and strengthen these
typical agile activities. Furthermore, we establish a set of requirements that an agile method must satisfy
to benefit the most from SCM. Following our general guidelines, an agile project can adapt the SCM
processes and tools to its specific agile method and its particular context.

IntroductIon can directly and in-directly contribute to better


QA on agile projects.
In traditional software development organisations, Software configuration management (SCM)
software configuration management (SCM) is is a set of processes for managing changes and
often pushed onto the projects by the quality as- modifications to software systems during their
surance (QA) organisation. This is done because entire life cycle. Agile methods embrace change
SCM in part can implement some QA measures and focus on how to respond rapidly to changes
and in part can support the developers in their work in the requirements and the environment (Beck,
and therefore helps them to produce better quality. 1999a). So it seems obvious that SCM should be
The same holds true for agile methods—SCM an even more important part of agile methods

Copyright © 2007, Idea Group Inc., distributing in print or electronic forms without written permission of IGI is prohibited.
Software Configuration Management in Agile Development

Figure 1. The different layers of SCM

than it is of traditional development methods. and the customer. While traditional SCM focuses
However, SCM is often associated with heavily on the projects and company layers in Figure 1,
process-oriented software development and the there is a need to support developers as well when
way it is commonly carried out might not transfer using SCM in agile projects. Shorter iterations,
directly to an agile setting. We believe there is a more frequent releases, and closer collaboration
need for SCM in agile development but that ist within a development team contribute to a much
should be carried out in a different way. There greater stress on SCM processes and tools.
is a need for the general values and principles of Agile methods are people-oriented rather than
SCM, which we consider universal for all develop- process-oriented and put the developer and the
ment methods, and there is a need for the general customer in focus. As a consequence, SCM has
techniques and processes, which we are certain to shift its primary focus from control activities
will be of even greater help to agile developers to that of service and support activities. The main
than they are to traditional developers. focus on audits and control needs to be replaced
There are some major differences in agile proj- by a main focus on supporting the highly iterative
ects compared to traditional projects that heavily way of working of both the team and the devel-
influence the way SCM can—and should—be opers, as seen in Figure 2. From a QA point of
carried out. Agile methods shift the focus from view, the control measures are moved down to
the relation between a project’s management and the developers themselves with the purpose of
the customer to the relation between developers shortening the feedback loop in agile methods. So

Figure 2. The main development loops in agile

137
Software Configuration Management in Agile Development

SCM does not directly contribute to the QA on an supported by SCM and how agile methods could
agile project, this is the task of the processes that benefit from adopting more SCM principles. We
the agile method in question prescribes. However, also provide pointers to literature where more
by supporting said processes and making them details can be found. Future trends for SCM in
easier and safer to practice SCM indirectly is a the agile context are described in Section 4, and
big factor in QA on agile projects. in Section 5 we draw our conclusions.
The traditional process-oriented view of SCM
has also lead to several misconceptions of agile
methods from an SCM point of view. The lack bAcKGround
of explicit use of SCM and its terminology has
lead quite a few people to conclude that agile This section gives an introduction to the concepts
methods are not safe due to an apparent lack of and terminology in SCM that serve as a back-
rigorous change management. However, a lot of ground for the analysis in following sections.
SCM activities are actually carried out in agile We also define and describe activities in agile
methods although they are not mentioned explic- methods that are related to SCM or affected by
itly. Bendix and Hedin (2002) identify a need SCM in one way or the other.
for better support from SCM, in particular for
refactoring in order for this practice to be viable. scM Activities
Koskela (2003) reviews agile methods in general
from an SCM point of view and concludes that SCM is a method for controlling the develop-
only a few of the existing agile methods take ment and modifications of software systems and
SCM explicitly into account. He also notices that products during their entire life cycle (Crnkovic,
most methods highly value SCM tool support but Asklund, & Persson Dahlqvist, 2003). From this
that SCM planning has been completely forgot- viewpoint, SCM is traditionally divided into the
ten. There is thus a need to provide guidance for following activities: configuration identifica-
using SCM or for implementing SCM in agile. tion, configuration control, configuration status
The SCM literature mostly takes the control- accounting, and configuration audit (Leon,
oriented view of SCM (Berlack, 1992; Buckley, 2005). These activities reflect mostly the part of
1993; Hass, 2003; Leon, 2005) and there is very a development project with relations to the cus-
little written about team- and developer-oriented tomer. However, since agile methods are often
support activities (Babich, 1986; Mikkelsen & more developer centric, there is also a need for a
Pherigo, 1997; Bendix & Vinter, 2001; Berczuk more developer-oriented view of SCM than the
& Appleton, 2003). These activities are the ones traditional control-oriented view above. Typi-
that can benefit agile methods the most and should cal developer-oriented aspects of SCM include:
therefore be emphasized more when used in an version control, build management, workspace
agile setting. However, it is important to stress management, concurrency control, change man-
that agile methods need the whole range of SCM agement, and release management (Bendix &
support from developer through to customer. Vinter, 2001). We present each activity from a
In the next section, we provide background general perspective and explain both its purpose
information about SCM for those who are not and what is included in the activity. After this
so familiar with SCM, and describe and define a introduction, the reader should be familiar with
number of SCM-related agile activities to estab- these basic SCM concepts and their purpose,
lish a terminology. In Section 3, we give general so we can use them for our analysis in the next
guidelines for how these agile activities can be section.

138
Software Configuration Management in Agile Development

Configuration Identification Configuration Status Accounting

Configuration identification is the activity where Developers are able to track the current status of
a system is divided into uniquely identifiable changes by formalizing the recording and report-
components, called configuration items, for the ing of established configuration items, status of
purpose of software configuration management. proposed changes, and implementation of ap-
The physical and functional characteristics of each proved changes. Configuration status accounting
configuration item are documented including its is the task to provide all kinds of information
interfaces and change history. Each configuration related to configuration items and the activities
item is given a unique identifier and version to that affect them. This also includes change logs,
distinguish it from other items and other versions progress reports, and transaction logs. Configu-
of the same item. This allows us to reason about ration status accounting enables tracking of the
a system in a consistent way both regarding its complete history of a software product at any time
structure and history. Each item can be either a during its life cycle and also allows changes to be
single unit or a collection (configuration) of lower tracked compared to a particular baseline.
level items allowing hierarchical composition.
During configuration identification a project Configuration Audits
baseline and its contents are also defined, which
helps to control change as all changes apply to The process of determining whether a configura-
this uniquely defined baseline. tion item, for instance a release, conforms to its
configuration documents is called configuration
Configuration Control audit. There are several kinds of audits each
with its own purpose but with the common goal
Software is very different from hardware as it can to ensure that development plans and processes
be changed quickly and easily, but doing so in an are followed. A functional configuration audit
uncontrolled manner often leads to chaos. Con- is a formal evaluation that a configuration item
figuration control is about enabling this flexibility has achieved the performance characteristics and
in a controlled way through formal change control functions defined in its configuration document.
procedures including the following steps: evalu- This process often involves testing of various
ation, coordination, approval or disapproval, and kinds. A physical configuration audit determines
implementation of changes. A proposed change the conformity between the actual produced con-
request typically originates from requests for figuration item and the configuration according to
new features, enhancement of existing features, the configuration documents. A typical example
bug reports, etc. A request is first evaluated by is to ensure that all items identified during con-
a Change Control Board (CCB) that approves figuration identification are included in a product
or disapproves the request. An impact analysis baseline prior to shipping. An in-process audit
is performed by the CCB to determine how the ensures that the defined SCM activities are being
change would affect the system if implemented. properly applied and controlled and is typically
If a request is approved, the proposed change carried out by a QA team.
is assigned to a developer for implementation.
This implementation then needs to be verified Version Control
through testing to ensure that the change has been
implemented as agreed upon before the CCB can A version control system is an invaluable tool
finally close the change request. in providing history tracking for configuration

139
Software Configuration Management in Agile Development

items. Items are stored, versions are created, and immutable, developers cannot be allowed to work
their historical development is registered and directly within this repository. Instead, they have
conveniently accessible. A fundamental invariant to take out a copy, modify it, and add the modified
is that versions are immutable. This means that copy to the repository. This also allows developers
as soon as a configuration item is given a version to work in a controlled environment where they are
number, we are assured that it is unique and its protected from other people’s changes and where
contents cannot be changed unless we create a they can test their own changes prior to releasing
new version. We can therefore recreate any ver- them to the repository. Workspace management
sion at any point in time. Version control systems must provide functionality to create a workspace
typically support configuration status accounting from a selected set of files in the repository. At
by providing automatic support for history track- the termination of that workspace, all changes
ing of configuration items. Furthermore, changes performed in the workspace need to be added to
between individual versions of a configuration the repository. While working in the workspace,
item can be compared automatically and vari- a developer needs to update his workspace, in a
ous logs are typically attached to versions of a controlled fashion, with changes that other people
configuration item. may have added to the repository.

Build Management Concurrency Control

Build management handles the problem of put- When multiple developers work on the same
ting together modules in order to build a running system at the same time, they need a way to
system. The description of dependencies and synchronize their work; otherwise it may happen
information about how to compile items are given that more than one developer make changes to the
in a system model, which is used to derive object same set of files or modules. If this situation is not
code and to link it together. Multiple variants detected or avoided, the last developer to add his
of the same system can be described in a single or her changes to the repository will effectively
system model and the build management tool erase the changes made by others. The standard
will derive different configurations, effectively way to avoid this situation is to provide a locking
building a tailored system for each platform or mechanism, such that only the developer who
product variant. The build process is most often has the lock can change the file. A more flexible
automated, ranging from simple build scripts solution is to allow people to work in parallel and
to compilation in heterogeneous environments then to provide a merge facility that can combine
with support for parallel compilation. Incremen- changes made to the same file. Compatible changes
tal builds, that only compile and link what has can be merged automatically while incompatible
changed, can be used during development for fast changes will result in a merge conflict that has
turn around times, while a full build, rebuilding to be resolved manually. It is worth noticing that
the entire system from scratch, is normally used conflicts are resolved in the workspace of the
during system integration and release. developer that triggered the conflict, who is the
proper person to resolve it.
Workspace Management
Change Management
The different versions of configuration items in a
project are usually kept in a repository by the ver- There are multiple and complex reasons for
sion control tool. Because these versions must be changes and change management needs to cover all

140
Software Configuration Management in Agile Development

types of changes to a system. Change management method, we consider them representative for the
includes tools and processes that support the orga- agile way of developing software.
nization and tracking of changes from the origin
of the change to the approval of the implemented Parallel Work
source code. Various tools are used to collect data
during the process of handling a change request. It Most projects contain some kind of parallel work,
is important to keep traceability between a change either by partitioning a project into sub-projects
request and its actual implementation, but also to that are developed in parallel, or by implementing
allow each piece of code to be associated to an multiple features in parallel.
explicit change request. Change management is Traditional projects often try to split projects
also used to provide valuable metrics about the into disjoint sub-projects that are later combined
progress of project execution. into a whole. The incremental and adaptive nature
of agile methods requires integration to be done
Release Management continuously since new features are added as their
need is discovered. Agile methods will therefore
Release management deals with both the formal inevitably lead to cooperative work on the same,
aspects of the company releasing to the customer shared code base, which needs to be coordinated.
and the more informal aspects of the developers To become effective, the developers need support
releasing to the project. For a customer release, we to work on new features in isolation and then merge
need to carry out both a physical and a functional their features into the shared code base.
configuration audit before the actual release. In
order to be able to later re-create a release, we Continuous Integration
can use a bill-of-material that records what went
into the release and how it was built. Releas- Continuous integration means that members of a
ing changes to the project is a matter of how to team integrate their changes frequently. This al-
integrate changes from the developers. We need lows all developers to benefit from a change as soon
to decide on when and how that is done, and in as possible, and enables early testing of changes
particular on the “quality” of the changes before in their real context. Continuous integration also
they may be released. implies that each member should integrate changes
from the rest of the team for early detection of
Agile Activities incompatible changes. The frequent integra-
tion decreases the overall integration cost since
This section identifies a set of agile activities that incompatible changes are detected and resolved
either implement SCM activities or are directly early, in turn reducing the complex integration
affected by SCM activities. The presentation problems that are common in traditional projects
builds on our view of agile methods as being in- that integrate less often.
cremental, cooperative, and adaptive. Incremental
in that they stress continuous delivery with short Regular Builds
release cycles. Cooperative in that they rely on
teams of motivated individuals working towards Agile projects value frequent releases of software
a common goal. Adaptive in that they welcome to the customer and rapid feedback. This implies
changing requirements and reflect on how to be- more frequent builds than in traditional projects.
come more effective. While all activities presented Releases, providing added value to the customer,
in this section may not be available in every agile need to be built regularly, perhaps on a weekly

141
Software Configuration Management in Agile Development

or monthly basis. Internal builds, used by the scM In An AGILE contEXt


team only, have to be extremely quick to enable
rapid feedback during continuous integration and In the previous section, we defined some agile
test-driven development. This requires builds to activities that are related to SCM and we also
be automated to a large extent to be feasible in outlined and described the activities that make up
practice. the field of SCM. In this section, we will show how
SCM can provide support for such agile activi-
Refactoring ties so they succeed and also how agile methods
can gain even more value from SCM. It was
The incremental nature of agile methods requires demonstrated in Asklund, Bendix, and Ekman
continuous Refactoring of code to maintain high (2004) that agile methods, in this case exempli-
quality. Refactorings need to be carried out as fied by XP, do not go against the fundamental
a series of steps that are reversible, so one can principles of SCM. However, it also showed that,
always back out if a refactoring does not work. in general, agile methods do not provide explicit
This practice relies heavily on automated testing nor complete guidance for using or implement-
to ensure that a change does not break the system. ing SCM. Furthermore, the focus of SCM also
In practice, this also means that it requires quick needs to shift from control to service and support
builds when verifying behavioural preservation (Angstadt, 2000) when used in agile. SCM does
of each step. not require compliance from agile, but has a lot
of good advice that you can adapt to your project
Test-Driven Development if you feel the need for it—and thus value people
and interactions before tools and processes (Agile
Test-driven development is the practice that test Manifesto, 2001).
drives the design and implementation of new In this section, we first look at how SCM can
features. Implementation of tests and production support and service the agile activities we defined
code is interleaved to provide rapid feedback on in the previous section. Next, we look at how agile
implementation and design decisions. Automated methods could add new activities and processes
testing builds a foundation for many of the pre- from SCM and in this way obtain the full benefit
sented practices and requires extremely quick of support from SCM.
builds to enable a short feedback loop.
How Can SCM Techniques Support
Planning Game Agile?

The planning game handles scheduling of an SCM is not just about control and stopping
XP project. While not all agile methods have an changes. It actually provides a whole range of
explicit planning game, they surely have some techniques and processes that can service and sup-
kind of lightweight iterative planning. We em- port also agile development teams. Agile methods
phasize planning activities such as what features may tell you what you should do in order to be
to implement, how to manage changes, and how agile or lean, but in most cases, they are also very
to assign team resources. This kind of planning lean in actually giving advice on how to carry
shares many characteristics with the handling of out these agile processes. In this sub-section, we
change requests in traditional projects. show how SCM techniques can be used to support
and strengthen the following SCM-related agile
activities: parallel work, continuous integration,

142
Software Configuration Management in Agile Development

regular builds, refactoring, test-driven develop- the version that you used for making your changes.
ment, and planning game. If that is not the case, it means that someone has
worked in parallel and has put a new version into
Parallel Work the repository. If you add your version to the
repository, it will “shadow” the previous version
Agile teams will be working in parallel on the and effectively undo the changes done in that
same system. Not only on different parts of the version. If you do not have versioning, the new
system leading to shared data, but also on the version will simply overwrite and permanently
same parts of the system, leading to simultaneous erase the other person’s changes. Instead you
update and double maintenance. Babich (1986) must “integrate” the parallel changes and put the
explains all the possible problems there are when resulting combined change into the repository or
coordinating a team working in parallel—and file system. There are tools that can help you in
also the solutions. performing this merge.
The most common way of letting people work The “double maintenance” problem is a con-
in parallel is not to have collective code ownership, sequence of the “protection” from the “shared
but private code ownership and locking of files data” problem. In the multiple workspaces, we
that need to be changed. This leads to a “split and will have multiple copies of every file and ac-
combine” strategy where only one person owns cording to Babich (1986) they will soon cease to
some specific code and is allowed to change it. be identical. When we make a change to a file in
Industry believes that this solves the problem, one workspace, we will have to make the same
but the “shared data” problem (Babich, 1986) change to the same file in all the other workspaces
shows that even this apparently safe practice has to keep the file identical in all copies. It sounds
its problems (e.g., combining the splits). These complicated but is really simple, even though it
problems are obviously present if you practise requires some discipline. Once you have made a
parallel work as well. In addition, we have to change, you put it in the repository and—sooner
solve the “simultaneous update” problem and or later—the other people will take it in from
the “double maintenance” problem, when people the repository and integrate it if they have made
actually work on the same file(s) in parallel. changes in parallel (see the “simultaneous update”
The “shared data” problem is fairly simple problem).
to solve—if the problem is sharing, then isolate A special case of parallel work is distributed
yourself. Create a physical or virtual workspace development where the developers are physically
that contains all of the code and use that to work separated. This situation is well known in the
in splendid isolation from other people’s changes. SCM community and the described solutions
Obviously you cannot ignore that other people (Bellagio & Milligan 2005) are equally appli-
make changes, but having your own workspace, cable to distributed development as to parallel
you are in command of when to “take in” those work. There are solutions that make tools scale
changes and will be perfectly aware of what is to this setting as well. Distributed development
happening. is thus not different from parallel work from an
The “simultaneous update” problem only oc- SCM perspective, as long as the development
curs for collective code ownership where more process that SCM supports scales to distributed
people make changes to the same code at the development.
same time. Again, the solution is fairly simple, In summary, we need a repository where we
you must be able to detect that the latest version, can store all the shared files and a workspace
commonly found in the central repository, is not where we can change the files. The most impor-

143
Software Configuration Management in Agile Development

tant aspect of the repository is that it can detect nothing new has happened, you are safe and can
parallel work and that it can help us in sorting do the “upload” (or publication) integration, which
out such parallel work. Also it should be easy and simply adds your changes as the latest versions in
simple to create whole workspaces. Most version the repository. If something has changed in the
control tools are able to do that and there is no repository, it can be either new versions of files
need to use locking, which prevents real parallel that you have not changed—these can simply be
work, since optimistic sharing works well. We copied into your workspace—or files that you have
must thus choose a tool that can implement the changed where there may be conflicting changes.
copy-merge work model (Feiler, 1991). In the latter case you have to merge the repository
changes into your own changes. At this point, all
Continuous Integration other people’s changes have been integrated with
your changes and your workspace is up-to-date,
In traditional projects, the integration of the so you could just add the result to the repository.
contributions of many people is always a painful However, you should check that the integration
process that can take days or even weeks. There- actually produced a viable result and check the
fore, continuous integration seems like a mission quality of it. This can be done by running a set
impossible, but this is actually not the case. The of quality tests (e.g., unit tests, acceptance tests),
reason why integration is painful can be found and if everything works well, then you can add
in the “double maintenance” problem (Babich, the result to the repository—if your workspace is
1986)—the longer we carry on the double main- still up-to-date. Otherwise, you have to continue
tenance without integrating changes, the greater to do “download” integrations and quality checks
the task of integration will be. So there are good until you finally succeed and can do the “upload”
reasons for integrating as often as possible, for integration, as shown in Figure 3.
instance after each added feature. This way of working (except for the upload
Integrating your change into the team’s shared quality control) is implemented in the strict long
repository is often a two-step process. The reason transactions work model (Feiler, 1991). You will
is that tools usually cannot solve merge conflicts notice that in this process, the upload integration
and re-run automated tests to check the quality in is a simple copy of a consistent and quality as-
one step. First, you have to carry out a “download” sured workspace. All the work is performed in
(or subscription) integration where you take all the the download integration. Following the advice
changes that have been added to the repository of Babich (1986), this burden can be lessened if
since you last integrated and integrate them into it is carried out often as the changes you have to
your workspace, as shown in Figure 3, where a box integrate are smaller. So for your own sake you
represents a new version of the configuration. If should download integrate as often as possible.

Figure 3. Download and upload integration

144
Software Configuration Management in Agile Development

Moreover, for the sake of the team you should up- process, and automation of the build and release
load (publish) immediately when you have finished processes.
a task or story so other people get the possibility Before you can even think about releasing
to synchronize their work with yours. your code, you have to assure that the code you
What we have described here is the common- have is of good quality. In traditional development
ality between the slightly different models and methods this is often done by a separate team that
approaches presented in Aiello (2003), Appleton, integrates the code and does QA. In agile, this is
Berczuk, and Konieczka (2003a, 2003b, 2004a), done by the developers as they go. The ideal situ-
Appleton, Berczuk, and Cowham (2005), Farah ation is that the code in the repository is always
(2004), Fowler and Foemmel (2006), Moreira of the highest quality and releasable at any time.
(2004) and Sayko (2004). If you are interested in This is not always possible and you can then use
the details about how you can vary your approach a mix between the traditional way and the agile
to continuous integration depending on your ideal by having multiple development lines. The
context, you can consult the references. developers use an integration line to check in
Continuous integration leads to an increased high quality code and to stay in sync with the rest
velocity of change compared to traditional devel- of the developers. The QA-team uses a separate
opment. This puts additional strains on the inte- line to pull in changes from the integration line
gration process but is not a performance problem and does a proper and formal QA before they
on the actual integration per se. However, there “promote” the approved change to the release
may be performance issues when the integration line, as seen in Figure 4.
is combined with a quality gate mechanism used In agile methods, there is a general tendency
to determine whether changes are of sufficient to move the focus of QA from coming late in
quality to be integrated in the common repository the development process, just before release, to
or not. Even if this quality gate process is fully being a centre of attention as early as possible in
automated, it will be much slower than the actual the development process. This means that agile
merge and upload operation and may become a can do with a less formal release process than
bottleneck in the integration process. It may there- traditional projects because much of the work has
fore not always be possible to be true to the ideal already been done. However, there is still a need
that developers should carefully test their code to do physical and functional audits and to work
before uploading their changes in which case you with bill-of-materials such that earlier releases can
could use a more complex model for continuous be re-created again if needed. In agile methods,
integration (Fowler & Foemmel, 2006) that we functional audits can be carried out by running the
will describe next under regular builds. acceptance tests. They are the specification of the
requirements that should be implemented. To be
Regular Builds really sure that we have implemented everything
we claim, we should check the list of acceptance
When releases become frequent it also becomes tests against the list of requirements we claim
important to be able to build and release in a have been implemented in this release. We also
lean way. If not, much time will be “wasted” in need to check whether all the files that should be
producing these releases that are needed to get in the release (e.g., configuration files, manual,
customer feedback. Making it lean can be done documentation, etc.) are actually there.
in three ways: having always releasable code in When releasing becomes a frequent action,
the repository, performing a less formal release there is a much greater need to automate it. The

145
Software Configuration Management in Agile Development

Figure 4. Working with integration and release lines

actual creation of the release can be automated by to reduce the risk of merge conflicts. The same
using build tools; acceptance tests and the veri- goes for refactorings that should be split up into
fication that all files are there can be automated many small steps that are integrated immediately
by writing simple scripts. when they are done.
More information about regular builds can be If you need to refactor code to facilitate the
found in Appleton and Cowham (2004b). ease of implementing a story, then this refactoring
should be seen as a separate step and integrated
Refactoring separately—the same goes if you need to refac-
tor after the implementation of the story. For the
Refactoring is an important part of agile methods architectural refactorings, we need to split the
but also to some extent in traditional methods. refactoring up into smaller tasks such that there
The purpose of a Refactoring is not to implement will be as little time as possible between integra-
new functionality, but rather to simplify the code tions to lower the risk of merge conflicts. Larger
and design. refactorings should also be planned and analysed
In general, there are two different situations for impact such that it is possible to coordinate
where you do refactorings: as part of a story to the work to keep down the parallel work, or at
simplify the code before and/or after the imple- least to make people aware of the fact that it is
mentation of the story’s functionality; and archi- going on.
tectural refactorings that are needed to implement For a more specific treatment of the problems
a whole new set of features. In both cases, the two architectural refactorings can cause to SCM tools
main problems are that a refactoring may touch and the continuous integration process and how
large parts of the code and that the refactoring these problems can be dealt with, we refer the
should be traceable and possible to undo. The latter reader to Ekman and Asklund (2004) and Dig,
means that there is the need for version control Nguyen, and Johnson (2006).
tool to keep track of the steps of each refactoring
and make it possible to back out of a refactoring Test-Driven Development
if it turns out that is does not work.
The fact that refactorings tend to be “global” The short version of test-driven development
possibly affecting large parts of the code, puts even is design a little—where you design and write
greater strains on the continuous integration since tests, code a little, and finally run the tests to get
there are more possibilities of merge conflicts. feedback. Here the crucial part is to get feedback
The recommendation for successful application on what you have just changed or added. If that
of continuous integration is to integrate very often cannot happen very quickly, test-driven develop-

146
Software Configuration Management in Agile Development

ment breaks down with respect to doing it in small Planning Game


increments. If you want to run your tests after
writing a little code, you must be able to re-build Agile methods use stories, or similar lightweight
the application you want to test very quickly—if specification techniques, as the way that customers
you have to wait too long you are tempted to not specify the requirements of the system, and ac-
follow the process as it is intended. ceptance tests to specify the detailed functionality.
So what is needed is extremely quick re-builds, These stories specify changes to the system and
a matter of a few minutes or less, and the good correspond to change requests when analyzed
news is that SCM can provide that. There are from an SCM perspective. The stories, or change
techniques for doing minimal, incremental builds requests, have to be estimated for implementation
that will give you a fast turn-around time, so you cost by the developers and then prioritised and
can run your tests often without having to wait too scheduled by the customer during the planning
long. Make (Feldman, 1979) is the ancestor of all game. For someone coming from SCM this sounds
minimal, incremental build tools, but there exists very much like the traditional way of handling
a lot of research on how to trade “consistency” change requests: an impact analysis has to be
of a build for time (Adams, Weinert, & Tichy, carried out to provide sufficient information for
1989; Schwanke & Kaiser, 1988). For the small the Change Control Board to be able to make its
pair development loop in Figure 2, we might be decision whether to implement the change re-
satisfied with less than 100% consistency of the quest, defer it, or reject it. So we can see that the
build as long as it is blisteringly fast. For the big parallel to estimation in agile is impact analysis
team development loop in Figure 2 (i.e., integrating (Bohner & Arnold, 1996) in traditional SCM.
with others), speed might not be that important Likewise, the parallel to the customer prioritising
while consistency of the build is crucial. A prop- is the chair of the Change Control Board taking
erly set up SCM system will allow developers to decisions (Daniels, 1985). For the planning game
have flexible build strategies that are tailored to to work properly, it is important that everyone is
specific parts of their development cycle. aware of what his or her role is—and that they
Another aspect of test-driven development is seek information that will allow them to fill that
that if we get an unexpected result of a test-run, role well. It is also important to be aware of the
then we have to go bug hunting. What is it that fact that the traditional formal change request
has caused the malfunction? If you run tests often, handling process can indeed—and should—be
it means that you introduced the bug in the code scaled to fit the agility and informality that is
that you wrote most recently—or as Babich puts needed in an agile method.
it “an ounce of derivation is worth a pound of
analysis” (Babich, 1986)—meaning that if we can How Can SCM Add More Value to
tell the difference in the code between now and Agile?
before, we are well under way with finding the
bug. Version control tools provide functionality In agile methods, there is very much focus on
for showing the difference between two versions the developers and the production process. In the
of the same file and some tools can even show previous sub-section, we have seen how many
the structural differences between two versions of these processes can be well supported by
of a configuration. techniques and principles from SCM. However,
agile methods often overlook the aspects of SCM

147
Software Configuration Management in Agile Development

that deal with the relation to the customer and SCM tools do not support name space version-
where traditional SCM has special emphasis. In ing (Milligan, 2003) (i.e., handling structural
the following, we look at the traditional SCM as changes to the repository while retaining the
represented by the four activities of configuration change history).
identification, configuration control, configura-
tion status accounting, and configuration audit Configuration Control
(Leon, 2005). For each activity, we describe what
new activities and processes could be added to The part of configuration control that deals with
agile methods to help provide a more covering the handling of change requests is taken care of
support for the development team. by a planning game or similar activity. However,
two important aspects of configuration control
Configuration Identification are neglected by most agile methods: tracking
and traceability.
The most relevant part of configuration identi- In traditional SCM, change requests are
fication for agile methods is the identification tracked through their entire lifetime from concep-
and organisation of configuration items. Some tion to completion. At any given point in time, it is
artefacts are so important for a project that they important to know the current state of the change
become configuration items and go into the shared request and who has been assigned responsibility
repository. Other artefacts (e.g., sketches, experi- for it. This can benefit agile methods too as they
ments, notes, etc.) have a more private nature and also need to manage changes and coordinate the
they should not be shared in order not to confuse work of different people. In some agile methods
other people. However, it may still be convenient there is an explicit tracker role (chromatic, 2003)
to save and version some of the private artefacts that is responsible for this activity.
to benefit from versioning even though they are Traceability is an important property of
not configuration items. They can be put into the traditional SCM and is sometimes claimed to
repository but it is very important that the arte- be the main reason for having SCM. It should
facts, configuration items and not, are structured be possible to trace changes made to a file back
in such a way that it is absolutely clear what a to the specific change request they implement.
configuration item is and what a private artefact Likewise, it should be possible to trace the files
is. Structuring of the repository is an activity that that were changed when implementing a certain
is also important when it contains only configura- change request. The files that are related to a
tion items. change request are not just source code files,
Configuration identification is an SCM activ- but all files that are affected by that change (e.g.,
ity that traditionally is done up-front, which goes test cases, documentation, etc). Another aspect
against the agile philosophy. However, there can of traceability is to be able to know exactly what
be some reason in actually trying to follow the went into a specific build or release—and what
experience that SCM provides. Rules for identify- configurations contain a specific version of a
ing configuration items should be agreed upon, specific file. The main advantage of having good
such that they can be put into the repository and traceability is to allow for a better impact analysis
information about them shared as early as possible. so we can be informed of the consequences of
More importantly, though, is that the structuring changes and improve the coordination between
of configuration items should not be allowed to people on the team.
just grow as the project proceeds, because most

148
Software Configuration Management in Agile Development

Configuration Status Accounting activity, it contributes to the quality of the product


by verifying that certain SCM and QA activities
This activity should be seen as a service to every- have actually been carried out as agreed upon.
one involved in a project including developers and Configuration audits are needed not because we
the customer, even though it traditionally has been mistrust people, but because from time to time
used primarily by management and in particular people can be careless and forget something. The
project managers. Configuration status accounting basis for automating the functional configuration
can be looked at as simple data mining where you audit in agile is there through the use of unit and
collect and present data of interest. Many agile acceptance tests.
methods are very code centred and the repository
is the place where we keep the configuration items SCM Plans and Roles
that are important for the project, so it is natural
to place the meta-data to mine in the same reposi- You definitely need to plan and design your SCM
tory. Configuration status accounting does not activities and processes very carefully on an agile
need to be an upfront activity like configuration project. Moreover, they have to be carried out
identification, but can be added as you discover differently from how they are done on traditional
the need. However, you should be aware that the projects and the developers will need to know
later you start collecting data to mine, the less more about SCM because they are doing more
data and history you get to mine. Usually this is of it on an agile project.
seen as an activity that benefits only managers, This does not imply that you should write big
but there can be much support for the develop- detailed SCM plans the same way as it is being
ers too—all you have to do it to say what kind of done for traditional projects. The agile manifesto
meta-data you want collected and how you want (Agile Manifesto, 2001) values working software
it to be presented. If you do not document changes over comprehensive documentation. The same
in writing, then it is important that you can get goes for SCM where you should value working
hold of the person that did a change; when you SCM processes over comprehensive SCM plans.
have shared code, then it is important to see who In general, what needs to be documented are
is currently working on what. processes and activities that are either complex
or carried out rarely. The documentation needs to
Configuration Audit be kept alive and used—otherwise it will not be
up-to-date and should be discarded. We can rely
Configuration audit can be looked at as a verifica- on face-to-face conversation to convey informa-
tion activity. The actual work, considered as a QA tion within a team when working in small groups
activity, has been done elsewhere as part of other and maybe even in pairs. However, if the team
processes, but during the configuration audits, grows or we have a high turnover of personnel,
it gets verified that it has actually been carried that might call for more documentation. If pos-
out. The functional configuration audits verify sible, processes should be automated, in which
that we have taken care of and properly closed case they are also documented.
all change requests scheduled for a specific build In general, agile projects do not have the same
or release. The physical configuration audit is a specialization in roles as on traditional projects.
“sanity check” that covers the physical aspects Everyone participates in all aspects of the project
(e.g., that all components/files are there—CD, box, and should be able to carry out everything—at
manual) and that it can actually be installed. Even least in theory. This means that all developers
though configuration audit is not directly a QA should have sufficient knowledge about SCM

149
Software Configuration Management in Agile Development

to be able to carry out SCM-related activities of the files in the repository. This means that if
by themselves. There will, for instance, not be the tool does not support name space versioning
a dedicated SCM-person to do daily or weekly (Milligan, 2003), we will have a harder time because
builds or releases on an agile project. However, to we lose history information and have no support
do the design of the SCM-related work processes, for merging differing structures. However, this
even an agile team will need the help of an SCM can be handled manually and by not carrying out
expert who should work in close collaboration structural changes in parallel with other work. It
with the team such that individuals and interac- is much more problematic to actually change your
tion are valued over processes and tools (Agile repository tool in the middle of a project. Often you
Manifesto, 2001). can migrate the code and the versions but you lose
the meta-data that is equally as valuable for your
SCM Tools work as the actual code. Therefore, if possible, you
should try to anticipate the possible success and
In general, SCM is very process centric and growth of the project and make sure that the tool
could, in theory, be carried out by following these will scale to match future requirements.
processes manually. However, agile methods try
to automate the most frequently used processes
and have tools take care of them (e.g., repository FuturE trEnds
tools, build tools, automated merge tools, etc).
Fortunately, the requirements that agile methods While resisting the temptation to predict the fu-
have to SCM tooling are not very demanding ture, we can safely assume that the increased use
and can, more or less, easily be satisfied by most and awareness of SCM in agile development will
tools. For this reason, we do not want to give any result in a body of best practices and increased
tool recommendations or discuss specific tools, interaction between agile and SCM activities.
but rather focus on the general requirements and Furthermore, we expect to see progress in tool
a couple of things to look out for. Furthermore, support, including better merge support and in-
most often, you just use the tool that is given or creased traceability to name a few.
the selection is based on political issues. Continuous integration is an activity that has
Using parallel work, we would need a tool already received much attention and is quite ma-
that works without locking and thus has powerful ture and well understood. Many other SCM-related
merge capabilities to get as painless an integra- activities require continuous integration and we
tion as possible. Using test-driven development, expect to see them mature accordingly when that
we need to build very often so a fast build tool foundation is now set. This will result in new best
is very helpful—and preferably it will be flex- practices and perhaps specific SCM-related sub-
ible such that we can sometimes choose to trade practices to make these best practices explicit.
speed for consistency. Working always against A first attempt to specify SCM sub-practices for
baselines, it would be nice if the repository tool an agile setting is presented in Asklund, Bendix,
would automatically handle bound configurations and Ekman. (2004) and we expect them to mature
(Asklund, Bendix, Christensen, & Magnusson, and more sub-practices to follow.
1999) so we should not do that manually. SCM tools provide invaluable support and we
However, a couple of things should be taken envision two future trends. There is a trend to
into account about SCM tooling. Because of refac- integrate various SCM-related tools into suites
toring and the fact that the architecture is grown that support the entire line of SCM activities.
organically, there will be changes to the structure These tools can be configured to adhere to pretty

150
Software Configuration Management in Agile Development

much any desired development process. They may, enhancement does not stem directly from SCM but
however, be somewhat heavyweight for an agile indirectly by supporting other quality enhancing
setting and as a contrast, we see the use of more activities. Traceability is, for instance, crucial to
lightweight tools. Most SCM activities described evaluate any kind of quality work, and configu-
in this chapter can be supported by simple merge ration audits verify that SCM and QA activities
tools with concurrency detection. have been carried out.
Parallel work with collective code ownership We have shown how typical agile activities
can benefit from improved merge support. Current can be supported directly by SCM techniques
merge tools often operate on plain text at the file while retaining their agile properties. For instance,
level and could be improved by using more fine- continuous integration demands support from
grained merge control, perhaps even with syntactic SCM tools and processes to succeed while build
and partially semantics aware merge. An alterna- and release management can help to streamline
tive approach is to use very fine-grained merge the release process to enable frequent releases.
combined with support for increased awareness SCM can thus be used to support and strengthen
to lower the risk of merge conflicts. The increased such developer-oriented activities.
use of SCM will also require merge support for SCM is traditionally very strong in aspects
other artefacts than source files. that deal with the relation to the customer. Agile
The use of SCM in agile development will methods can benefit from these activities as well.
enable better support for traceability and track- Configuration control allows precise tracking of
ing of changes. A little extra effort can provide progress and traceability for each change request.
bi-directional traceability between requirements, Lightweight SCM plans simplify coordination
defects, and implementation. However, more ex- within a team and help in effective use of other
perience is needed to determine actual benefits SCM-related activities. These are areas that are of-
in an agile context before one can motivate and ten not mentioned explicitly in agile literature.
justify this extra “overhead.” There is, in general, no conflict between
SCM is being used more and more in agile agile methods and SCM—quite the contrary.
methods, despite not being mentioned explicitly. Agile methods and SCM blend well together
However, it is often carried out in the same way and enhance each other’s strengths. Safe SCM
as in traditional projects, but can benefit from with rigorous change management can indeed
being adapted to this new setting. The practices be carried out in an agile project and be tailored
presented in this chapter adapt SCM for agile to agile requirements.
methods but more widespread use will lead to SCM tools provide help in automating many
even more tailored SCM. In particular, SCM agile activities, but we must stress that what is
practices will be further refined to fit an agile important are the SCM processes and not so much
environment and probably lead to more agile a particular set of tools. There are also many agile
SCM. Some of these ideas may indeed transfer to activities that could be supported even better by
traditional projects, providing more lightweight enhanced tool support. For instance, current merge
SCM in that setting as well. tools are often fairly poor at handling structural
merges such as refactorings; often this results
in loss of version history and traceability, and
concLusIon incomprehensible merge conflicts.
Many agile teams already benefit from SCM,
SCM provides valuable activities that enhance but we believe that a more complete set of SCM
the QA for agile development. The main quality activities can be offered to the agile community.

151
Software Configuration Management in Agile Development

Tailored processes and tools will add even more Asklund, U., Bendix L., Christensen H. B., &
value and may indeed result in SCM activities Magnusson, B. (1999, September 5-7). The unified
that are themselves agile, which may even have extensional versioning model. Proceedings of the
an impact on more traditional software develop- 9th International Symposium on System Configu-
ment methods. ration Management, Toulouse, France.
Asklund, U., Bendix, L., & Ekman, T. (2004,
August 17-19). Software configuration manage-
rEFErEncEs
ment practices for extreme programming teams.
Proceedings of the 11th Nordic Workshop on
Adams, R., Weinert, A., & Tichy, W. (1989).
Programming and Software Development Tools
Software change dynamics or half of all ADA
and Techniques, Turku, Finland.
compilations are redundant. Proceedings
of the 2nd European Software Engineering Babich, W. A. (1986). Software configuration
Conference,Coventry, UK. management: Coordination for team productivity.
Addison-Wesley.
Agile Manifesto (2001). Manifesto for agile soft-
ware development. Retrieved June 1, 2006, from Beck, K. (1999a). Embracing change with extreme
http://agilemanifesto.org/ programming. IEEE Computer, 32(10), 70-77.
Aiello, B. (2003). Behaviorally speaking: Continu- Beck, K. (1999b). Extreme programming ex-
ous integration: Managing chaos for quality! CM plained: Embrace change. Addison-Wesley.
Journal, September.
Bellagio, D. E., & Milligan, T. J. (2005). Software
Angstadt, B. (2000). SCM: More than support configuration management strategies and IBM
and control. Crosstalk: The Journal of Defence Rational ClearCase. IBM Press.
Software Engineering, March.
Bendix, L., & Vinter, O. (2001, November 19-23).
Appleton, B., & Cowham, R. (2004b). Release Configuration management from a developer’s
management: Making it lean and agile. CM perspective. Proceedings of the EuroSTAR 2001
Journal, August. Conference, Stockholm, Sweden.
Appleton, B., Berczuk, S., & Konieczka, S. Bendix, L., & Hedin, G. (2002). Summary of the
(2003a). Continuous integration: Just another subworkshop on extreme programming. Nordic
buzz word? CM Journal, September. Journal of Computing, 9(3), 261-266.
Appleton, B., Berczuk, S., & Konieczka, S. Berczuk, S., & Appleton, S. (2003). Software con-
(2003b). Codeline merging and locking: Con- figuration management patterns: Effective team-
tinuous updates and two-phased commits. CM work, Practical Integration. Addison-Wesley.
Journal, November.
Berlack, H. R. (1992). Software configuration
Appleton, B., Berczuk, S., & Konieczka, S. management. John Wiley & Sons.
(2004a). Continuous staging: Scaling continuous
Bohner, S. A., & Arnold, R. S. (1996). Software
integration to multiple component teams. CM
change impact analysis. IEEE Computer Society
Journal, March.
Press.
Appleton, B., Berczuk, S., & Cowham, R. (2005).
Branching and merging: An agile perspective.
CM Journal, July.

152
Software Configuration Management in Agile Development

Buckley, F. J. (1993). Implementing configuration Fowler, M., & Foemmel, M. (2006). Continuous
management: Hardware, software, and firmware. integration. Retrieved June 1, 2006, from http://
IEEE Computer Society Press. www.martinfowler.com/articles/continuousIn-
tegration.html
Chromatic. (2003). Chromatic: Extreme program-
ming pocket guide. O’Reilly & Associates. Hass, A. M. (2003). Configuration management
principles and practice. Addison-Wesley.
Crnkovic, I., Asklund, U., & Persson Dahlqvist,
A. (2003). Implementing and integrating product Koskela, J. (2003). Software configuration man-
data management and software configuration agement in agile methods. VTT publications: 514,
management. Artech House. VTT Tietopalvelu.
Daniels, M. A. (1985). Principles of configuration Leon, A. (2005). Software configuration manage-
management. Advanced Applications Consul- ment handbook. Artech House.
tants, Inc.
Mikkelsen, T., & Pherigo, S. (1997). Practical
Dig, D., Nguyen, T. N., & Johnson, R. (2006). software configuration management: The Late-
Refactoring-aware software configuration man- night developer’s handbook. Prentice Hall.
agement (Tech. Rep. UIUCDCS-R-2006-2710).
Milligan, T. (2003). Better software configuration
Department of Computer Science, University of
management means better business: the seven
Illinois at Urbana-Champaign.
keys to improving business value. IBM Rational
Ekman, T., & Asklund, U. (2004). Refactoring- white paper.
aware versioning in eclipse. Electronic Notes in
Moreira, M. (2004). Approaching continuous
Theoretical Computer Science, 107, 57-69.
integration. CM Journal, November.
Farah, J. (2004). Making incremental integration
Sayko, M. (2004). The role of incremental integra-
work for you. CM Journal, November.
tion in a parallel development environment. CM
Feiler, P. H. (1991). Configuration management Journal, November.
models in commercial environments (Tech. Rep.
Schwanke, R. W., & Kaiser, G. E. (1988, January
CMU/SEI-91-TR-7). Carnegie-Mellon University/
27-29). Living with inconsistency in large systems.
Software Engineering Institute.
Proceedings of the International Workshop on
Feldman, S. I. (1979). Make—A program for main- Software Version and Configuration Control,
taining computer programs. Software—Practice Grassau, Germany.
and Experience, 9(3), 255-265.

153
154

Chapter VIII
Improving Quality by
Exploiting Human Dynamics
in Agile Methods
Panagiotis Sfetsos
Alexander Technological Educational Institution of Thessaloniki, Greece

Ioannis Stamelos
Aristotle University, Greece

AbstrAct

Theory and experience have shown that human factors are critical for the success of software engineering
practices. Agile methods are even more sensitive in such factors because they rely heavily on personal
efforts with limited guidance from process manuals, allowing freedom in choosing solutions, inter-per-
sonal communications, etc. This fact raises important issues for the management of software engineers
that are expected to apply agile methods effectively. One such issue at the agile organization executive
level is human resource management, which should take into account agile development peculiarities,
work competencies needed, agile workforce planning, etc. Another issue at the micro-management level
is agile workforce management within the development process (e.g., team planning for a specific task
or project) where individual human features will undoubtedly affect delivered quality and ultimately the
task/project degree of success. This chapter deals with one problem at each level of management in an
agile company applying extreme programming, one of the most diffused agile methods. In particular,
the first part of the chapter proposes and discusses a model for personnel management based on the
well known People-CMM1 assessment and improvement model, while the second one proposes a model
that exploits developer personalities and temperaments to effectively allocate and rotate developers in
pairs for pair programming.

Copyright © 2007, Idea Group Inc., distributing in print or electronic forms without written permission of IGI is prohibited.
Improving Quality by Exploiting Human Dynamics in Agile Methods

IntroductIon performance management, to mention some


of the most important.
Software engineering practices extensively in- • To assure and exploit personnel qualities at
volve humans under different roles (managers, the project/team level, for example, to iden-
analysts, designers, developers, testers, quality tify early and understand the effects of its
assurance experts, etc.) (Pfleeger, 2001; Sommer- developer characteristics (skills, personali-
ville, 2004). Software activities are still mostly ties, temperaments), effectively combining
based on individuals’ knowledge and skills. On the them to address problems quickly and im-
other hand, in theory, agile methods put particular prove communication and collaboration.
emphasis on people and their interactions. Agile
organizations are expected to value individuals The rest of this chapter is organized in two
and interactions over processes and tools (Beck, separate sections. The first section deals with
2000), but this fundamental consideration is of- human resource management at the corporate
ten ignored and underestimated. Employment of level. It focuses on extreme programming (XP),
people in agile projects presents both challenges which is analyzed from the perspective of the
and opportunities for managers. They should avoid people capability maturity model (P-CMM), a
pitfalls in managing agile software engineers such five-level model that prescribes a framework for
as assigning a developer to the wrong task, and managing the development of people involved
they should exploit human competencies to assure in software development processes. An analysis
high productivity and quality. As a consequence, is provided showing that an XP organization,
people management is of paramount importance starting typically from the Managed Level (Level
for agile organizations’ success. 2), would potentially successfully address most
Often large organizations, applying both agile of the P-CMM Level 2 and 3 practices, and can
and traditional methodologies, have to integrate reach Level 4 and 5 by applying quantitative
new processes with existing ones. These compa- measurements for improving performance of
nies face cultural problems highlighted by differ- the competency-based processes. Eventually, an
ences between agile and traditional teams, and adaptive P-CMM assessment and improvement
problems caused by distribution of work across process model is proposed, which can be used by
multiple teams in large and complex projects any XP organization for the successful implemen-
(Cockburn, 2002; Highsmith, 2000; Lindval et tation of its workforce management.
al., 2004). On the other hand, small organizations The second section provides a concrete ex-
are more dependent on skilled and experienced ample of how to assure quality at the project/team
developers and are often facing problems related level; a pair formation and allocation model is
to human issues such as unpleasant conditions built based on developer personalities and tem-
or relations among staff (Sfetsos, Angelis, & peraments. A thorough and systematic analysis
Stamelos et al., 2006a). of human dynamics in pair programming, the
Regardless of its size, any organization apply- most popular of XP practices, is provided aiming
ing agile methods must develop its own assessment at the improvement of quality. First, the salient
and improvement processes for two reasons: characteristics of the different personalities and
temperaments on communication, knowledge
• To assure personnel quality at the corporate management, and decision making in pair pro-
level, for example, to address workforce- gramming are analyzed. The results of a study
related problems such as bad staffing, investigating the impact of developer personalities
inadequate training, bad competency, and and temperaments on communication and col-

155
Improving Quality by Exploiting Human Dynamics in Agile Methods

laboration-viability in pair programming, using they manage to design and effectively implement
the Keirsey Temperament Sorter (KTS) (Keirsey sets of processes and practices that are advanced
& Bates, 1984), are reported. Next, an adaptive with respect to those of the previous level. One
pair formation/rotation process model for the widely accepted and used E&A model is CMM
identification, interpretation, and the effective (Paulk, Curtis, Chrissis, & Weber, 1993), and
combination of developer variations to improve its newest version CMM-I (Chrissis, Konrad, &
pair effectiveness is described. Shrum, 2003).
As was discussed previously in Introduction,
people, people quality, and people management are
AssurIng Personnel essential for agile companies. As a consequence,
QuAlIty At the corPorAte E&A people management models may help agile
level: PeoPle cAPAbIlIty companies improve their people management
MAturIty Model And extreMe processes and policies, assuring agile personnel
PrAMMIng quality. However, no such models capable to
produce agile organization assessment have been
Evaluation and assessment (E&A) are critical ac- proposed up to now. In the next, one such model,
tivities in software engineering both for products based on CMM people counterpart, namely People
and processes (Pfleeger, 2001). E&A models are CMM, is outlined.
also critical for organizations and people. They People CMM, first published in 1995 and re-
typically provide E&A structured in the form of vised 2001 (version 2) (Curtis, Hefley, & Miller,
levels; organizations achieve higher levels when 1995, 2001), is a five-level model that focuses on

Table 1. Process areas of the People CMM: Version 2

Maturity Focus Key Process Areas


Level
5 Continuously improve and • Continuous workforce innovation.
Optimizing align personal, workgroup, • Organizational performance align-
and organizational capa- ment.
bility. • Continuous capability improvement.
4 Empower and integrate • Mentoring.
Predictable workforce competencies • Organizational capability manage-
and manage performance ment.
quantitatively. • Quantitative performance manage-
ment.
• Competency-based assets.
• Empowered workgroups.
• Competency integration.
3 Develop workforce com- • Participatory culture.
Defined petencies and workgroups, • Workgroup development.
and align with • Competency-based practices.
business strategy and • Career development.
objectives. • Competency development.
• Workforce planning.
• Competency analysis.
2 Managers take responsi- • Compensation
Managed bility for managing and • Training and development.
developing their people. • Performance management.
• Work environment.
Communication and coordination staff-
ing
1 Workforce practices ap- (no KPAs at this level)
Initial plied inconsistently.

156
Improving Quality by Exploiting Human Dynamics in Agile Methods

continuously improving the management and examine XP from the People CMM perspective,
development of the human assets of a software presenting a brief summary of the KPAs effect
systems organization. People CMM, like most in each maturity level and analyzing only those
other capability maturity models, is a staged KPAs we consider successfully addressed by XP
model for organizational change consisting of five practices and values.
maturity levels through which an organization’s
workforce practices and processes evolve. Each
maturity level, representing a higher level of the InItIAl level
organizational capability, is composed of several (MAturIty level 1)
key process areas (KPAs) that identify clusters of
related workforce practices (see Table 1). At the initial level, work force practices are often
At the initial maturity level (Level 1), work- ad hoc and inconsistent and frequently fail to
force practices are performed inconsistently and achieve their intended purpose. This means that
frequently fail to achieve their intended purpose. in some areas, the organization has not defined
Managers usually rely on their intuition for manag- workforce practices, and in other areas, it has not
ing their people. To achieve the managed maturity trained responsible individuals to perform the
level (Level 2), the organization implements the practices that are established. Managers usually
discipline of performing basic workforce prac- find it difficult to retain talented individuals and
tices. While maturing to the defined level (Level rely on their intuition for managing their people.
3), these practices are tailored to enhance the Turnover is high so the level of knowledge and
particular knowledge, skills, and work methods skills available in the organization does not grow
that best support the organization’s business. To over time because of the need to replace experi-
achieve the predictable maturity level (Level 4), enced and knowledgeable individuals who have
the organization develops competency-based, left the organization.
high-performance workgroups, and empirically XP is a high-disciplined methodology, thus
evaluates how effectively its workforce prac- organizations applying XP tend to retain skilled
tices meet objectives. To achieve the optimizing people, develop workforce practices, and train
maturity level (Level 5), the organization looks responsible individuals to perform highly co-
continually for innovative ways to improve its operative best practices. Most of XP practices,
workforce capability and to support the workforce especially pair programming, encourage the
in their pursuit of professional excellence. tacit transmission of knowledge and promote
Practices of a key process area must be continuous training. Managers and coaches in XP
performed collectively achieving a set of goals organizations are well prepared to perform their
considered important for enhancing workforce workforce responsibilities. We consider that most
capability. People CMM can be applied by an XP organizations bypass the initial level.
organization in two ways: as a guide for imple-
menting improvement activities and as a standard
for assessing workforce practices. As a guide, the Key Process AreAs At the
model helps organizations in selecting high-prior- MAnAged level
ity improvement actions, while as an assessment (MAturIty level 2)
tool describes how to assess workforce capability.
Due to limited space, the reader should consult The key process areas at managed level focus on
(Curtis et al., 1995, 2001) for details about the key establishing basic workforce practices and elimi-
process areas. In the rest of this section we will nating problems that hinder work performance.

157
Improving Quality by Exploiting Human Dynamics in Agile Methods

At the managed level, an organization’s attention techniques and problem domain increases per-
focuses on unit-level issues. An organization’s ca- formance. Testing, minimizing defect rates, and
pability for performing work is best characterised on-site customer providing feedback often and
by the capability of units to meet their commit- early are also significant factors affecting posi-
ments. This capability is achieved by ensuring tively performance. The same effect is obtained
that people have the skills needed to perform their with simple design, common code ownership,
assigned work and by implementing the defined and metaphor. The purpose of training and de-
actions needed to improve performance. Staffing velopment is to ensure that all individuals have
is designed to establish basic practices by which the skills required to perform their assignments.
talented people are recruited, selected among job XP addresses successfully training needs by
candidates, and assigned to tasks/projects within rotating developers in pair programming and by
the organization. Knowledge intensive XP organi- involving them in significant practices such as
zations setting skill requirements at a higher level planning game, testing, refactoring, and meta-
must coordinate their staff selection activities to phor. Compensation is designed to provide all
attract developers capable to implement demand- individuals with payment and benefits based on
ing XP practices, such as pair programming, test their contribution and value to the organization.
driven development, etc. The purpose of commu- Apart from compensation, 40-hours a week is
nication is to establish a social environment that a practice benefiting both developers and or-
supports effective interaction and to ensure that ganization. Consequently, we consider that XP
the workforce has the skills to share information organisations would address P-CMM Level 2
and coordinate their activities efficiently. In the KPAs without problems.
XP process, communication is the most signifi-
cant of the four prized values, starting from the
early phase of the development process (planning Key Process AreAs At the
game) and being implemented in most of the other defIned level
practices (i.e., pair programming, testing, etc.). (MAturIty level 3)
The purpose of work environment is to establish
and maintain physical working conditions that In order to mature into the defined level, basic
allow individuals to perform their tasks efficiently workforce practices that have been established for
without distractions. For XP teams (usually small, units (managed level) are tailored to enhance the
2-12 persons), one large room with small cubbies particular knowledge, skills, and work methods
at the side is used. All team members (program- that best support the organization’s business. At
mers, coach, customer, etc.) work together in this this level, organization addresses organizational
room. Performance management is designed to issues, developing a culture of professionalism
establish objective criteria against which unit and based on well-understood workforce competen-
individual performance can be measured, and to cies. Competency analysis, competency develop-
enhance performance and feedback continuously. ment, and competency-based practices are de-
Skills obtained by the successful implementation signed to identify, develop, and use the knowledge,
of XP practices are capable to boost performance. skills, and process abilities required by workforce
XP addresses with success requirement changes to perform the organization’s business activities,
through user stories in planning game, continuous respectively. Career development is designed to
integrations, and small releases. Pair program- ensure that individuals are provided opportunities
ming with continuous code reviews, faster code to develop workforce competencies enabling them
production, and learning of both programming to achieve career objectives. Workgroup develop-

158
Improving Quality by Exploiting Human Dynamics in Agile Methods

ment on the other hand strives to organize work activities with current and future business needs.
around competency-based process abilities. All Consequently, we consider that XP organizations
the previously mentioned process areas contribute are well prepared to successfully address most of
in creating a participatory culture, which gives the the P-CMM Level 3 KPAs.
workforce full capability for making decisions that
affect the performance of business activities. They
also assist in workforce planning, which refers to Key Process AreAs At the
coordination of workforce activities with current PredIctAble level
and future business needs. An XP organization (MAturIty level 4)
can enhance workforce competencies by:
In maturing to the predictable level, the organi-
• Providing opportunities for individuals to zational framework of workforce competencies
identify, develop, and use their skills and that has been established in the defined level is
knowledge involving them in the imple- both managed and exploited. The organization
mentation of the XP practices, and by has the capability to predict its performance and
• Using the skills and knowledge of its work- capacity for work even when business objectives
force as resources for developing the work- are changed through a culture of measurement
force competencies of others (e.g., through and exploitation of shared experiences. The key
pair programming). processes introduced in this level help organiza-
tions quantify the workforce capabilities and the
XP teams, amalgamating technical and busi- competency-based processes it uses in perform-
ness people with divergent backgrounds and skills, ing its assignments. Competency integration is
keep the most significant role in identification, designed to improve the efficiency and agility of
development, and use of competency practices. interdependent work by integrating the process
Competency practices starts with pair program- abilities of different workforce competencies.
ming that helps managers and developers to The purpose of empowered workgroups is the
identify, develop, and use available knowledge creation of workgroups with the responsibility
and skills. Technical competencies related to and authority to determine how to conduct their
methodologies, project-based knowledge, and business activities more effectively. Competency-
tool usage are improved by planning game, based assets is designed to capture the knowl-
pair programming, test-driven development, edge, experience, and artefacts developed while
refactoring, simple design, and common code performing competency-based processes for en-
ownership. Knowledge and skills, obtained by hancing capability and performance. Quantitative
gradual training and successful projects, enhance performance management is designed to predict
organization’s knowledge repository. The XP and manage the capability of competency-based
process establishes a high participatory culture processes for achieving measurable performance
(pair programming and other practices), spreading objectives. Organizational capability manage-
the flow of information within the organization, ment is designed to quantify and manage the
and incorporating the knowledge of developers capability of the workforce and of the critical
into decision-making activities, providing them competency-based processes they perform. Men-
with the opportunity to achieve career objectives. toring is designed to transfer the lessons obtained
Iterative and incremental development with small through experience into a work-force competency
releases assist in work-force planning, which refers to improve the capability of other individuals or
to coordination and synchronization of workforce workgroups.

159
Improving Quality by Exploiting Human Dynamics in Agile Methods

XP is a team-based process helping work- Key Process AreAs At the


groups to develop more cohesion, capability, and oPtIMIzIng level
responsibility. Team-based practices, compe- (MAturIty level 5)
tency practices, training, and mentoring are the
key process areas most benefiting from pairing. The process areas at the optimizing level focus on
Mentoring in pair programming is a never-ending continuous improvement of workforce capability
process, transferring inter-personal knowledge and practices. These practices cover issues that
in an informal way (Williams & Kessler, 2002; address continuous improvement of methods for
Williams, Kessler, Cunningham, & Jefferies, developing competency at both the organizational
2000). Recent research studies have shown that and the individual level. The organization uses the
the assimilation time came down from 28 days results of the quantitative management activities
to 13 days, the mentoring time was reduced from established at level 4 to guide improvements at
32% to 25%, and the training effort was cut down this level. Continuous capability improvement
by half (Williams et al., 2002). XP process re- provides a foundation for individuals and work-
quires that developers implement best practices groups to continuously improve their capability
in extreme levels using proven competency-based for performing competency-based processes.
activities in their assignments. Managers trust Organizational performance alignment enhances
the results that developers produce and the XP the alignment of performance results across
organization preserves successful results in its individuals, workgroups, and units with orga-
repository and exploits them as organizational as- nizational performance and business objectives.
sets. Organizational assets can be used effectively Continuous workforce innovation is designed
again and again as corporate standards, increas- to identify and evaluate improved or innova-
ing productivity and spreading learning rapidly tive workforce practices and technologies, and
through the organization. Managers trusting team implement the most promising ones throughout
competencies empower teams by transferring to the organization.
them responsibility and authority for performing XP practices, especially pair programming
committed work. Developers define milestones for with pair rotation, help increasing the knowledge
coordination, integrating their competency-based level of the individuals and subsequently of the
activities into a single process. This process, con- team. As mentioned in level 4, this knowledge
stituted from different workforce competencies, enriches organization’s knowledge repository
should be institutionalized by organization, which providing both individuals and workgroups the
begins to manage its capability quantitatively. ability to continuously improve their capabilities.
The performance of each unit and team should This improvement occurs through incremental
be measured enabling organizations performance advances from the implementation of the XP
to become more predictable. The integration of practices. The results from measurements at level
the people processes with business processes 4 and the culture of improvements established by
and measuring of the co-relations between the the continuous implementation of the XP prac-
two will help an XP organization to mature up tices can help the XP organization to mature up
to this level. to this level.

160
Improving Quality by Exploiting Human Dynamics in Agile Methods

Figure 1. An adaptive people CMM assessment process model for assessing XP- organizations

An AdAPtIve PeoPle cMM people CMM to identify gaps or shortcomings.


AssessMent Process Model This kind of analysis helps the organization to
to Assess xP orgAnIzAtIons measure progress. Gap analysis can be conducted
as a guided workshop session led by a qualified
The process model we suggest is an adaptive peo- assessor or facilitator. Typical steps are:
ple CMM assessment process model in the sense
that the XP organization assesses itself against 1. An assessor or a small team of assessors
the process areas defined in each maturity level consisting of managers and developers is
(focusing mostly on those previously discussed), selected and trained in the people CMM.
and decides what course of action to take and how After a short presentation describing the
to address the improvement areas. The model (see People CMM and the purpose of the survey,
Figure 1) is divided into three stages: the program manager or facilitator assigns a
specific process area and the proper evalu-
• Input, where the people process currently ation questionnaire to assessors.
used by the XP organization and the adap- 2. Each assessor scores and comments on the
tive people CMM framework are entered process areas individually in the question-
into the process. naire, evaluating the organization against
• Operation, where the assessment process each criteria item, and determining how
takes place. well the organization satisfies the described
• Output, where the results of the assessment practices. Questionnaires can be filled in a
process, in the form of a new improved group session.
process, are adopted by the people process 3. Program manager or facilitator picks up
management task and are communicated to questionnaires, elaborates scores and com-
the organization. ments analyzing responses, and prioritizes
results for discussion.
The main assessment process starts with a gap 4. Program manager or facilitator convokes a
analysis (Curtis et. al., 1995, 2001), where organi- consensus meeting focusing on key areas
zation’s workforce activities are examined against with low scores (i.e., areas needing improve-

161
Improving Quality by Exploiting Human Dynamics in Agile Methods

ment). Meeting leads to agreement on key excellence. The step is to move into the commu-
improvement areas based on overall assess- nication phase where strengths, shortcomings,
ment and comes to a consensus on prioritized changes in organizational structure or processes,
inputs. action plans, and detailed actions that must be
5. Summary reports are written, describing the taken to improve practices are communicated to
results for both the developer and the man- the entire organization.
ager questionnaires. These reports provide
team members with information about the
consistency with which workforce practices exPloItIng Personnel
are performed and about the major issues QuAlItIes At the Project/teAM
related to them. Reports provides both sum- level: AssessIng And
mary statistical data and written comments IMProvIng PAIr ProgrAMMIng
related to questions. effectIveness bAsed on
develoPer PersonAlItIes
The assessment results are firstly incorporated
into the work-force practices and secondly the As discussed in the Introduction, one of agile
improved workforce practices are established organizations major concerns must be careful
and communicated to the organization. Analyti- personnel management at the project/team level.
cally: Apart from correct handling of individual techni-
cal skills, how could developer personality and
• Responses are analyzed and a summary temperament types be used to obtain improved
presentation is delivered to the organiza- performance and ultimately increased software
tion. quality levels? This section exemplifies such
• The recommended action plans and detailed personnel treatment by providing a model for pair
improvement activities are prioritized and formation and allocation in pair programming.
incorporated into the workforce manage-
ment task cycle plan to address identified human Issues in Pair Programming
areas for improvement. These steps in the
assessment must be repeated in short period Extreme programming bases its software devel-
times (i.e., every year) to keep the assess- opment process on a bunch of intensely social
ment up to date, to evaluate the progress of and collaborative activities and practices (Beck,
previously deployed assessment processes, 2000). The intent of these practices is to capital-
and to use the results to feed the yearly ize on developer’s unique skills, experiences,
planning cycle. idiosyncrasies, and personalities, considering
them as the first-order impact on project success.
After the application of the improved process, Pair programming, a popular practice not only in
the next step is to move into the establishing XP, is a disciplined practice in which the overall
phase where a program of continuous workforce development activity is a joint effort, a function
development is established. In this phase, a pro- of how people communicate, interact, and col-
gram of workforce development is integrated with laborate to produce results.
corporate process improvement, linking together In the past few years, pair programming has
improved workforce practices with organization’s received increased interest not only as a best
workforce process. Improved workforce practices practice in extreme programming, but also as
are continuously used incorporating a culture of a standalone programming style. It is an inten-

162
Improving Quality by Exploiting Human Dynamics in Agile Methods

sively social and collaborative activity practiced In the rest of the chapter, we will try to answer
by two developers working together at one ma- this research question and we will propose an
chine (Beck, 2000). One of the developers is the adaptive pair formation/rotation process model
driver—creating artefacts (e.g., code, designs), for the identification, interpretation, and the ef-
and the other is the navigator—peer reviewing fective combination of developer variations. We
the driver’s output and thinking of alternatives. base our approach on Cockburns’ team ecosystems
Developers must periodically switch roles and as described in his Teams as Ecosystems (Cock-
partners so that the overall development activity burn, 2002), on the findings of two field studies,
is a joint effort. Creativity becomes a function of the first at the North Carolina State University
how developers communicate, interact, and col- (Katira et al., 2004) and the second at 20 soft-
laborate to produce results (Beck, 2000). When ware development teams in Hong Kong (Gorla
working in pairs, their personal preferences, traits, & Lam, 2004), on the findings of a survey of 15
and characteristics have a strong influence on agile companies (Sfetsos et al., 2006a), and on the
their decisions and actions. results of a controlled experiment we conducted
Up to now, organizations and managers have (Sfetsos et al., 2006b).
faced pair programming as a rough technical proc- We consider pairs as adaptive ecosystems in
ess (Sfetsos et al., 2006a, Sfetsos, Stamelos, Ange- which physical structures, roles, and developer
lis, & Deligiannis, 2006b). But as in any software personalities all exert forces on each other. They
process, there exist human factors that can not are adaptive because developers through pair ro-
be easily identified and understood well enough tations, can create, learn, and respond to change.
to be controlled, predicted, or manipulated. On In these ecosystems, the overall development
the other hand, performance and effectiveness activity becomes a joint effort, a function of how
problems always exist and must be addressed paired developers communicate, interact, and
successfully. Such problems are not addressable collaborate to produce results. However, different
through the known improvement approaches, as personalities express different natural preferences
most of them focus on processes or technology, on communication, information, and knowledge
not on people. The primary role of people has been handling and sharing, decision-making, and prob-
largely ignored up to now and no efforts have been lem solving (Cockburn, 2002; Highsmith, 2002).
devoted to increase developers’ communication, Personalities are not right or wrong, they just are,
collaboration, and ultimately effectiveness or to and can be more or less effective, more or less
address pair problems and failures. Beck states that appropriate for different roles and tasks. They can
management has much to gain from psychology be turned into powerful tools instead of dividing
to understand where and why slowdowns occur obstacles, contributing to success if effectively
(Beck, 2000). Cockburn claims that only develop- combined (Ferdinandi, 1998). By understanding
ers with different personalities and with the same developer variations and knowing what motivates
experience, if effectively combined, can minimize them, we can facilitate the pair formation and
communication gaps (Cockburn, 2002). This pair rotation process, allowing individuals to
means that management must utilize processes, work in areas in which they are strong. Laplante
which first identify and understand developers’ and Neil claim that: “Having understood people
personalities and then effectively combine their motivations, it becomes easier to seek win-win
potential strengths, fostering communication and solutions or avoid causing problems” (Laplante
collaboration. However, one critical question that & Neil, 2006).
still remains to be answered is which personality
types should be combined in pair formations and
rotations?

163
Improving Quality by Exploiting Human Dynamics in Agile Methods

Pair Programming roles and Actions knowledge management (Highsmith, 2002). In


pair programming, many important decisions,
Paired developers must succeed in many formal or which must be made quickly and well are often
informal assigned roles, either pair2 or functional3, left to developers. Decisions are made, but the
such as the role of a leader, mentor, coordinator, question is what criteria are used and what is the
facilitator, innovator, analyser, tester, decision scope of the decisions. Managers must facilitate
maker, negotiator, and that of a peer reviewer, pair decision-making, taking into account devel-
to mention some of the most significant. To ac- oper personality preferences and motivations, in
complish all these different roles, developers must addition to the level of knowledge and information
deploy a broad set of interpersonal skills, which possessed by the pair, linking successful decisions
complement each other, ensuring effective pair to good performance and effectiveness. The same
interrelationship and cohesion. Literature does holds for transferring and sharing knowledge.
not provide guidelines for the optimal distribution During pair programming sessions, explicit and
of roles and tasks among the paired developers. tacit knowledge are transferred and shared be-
However, managers should assign roles and tasks tween developers. Tacit knowledge is managed
according to the strong points of developer per- first through face-to-face communication and
sonalities effectively combining their talents and subsequently through developer rotation, simple
strengths in pair rotations. workable code, and extensive unit tests.

communication and collaboration Identifying and understanding


Personalities and temperaments
Communication is one of the four prized values
in XP, but its impact on pair performance and Two widely used tools to assist in the identifi-
effectiveness has not been empirically investi- cation of personality and temperament types
gated. In particular, pair programming assumes are the Myers-Briggs Type Indicator (MBTI4)
that developers with frequent, easy, face-to-face (Myers, 1975) and the Keirsey Temperament
communication will find it easier to develop soft- Sorter (KTS) (Keirsey et al., 1984). The MBTI,
ware, get quick feedback, and make immediate a 94-item questionnaire, focuses on four areas of
corrections in their development course. But as opposite behavior preferences forming 16 different
software grows and pairs rotate, communication personality types. It is used to quickly identify
paths spread and grow, thus increasing the effort where people get their energy, how they gather
for successful communication. Therefore, col- information, how they make decisions, and which
laboration and personal contact among developers work style they prefer. The four pairs of prefer-
must be further improved, eliminating prob- ences are Extraverting (E) and Introverting (I),
lems and smoothening possible differences and Sensing (S) and iNtuiting (N), Thinking (T) and
conflicts. Developer communication, as people Feeling (F), and Judging (J) and Perceiving (P).
communication in general, is never perfect and The KTS, a 70-item questionnaire, classifies the
complete depending on developers’ personality 16 personality types into four temperament types:
preferences. Artisan (SP), Guardian (SJ), Idealist (NF), and Ra-
Collaboration is defined as an act of shared tional (NT). We used the hardcopy of the Keirsey
creation. It differs from communication in the Temperament Sorter5 to identify and interpret the
sense that it involves joint and active participation personality inventories of the participants in one
in all paired activities, especially in the creation experiment with pair programming. In Table 2,
of working software, in decision-making, and in we summarise the salient characteristics of each

164
Improving Quality by Exploiting Human Dynamics in Agile Methods

Table 2. The salient characteristics of personality types with respect to pair programming
Personality Type Salient Characteristics Suggested use in Pair
Programming
Extroverts • Get energy from the outside world, experi- • Suitable for interactions
ences, and interactions. with users and manage-
• Talk easily. ment.
• May be good drivers.
Introverts • Get energy from within themselves, from • Might not be suitable for
internal thoughts, feelings, and reflections. pair programming.
• Prefer finished ideas, prefer to read and think • Must be handled with
about something before start talking. care in meetings.
• Prefer to be silent. • May become navigators.
Sensors • Gather information linearly through senses. • Probably the most
• Observe what is happening around. capable programmers.
• Recognize the practical realities of a situation.
• Take things literally and sequentially.
• Concentrate on details.
• Prefer tangible results clearly described.
Intuitives • Gather information more abstractly • Probably the most
• See the big picture of a situation or problem. capable system and ap-
• Focus on relationships and connections be- plication analysts.
tween facts.
• Good at seeing new possibilities and different
ways of doing things.
Thinkers • Make objective decisions. • Suitable for making pair
• Are logical, critical, and orderly. decisions.
• Prefer to work with facts. • Suitable for problem-
• Examine carefully cause and effect of a choice solving situations.
or action.
• Can apply problem-solving abilities.
Feelers • Make subjective decisions. • Are good pair and team-
• Are driven by personal values. builders.
• Likes to understand, appreciate, and support • Are good in relations
others. with other pairs.
• Are more people-oriented.
Judgers • Live in an orderly and planned way, with • May be good navigators.
detailed schedules. • Generally combines well
• Prefer things decided and concluded. with a perceiver.
• Prefer to avoid last-minute stresses.
Perceivers • Live in a flexible, spontaneous way. • May be good drivers.
• Rely on experience. • Generally combines well
• Leave open issues. with a Judger.
• Explore all possibilities.
• Find difficulty with decision-making.
• Often relies on last minute work.

personality type and our suggestions for exploit- diversities in pair rotations, allowing individu-
ing them in pair programming. als to work in roles and tasks in which they can
In Table 3, we summarize the temperaments actually succeed.
salient characteristics and our suggestions for
their use in pair programming. An Adaptive Pair formation and
It is good to have variety of pairs—extroverts rotation Process Model
and introverts, abstract and concrete thinkers,
orderly and random approaches—with people In a recent field research study (Sfetsos et al.,
who enjoy diving into details before deciding 2005a), we found out that software companies
and others who decide quick and are guided by applying pair programming experienced problems
perception. Therefore, it is up to organizations due to human factors. In interviews, developers
and managers to effectively combine developer pinpointed that the most important problem they

165
Improving Quality by Exploiting Human Dynamics in Agile Methods

Table 3. The salient characteristics of temperament types with respect to pair programming

Temperament Type Salient Characteristics Suggested use in Pair Programming


Artisans (SP) • Prefer concrete communica- • Good as start-up persons.
(Sensing-Perceiving) tions. • Effective brainstormers.
• Prefer a cooperative path to goal • May be good in decision making.
accomplishment. • May exhibit adaptability and be in-
• Possess a superior sense of tim- novative.
ing.
• Prefer practical solutions.
• Are lateral thinkers.
Guardians (SJ) • Prefer concrete communica- • May be good in estimations (e.g.
(Sensing-Judging) tions. from user stories).
• Prefer more a utilitarian ap- • May be good in resource manage-
proach. ment.
• Are traditionalists and stabiliz- • May be good in planning game,
ers. contracts.
• Prefer rules, schedules, regula- • Are considered very responsible,
tions, and hierarchy. succeed in assigned tasks.
• Prefer that things remain as are.
Idealists (NF) • Prefer more abstract communi- • Will contribute to pair spirit and
(Intuitive-Feeling) cations. morale.
• Prefer more a utilitarian ap- • Are good in personal relationships.
proach. • Are good in interaction with users
• Prefer to guide others. and management.
• Excellent communicators. • May be forward and global thinkers.
Rationalists (NT) • Prefer more abstract communi- • Are good in subtask identification.
(Intuitive-Thinking) cations. (e.g., in splitting user stories)
• Prefer a cooperative path to goal • Are good in long-range plans (i.e.,
accomplishment. planning game)
• Are natural-born scientists, theo- • Are good in analysis and design.
rists, and innovators. • Are considered good in inventing
• Possess highly valuing logic and and configuring.
reason.
• Prefer competence and excel-
lence.

are facing is the unpleasant relations with their the same experience can minimize communica-
pair-mates. Besides, managers stated that such tion and collaboration gaps, we conducted a formal
problems can not be addressed easily because controlled experiment with the participation of
most improvement programs focus on processes 84 undergraduate students. The objective of the
or technology, not on people. However, in general, experiment was to compare pairs comprised of
literature and published empirical studies on pair mixed personalities with pairs of the same per-
programming do not delve in issues concerning sonalities, in terms of pair effectiveness (Sfetsos
developers’ personalities and temperaments and et al., 2006b). Pair effectiveness (similar to team
how they should be effectively combined, so as to effectiveness, Sundstrom, Meuse, & Futrell, 1990)
match their potential roles and tasks. In another was captured through: pair performance—meas-
recent case study (Katira et al., 2004), it was ob- ured by communication, velocity, productivity,
served that undergraduate students seem to work and customer satisfaction (passed acceptance
better with partners of different personality type. tests), and pair viability—measured by devel-
In order to obtain concrete evidence that supports opers’ satisfaction, knowledge acquisition, and
or rejects the hypothesis that the combination of participation (communication satisfaction ratio,
developers with different personalities and with nuisance ratio, and driver or navigator preference).

166
Improving Quality by Exploiting Human Dynamics in Agile Methods

Considering the importance of communication in (communication-collaboration reviews) for pair


pair performance, we included the communication evaluation, and the establishment of the improved
variable in the experiment variables system. The pair rotation process. In detail, the set of actions,
results of the experiment have shown that there which must be successively taken are:
is significant difference between the two groups,
indicating better performance and viability for 1. Identify developer personalities and tem-
the pairs with mixed personalities. peraments using the KTS or the MBTI
Based on the findings of the three field stud- tool, creating personality and temperament
ies, the results of the experiment and having the inventories.
theory that considers pairs as adaptive ecosys- 2. Understand and interpret the impact of
tems as framework, we propose an adaptive pair developer personalities and temperaments
formation/rotation process model (see Figure 2). on communication and collaboration us-
This model can help organizations and manag- ing existing personality and temperament
ers build high-performance pairs out of talented inventories to find their strong and weak
developers. It describes three main phases: the points.
setup phase, the assessment phase, and the im- 3. Assess existing situation analytically:
provement phase. The setup phase includes the
identification, understanding, and interpretation • Perform gap analysis. First start noticing
of the developer personalities—temperaments. developer strengths, weaknesses, and oddi-
The assessment phase includes a gap analysis and ties. Notice how some developers:
the construction or review of a set of guidelines  Fit their roles and task.
and policies for pair formation/rotations. The  Exhibit a steady performance.
improvement phase includes mini retrospectives

Figure 2. An adaptive pair formation/rotation process model

Setup phase Assessment phase Improvement phase

167
Improving Quality by Exploiting Human Dynamics in Agile Methods

 Take unnecessary risks, while others are improving workforce competencies. We believe
conservative. that organizations practicing XP should not have
 Construct a set of conventions and policies problems in addressing most of the P-CMM level
that might work well for them, suiting 2 and 3 KPAs. XP organizations, starting usually
their strengths and weaknesses. from the managed level (level 2), have to make
 Order pair formations/rotations for relatively limited adjustments in their workforce
pair programming projects, combining practices to manage other key process areas. Using
strengths to minimize weaknesses, as- measures on the performance of competency-based
signing the roles and tasks to developers processes can mature an XP organization into level
by their strong points of their personali- 4. The continuous improvement of competency-
ties. based processes, using the results of measurements,
4. Monitor developer and pair performance in can mature an XP organization into level 5. We
regular mini retrospectives (communication- described an adaptive people CMM assessment
collaboration reviews), helping developers process model for assessing XP organizations and
learn about themselves and how they will stepwise guidelines for its implementation.
effectively communicate and collaborate. In the second part of the chapter, we focused
Retrospectives for people reviews are used on human factors in pair programming, the heart
in ASD (Adaptive Software Development of the XP practices’ implementation. Considering
(Highsmith, 2000) and DSDM (Dynamic pairs as adaptive ecosystems, we investigated how
Systems Development Method) (Stapleton, developers with different personalities and tem-
1997). peraments communicate, interact, and collaborate
5. Establish improved pair formation/rotation to produce results. In particular, we established
process, communicate the results. the impact of developers’ natural preferences and
traits on the assigned roles, communication, deci-
sion-making, and knowledge management. Based
conclusIon on the findings of three field studies, the results of
an experiment, and using as framework the theo-
In the first part of this chapter, we analysed XP retical background of agile methods, we propose
from the P-CMM perspective and proposed an an adaptive pair formation/rotation process model,
adaptive P-CMM assessment and improvement which identifies, interprets, and effectively com-
process model for improving workforce quality in bines developer variations. The proposed model
XP organizations, providing stepwise guidelines can help organizations and managers improve pair
for its implementation. An agile organization’s ma- effectiveness, by matching developers’ personal-
turity from the P-CMM perspective derives from ity and temperament types to their potential roles
the repeatedly performed workforce practices, and and tasks, effectively exploiting their differences
the extent to which these practices have been inte- in pair formations and rotations.
grated into the organizations’ repository. The more
mature an organization, the greater its capability
for attracting, developing, and retaining skilled references
and competent employees it needs to execute its
business. Agile methods, in particular extreme Beck, K. (2000). Extreme programming ex-
programming, through their repeatable practices plained: Embrace change. Reading, MA: Ad-
lead to an improved workforce environment with dison-Wesley.
learning, training, and mentoring opportunities,

168
Improving Quality by Exploiting Human Dynamics in Agile Methods

Chrissis, M. B., Konrad, M., & Shrum, S. (2003). Lindvall, M., Muthig, D., Dagnino, A., Wallin, C.,
CMMI: Guidelines for process integration and Stupperich, M., Kiefer, D., May, J., & Kähkönen,
product improvement. Boston: Addison-Wesley. T. (2004, December). Agile software develop-
ment in large organizations. Computer, IEEE,
Cockburn, A. (2002). Agile software development.
37(12), 26-24.
Boston: Addison-Wesley.
Myers, I. (1975). Manual: The Myers-Briggs type
Curtis, B., Hefley, W. E., & Miller, S. (1995, Sep-
indicator. Palo Alto, CA: Consulting Psycholo-
tember). People capability maturity model (CMU/
gists Press.
SEI-95-MM-002 ADA300822). Pittsburgh, PA:
Software Engineering Institute, Carnegie Mellon Paulk, M. C., Curtis, B., Chrissis, M. B., & Weber,
University. C. V. (1993). Capability maturity model for soft-
ware, Version 1.1. Software Engineering Institute:
Curtis, B., Hefley, W. E., & Miller, S. (2001,
Capability Maturity Modeling, 82.
July). People capability maturity model Version
2.0, (CMU/SEI-2001-MM-01). Pittsburgh, PA: Pfleeger, S. (2001). Software engineering: Theory
Software Engineering Institute, Carnegie Mel- and practice (2nd ed.). NJ: Prentice-Hall, Inc.
lon University.
Sfetsos, P., Angelis, L., & Stamelos, I. (2006a,
Ferdinandi, P. (1998, September/October). Facili- June). Investigating the extreme programming
tating collaboration. IEEE Software, 92-98. system—An empirical study. Empirical Software
Engineering, 11(2), 269-301.
Gorla, N., & Lam, Y. W. (2004, June). Who should
work with whom? Building effective software Sfetsos, P., Stamelos, I., Angelis, L., & Deligi-
project teams. Communications of ACM, 47(6), annis, I. (2006b, June). Investigating the impact
79-82. of personality types on communication and col-
laboration—Viability in pair programming—An
Highsmith, J. (2000). Adaptive software devel-
empirical study. The 7th International Conference
opment: A collaborative approach to managing
on eXtreme Programming and Agile Processes in
complex systems. New York: Dorset House.
Software Engineering (XP2006), Finland.
Highsmith, J. (2002). Agile software development
Sommerville, I. (2004). Software engineering (7th
ecosystems. Boston: Addison Wesley.
ed.). Addison Wesley.
Katira, N., Williams, L., Wiebe, E., Miller, C.,
Stapleton, J. (1997). DSDM, dynamic systems
Balik, S., & Gehringer, E. (2004). On understand-
development method: The method in practice.
ing compatibility of student pair programmers.
Harlow, UK: Addison-Wesley.
SIGCSE’04 (pp. 3-7).
Sundstrom, E., De Meuse, K., & Futrell, D. (1990,
Keirsey, D., & Bates, M. (1984). Please Under-
February). Work teams. American Psychologist,
stand Me, Del Mar, California: Prometheus Book
45, 120-133.
Company.
Williams, L., & Kessler, R. (2002). Pair program-
Laplante, P., & Neil, C. (2006). Antipatterns.
ming illuminated. Boston: Addison-Wesley.
Identification, refactoring, and management.
Boca Raton, FL: Auerbach Publications. Williams, L., Kessler, R., Cunningham, W., &
Jefferies, R. (2000, July/August). Strengthening
the case for pair-programming. IEEE Software,
17, 19-25.

169
Improving Quality by Exploiting Human Dynamics in Agile Methods

endnotes

1
The people capability maturity model (P-
CMM) was developed by the Software En-
gineering Institute (SEI) at Carnegie Mellon
University (Curtis et al., 1995, 2001).
2
Roles that developers must undertake into
pairs, usually informally assigned (e.g.,
leader, mentor).
3
Roles defined by the individual’s technical
skills and knowledge (e.g., tester).
4
Myers-Briggs type indicator and MBTI are
registered trademarks of the Myers-Briggs
type indicator trust.
5
See http://keirsey.com/cgi-bin/keirsey/kcs.
cgi

170
171

Chapter IX
Teaching Agile Software
Development Quality Assurance
Orit Hazzan
Technion – Israel Institute of Technology, Israel

Yael Dubinsky
Technion – Israel Institute of Technology, Israel

AbstrAct

This chapter presents a teaching framework for agile quality—that is, the way quality issues are perceived
in agile software development environments. The teaching framework consists of nine principles, the
actual implementation of which is varied and should be adjusted for different specific teaching environ-
ments. This chapter outlines the principles and addresses their contribution to learners’ understanding
of agile quality. In addition, we highlight some of the differences between agile software development
and plan-driven software development in general, and with respect to software quality in particular.
This chapter provides a framework to be used by software engineering instructors who wish to base
students learning on students’ experiences of the different aspects involved in software development
environments.

IntroductIon Agile software development methods emerged


during the past decade as a response to the char-
Quality assurance (QA) is an integral and essential acteristics problems of software development
ingredient of any engineering process. Though processes. Since the agile methods introduced a
there is a consensus among software practitioners different perspective on QA, we will call the agile
about its importance, in traditional software de- approach toward quality issues agile quality—AQ,
velopment environments conflicts may still arise and will focus, in this chapter, on the teaching of
between software QA people and developers (Van AQ. By the term AQ, we refer to all the activities
Vliet, 2000, p. 125). (e.g., testing, refactoring, requirement gathering)

Copyright © 2007, Idea Group Inc., distributing in print or electronic forms without written permission of IGI is prohibited.
Teaching Agile Software Development Quality Assurance

that deal with quality as they are manifested and that result from such practices, the notion of a
applied in agile software development environ- production chain is eliminated in agile software
ments. It is important to emphasize that the term development environments and is replaced by
AQ does not imply that quality changes. To the a more network-oriented development process
contrary, the term AQ reflects the high standards (Beck, 2000). In practice, this means that in agile
that agile software methods set with respect to teams, the task at hand is not divided and allo-
software quality. cated to several different teams according to their
Based on our extensive experience of teach- functional description (for example, designers,
ing agile software development methods both developers, and testers), each of which executes
in academia and in the software industry1, we its part of the task. Rather, all software develop-
present a teaching framework for AQ. The teach- ment activities are intertwined and there is no
ing framework consists of nine principles, the passing on of responsibility to the next stage in
actual implementation of which is varied and the production chain. Thus, all team members are
should be adjusted for different specific teach- equally responsible for the software quality. We
ing environments (e.g., academia and industry to suggest that this different concept of the develop-
different sizes of groups). This chapter outlines ment process results, among other factors, from
the principles and addresses their contribution to the fact that software is an intangible product,
learners’ understanding of AQ. and therefore it requires a different development
In the next section, we highlight some of the process, as well as a different approach toward
differences between agile software development the concept of software quality, than do tangible
and plan-driven2 software development in general, products.
and with respect to software quality in particu-
lar. Then, we focus on the teaching of AQ. We
start by explaining why quality should be taught Agile development Methods vs.
and, based on this understanding, we present Plan-driven development Methods
the teaching framework for AQ, which suggests
an alternative approach for the teaching of AQ. During the 1990s, the agile approach toward soft-
Finally, we conclude. ware development started emerging in response
to the typical problems of the software industry.
Agile vs. Plan-driven software The approach is composed of several methods and
development it formalizes software development frameworks
that aim to systematically overcome characteristic
In this section, we highlight some of the main problems of software projects (Highsmith, 2002).
differences between agile software development Generally speaking, the agile approach reflects the
and traditional, plan-driven software develop- notion that software development environments
ment. Before we elaborate on these differences, should support communication and information
we present our perspective within which we wish sharing, in addition to heavy testing, short releases,
to analyze these differences. customer satisfaction, and sustainable work-pace
Traditional software development processes for all individuals involved in the process. Table 1
mimic traditional industries by employing some presents the manifesto for agile software develop-
kind of production chain. However, the failure ment (http://agilemanifesto.org/).
of software projects teaches us that such models Several differences exist between agile
do not always work well for software develop- software development methods and plan-driven
ment processes. In order to cope with problems

172
Teaching Agile Software Development Quality Assurance

Table 1. Manifesto for agile software development


We are uncovering better ways of developing software by doing it and helping
others do it. Through this work we have come to value:
 Individuals and interactions over processes and tools.
 Working software over comprehensive documentation.
 Customer collaboration over contract negotiation.
 Responding to change over following a plan.

That is, while there is value in the items on the right, we value the items on the
left more.

Table 2. Several differences between agile and plan-driven software development methods
Agile Software Development Plan-Driven Software Develop-
Methods ment Methods
Process orien- The development process is The development process is formu-
tation formulated in terms of activities lated in terms of stages, in which
that all team members apply on a each team member has one defined
daily basis. role in the process.
Formulation Requirements are formulated in Requirements are formulated in
of require- a gradual process during which one of the first stages of the proj-
ments customers and developers im- ect. Therefore, the cost of imple-
prove their understanding of the menting a change in requirements
developed product. This process increases the later in the process it
enables natural evolution. is introduced.
Customer Customers are available for dis- Primary contact with the custom-
involvement cussion, clarifications, etc., in all ers occurs at the beginning of the
stages of the software develop- development process.
ment process.

methods. Table 2 summarizes some of these dif- not the developers of the code whose quality is
ferences. being examined.
To illustrate the agile software development ap-
AQ vs. Plan-driven QA proach toward quality, we quote Cockburn (2001),
who describes quality as a team characteristic:
In plan-driven software development environ- Quality may refer to the activities or the work
ments, the main concept related to software products. In XP, the quality of the team’s program
quality is quality assurance, which, according is evaluated by examining the source code work
to Sommerville (2001), is “The establishment of product: “All checked-in code must pass unit tests
a framework of organizational procedures and at 100% at all times.” The XP team members also
standards which lead to high-quality software” evaluate the quality of their activities: Do they
(p. 537). Though this definition inspires an orga- hold a stand-up meeting every day? How often
nizational roof for quality assurance processes, do the programmers shift programming partners?
in reality, in many software organizations quality How available are the customers for questions? In
assurance is associated with a specific stage of some cases, quality is given a numerical value, in
a typical software development process and is other cases, a fuzzy value (“I wasn’t happy with
usually carried out by the QA people who are the team moral on the last iteration”) (p. 118).

173
Teaching Agile Software Development Quality Assurance

Table 3. Some differences between AQ and plan-driven QA


Agile Quality (AQ) Plan-Driven QA
Who is responsible for All development team The QA team
software quality? members
When are quality-related During the entire software Mainly at the QA/testing
topics addressed? development process; qual- stage
ity is one of the primary
concerns of the develop-
ment process
Status of quality-related Same as other activities Low (Cohen, Birkin, Gar-
activities relatively to field, & Webb, 2004)
other software development
activities
Work style Collaboration between all Developers and QA
role holders people might have con-
flicts (Cohen et al., 2004)

As can be seen, within the framework of tEAcHInG AGILE soFtWArE


agile software development, quality refers to the dEVELoPMEnt QuALItY
entire team during the entire process of software
development and it measures the code as well Why teach QA?
as the actual activities performed during the
development process, both in quantitative and Naturally, software engineers should be educated
in qualitative terms. Accordingly, the term qual- for quality. The importance of this belief is re-
ity assurance does not appear in agile software flected, for example, in the Software Engineer-
development as a specific stage. ing volume3 of the Computing Curricula 2001,
In Table 3, we summarize some of the no- in which software quality is one of the software
ticeable differences between the attitude toward engineering education knowledge areas (p. 20),
quality of agile software development methods and is described as follows:
and of plan-driven methods, as it is manifested
in many software organizations. Software quality is a pervasive concept that af-
We note that these previous perspectives are fects, and is affected by all aspects of software
clearly also reflected in the cultures of the two development, support, revision, and maintenance.
approaches toward software development. While It encompasses the quality of work products de-
in the context of plan-driven development, confer- veloped and/or modified (both intermediate and
ences are held that are dedicated to QA issues, deliverable work products) and the quality of the
conferences that target the community of agile work processes used to develop and/or modify the
software developers subsume all aspects of the de- work products. Quality work product attributes
velopment process, including AQ. This difference include functionality, usability, reliability, safety,
might, of course, be attributed to the maturity of security, maintainability, portability, efficiency,
the plan-driven software development approach; performance, and availability. (p. 31)
still, the observation is interesting by itself.

174
Teaching Agile Software Development Quality Assurance

Table 4. Principles of the software engineering code of ethics and professional practice
1. Public: Software engineers shall act consistently with the public interest.
2. Client and Employer: Software engineers shall act in a manner that is in the best
interests of their client and employer, consistent with the public interest.
3. Product: Software engineers shall ensure that their products and related modifi-
cations meet the highest professional standards possible.
4. Judgment: Software engineers shall maintain integrity and independence in their
professional judgment.
5. Management: Software engineering managers and leaders shall subscribe to
and promote an ethical approach to the management of software development and
maintenance.
6. Profession: Software engineers shall advance the integrity and reputation of the
profession consistent with the public interest.
7. Colleagues: Software engineers shall be fair to and supportive of their col-
leagues.
8. Self: Software engineers shall participate in lifelong learning regarding the prac-
tice of their profession and shall promote an ethical approach to the practice of the
profession.

Furthermore, the software engineering code of others, is illustrated in the next section in which
ethics and professional practice4, formulated by an we present the teaching framework we have de-
IEEE-CS/ACM Joint Task Force, addresses qual- veloped for teaching agile software development
ity issues and outlines how software developers and illustrate how AQ integrated naturally into
should adhere to ethical behavior. Table 4 presents this teaching framework.
the eight principles of the Code. Note especially
Principle 3, which focuses on quality. teaching Framework for AQ
Based on the assumption that the concept of
quality should be taught as part of software engi- This section is the heart of our chapter. In what
neering education, the question that we should ask follows, we introduce our teaching framework,
at this stage is, How should quality be taught? Later which is composed of nine principles, presented
in this section, we present our perspective on this in Table 5 as pedagogical guidelines. Each of
matter. We suggest that the nature of the software the principles is illustrated with respect to the
development methods that inspire a curriculum teaching of AQ.
is usually reflected in the curriculum itself. For As can be seen, all principles put the learners
example, in traditional software engineering and at the center of the discussion while referring to
computer science programs, QA is taught as a two main aspects—cognitive and social. Spe-
separate course, similar to the way in which it is cifically, Principles 1, 2, 3, and 7 emphasize the
applied in reality in plan-driven software devel- learning process from a cognitive perspective
opment processes. Based on our teaching experi- while Principles 4, 5, 6, 8, and 9 highlight the
ence of agile software development methods, we learning process from a social perspective. We
propose that when teaching the concept of quality note that this is not a dichotomy, but rather, each
is integrated into a software engineering program principle addresses both aspects to some degree.
that is inspired by agile software development, Accordingly, in what follows, the principles are
quality-related issues should and are integrated presented in such an order that enables a gradual
and intertwined in all topics. This idea, as well as

175
Teaching Agile Software Development Quality Assurance

Table 5. Teaching framework


• Principle 1: Inspire the agile concept nature.
• Principle 2: Let the learners experience the agile concept as much as possible.
• Principle 3: Elicit reflection on experience.
• Principle 4: Elicit communication.
• Principle 5: Encourage diverse viewpoints.
• Principle 6: Assign roles to team members.
• Principle 7: Be aware of cognitive aspects.
• Principle 8: Listen to participants’ feelings toward the agile concept.
• Principle 9: Emphasize the agile concept in the context of the software world.

mental construction of the learning environment at the same time, is supported by them. It suggests
that this teaching framework inspires. that complex concepts in software development,
Specifically, for each principle we first de- such as quality or a software development method,
scribe how it is expressed when agile software should not be lectured about, but rather, their spirit
development concepts are taught, and then how should be inspired. In other words, the teaching
it is applied in the teaching of AQ. of a complex (agile) concept should not be based
This presentation style is consistent with our solely on lecturers but rather, the learning of the
perspective of the teaching of AQ. As mentioned main ideas of such concepts is more valuable if a
previously, agile software development inspires “learning by doing” approach is applied and the
a development environment in which all activi- (agile) concept is applied, performed, and used
ties involved in software development processes by the learners. Such an experience improves the
are intertwined, and the notion of a production learners experience and skills in the said agile
chain is eliminated. Accordingly, when we teach concept, and at the same time, provides the teacher
AQ we do not separate it from the teaching of the with opportunities to elicit reflection processes.
software development process (in our case, agile The application of this principle is expressed
software development) but, rather, AQ is taught as by active learning (Silberman, 1996) on which
part of the software development process in the the next principle elaborates, and should take
same spirit in which the entire agile development place in an environment that enables the actual
process is taught. performance of the agile concept.
This section presents, in fact, the application of In the case of teaching AQ, this principle im-
our teaching framework for software development plies that the learning occurs in an environment
methods (presented in Dubinsky & Hazzan, 2005 in which it would be natural to illustrate and feel
and in Hazzan & Dubinsky, 2006) for the case the interrelation between AQ and the other activi-
of AQ. In Dubinsky and Hazzan (2005), we also ties that take place in agile software development
outline the evolutionary emergence of the teach- environments. For example, the extreme program-
ing framework and describe its implementation ming practice of whole team, which states that “a
in a specific course (including detailed schedule variety of people work together in interlinking
and activities). ways to make a project more effective” (Beck &
Andres, 2004, p. 73), should be applied in order
Principle 1: Inspire the Agile to inspire agile software development. In such
Concept Nature software development environments, when the
teacher asks the learners to expose and reflect on
This is a meta-principle that integrates several of the relationships between AQ and the other activi-
the principles described later on in this section and,

176
Teaching Agile Software Development Quality Assurance

ties, connections between AQ and other activities We do not claim that lecturing should be ab-
performed in this environment become clear. solutely avoided in the process of teaching AQ; in
fact, some aspects of AQ can and should be taught
Principle 2: Let the Learners by means of lectures. Our experience, however,
Experience the Agile Concept as Much teaches us that the more learners experience AQ
as Possible and reflect upon it, the more they improve their
understanding of the essence of the topic, as well
This principle is derived directly from the previous as their professional skills.
one. In fact, these two principles stem from the To illustrate how this principle is applied in
importance attributed to the learners’ experimen- the case of AQ, we focus on acceptance tests.
tal basis, which is essential in learning processes Here, active learning is expressed in several
of complex concepts. This assertion stands in line ways. First, learners are active in the definition
with the constructivist perspective of learning of the software requirements. Second, learners
(Davis, Maher, & Noddings, 1990; Confrey, 1995; define the acceptance tests and verify that they
Kilpatrick, 1987), the origins of which are rooted meet the requirements. Third, they develop the
in Jean Piaget’s studies (Piaget, 1977). acceptance tests. And fourth, they are guided to
Constructivism is a cognitive theory that reflect both on each individual step and on the
examines learning processes that lead to mental entire process. Such a complete process provides
constructions of knowledge based upon learners’ learners with a comprehensive message that both
knowledge and experience. According to this highlights each element of the AQ process and
approach, learners construct new knowledge by at the same time connects each of its elements
rearranging and refining their existing knowledge to the others.
(Davis et al., 1990; Smith, diSessa, & Roschelle,
1993). More specifically, the constructivist ap- Principle 3: Elicit Reflection on
proach suggests that new knowledge is constructed Experience
gradually, based on the learner’s existing mental
structures and in accordance with feedback that The importance of introducing reflective pro-
the learner receives both from other people with cesses into software development processes has
whom he or she interacts and from the different been already discussed (Hazzan, 2002; Hazzan
artifacts that constitute the learning environments. & Tomayko, 2003). This approach is based on
In this process, mental structures are developed Schön’s Reflective Practitioner perspective
in steps, each step elaborating on the preceding (Schön, 1983, 1987). Indeed, it is well known in
ones. Naturally, there may also be regressions the software industry that a reflective person,
and blind alleys. who learns both from the successes and failures
We suggest that quality in general, and AQ of previous software projects, is more likely to
in particular, are complex concepts. Therefore, improve his or her own performance in the field
their gradual learning process should be based (Kerth, 2001).
on the learners’ experience. One way to support According to this principle, learners should be
and enhance such a gradual mental learning encouraged to reflect on their learning processes
process is to adopt an active-learning teaching as well as on different situations in the software
approach according to which learners are active development process in which they participated.
to the extent that enables a reflective process We note that reflection processes should not be
(which is addressed by another principle later on limited to technical issues, but rather should
in this chapter). also address feelings, work habits, and social

177
Teaching Agile Software Development Quality Assurance

interactions related to the software development of software projects is sometimes attributed to


processes. communication issues. Accordingly, in all learn-
In order to elicit learners’ reflective processes, ing situations we aim at fostering learner-learner,
learners should be offered verbal and written as well as learner-teacher communication.
means for self-expression. The ability to express When communication is one of the main in-
one’s reflections and impressions gives learners gredients of the learning environment, the idea
the feeling that their thoughts and feelings are of knowledge sharing becomes natural. Then, in
of interest to the instructors. Naturally, such turn, knowledge sharing reflects back on com-
reflective processes might also elicit criticism munication. This principle can be applied very
and complaints. In this spirit, learners should be naturally in the context of AQ since it is a multi-
encouraged to express not only positive ideas, faceted concept. During the AQ learning process,
but also negative feelings and suggestions for learners can be asked to identify its different
improvement. facets (such as, the developer perspective, the
The teaching of AQ is a good opportunity to customer perspective, its fitness to the organiza-
illustrate this principle since it allows us to address tional culture) and to allocate the learning of its
the different facets of AQ. First, we can address facets to different team members—first learning
the technical aspect of AQ, asking learners to them, and then subsequently teaching them to the
reflect on the actual processes of applying AQ. other team members in the stage that follows. In
Specifically, learners can be asked to describe the the spirit of agile software development, it is ap-
process they went through, to indicate actions that propriate to assign the different aspects that are
improved their progress and actions that blocked to be learned to pairs of learners (rather than to
progress and should be improved, and to suggest individuals) in order to foster learning processes.
how the AQ process itself could be improved. When the team members present what they have
Second, affective aspects can be referred to dur- learned to their teammates, not only do they share
ing the reflection process. For example, learners their knowledge, but further communication is
can be asked to describe their feelings during the enhanced.
AQ process and specifically indicate actions that Another way to foster communication is to
encouraged them, as well as actions that discour- use metaphors or “concepts from other worlds.”
aged them, in their pursuit of the AQ process. Metaphors are used naturally in our daily life, as
Finally, social issues can be addressed in such well as in educational environments. Generally
reflection processes. For example, learners can speaking, metaphors are used in order to under-
be asked to indicate what teamwork actions sup- stand and experience one specific thing using the
ported the AQ process and which interfered with terms of another thing (Lakoff & Johnson, 1980;
that process and to suggest how such interactions Lawler, 1999). Communication, which is based
should be changed so as to support the AQ process. on the metaphor’s concept-world, refers not only
Furthermore, experience learners can be asked to to instances in which both concept-worlds cor-
reflect both during the AQ process and after it is respond to one another, but also to cases in which
completed—processes that Schön calls in-action they do not. If both concept-worlds are identical,
and on-action reflection, respectively. the metaphor is not a metaphor of that thing, but
rather the thing itself. Specifically, metaphors can
Principle 4: Elicit Communication be useful even without specifically mentioning the
concept of metaphor. For example, the facilitator
Communication is a central theme in software de- may say: “Can you suggest another concept-world
velopment processes. Indeed, the success or failure that may help us understand this unclear issue.”

178
Teaching Agile Software Development Quality Assurance

Our experience indicates that learners have no of openness toward alternative opinions. In the
problem suggesting a varied collection of con- case of learning AQ, which inspires different work
cept-worlds, each highlighting a different aspect habits than the ones most learners are familiar
of the said problem and together supporting the with, such openness to a different perspective is
comprehension of the topic under discussion. especially important.

Principle 5: Encourage Diverse Principle 6: Assign Roles to Team


Viewpoints Members

This perspective is based on management theo- This principle suggests that each team member
ries that assert the added value of diversity (cf. should have an individual role in addition to the
the American Institute for Managing Diversity, personal development tasks for which he or she
http://aimd.org). In the context of agile software is responsible. Based on our agile teaching and
development, it is appropriate to start by quoting research practice, we have identified 12 roles, each
Beck et al. (2004): of which is related to at least one aspect of software
development, several of which are related to AQ
Teams need to bring together a variety of skills, (Dubinsky & Hazzan, 2004a). See Table 6.
attitudes, and perspectives to see problems and The role assignment serves as a means for
pitfalls, to think of multiple ways to solve prob- distributing the responsibility for the project
lems, and to implement the solutions. Teams need progress and quality among all team members.
diversity. (p. 29) The rationale for this practice stems from the fact
that one person (or a small number of practitioners)
We argue that this perspective is correct also can not control and handle the great complexity
with respect to AQ, as explained next. involved in software development projects. When
Naturally, the more diverse a team is, the more accountability is shared by all team members, each
diverse the perspectives elicited are. These diverse aspect of the entire process is treated by single
viewpoints may improve software development team member, yet, at the same time, each team
processes in general, and the execution of AQ in member feels personally responsibility for every
particular. Specifically, in this context diversity such aspect. Indeed, both the software project
has several benefits. First, learners are exposed and all team members benefit from this kind of
to different perspectives that they can use when organization.
communicating with people from different sectors More specifically, our research shows that
and of different opinions. Second, the developed the accumulative impact of these roles increases
software product itself may be improved because the software quality both from the customer’s
when different perspectives are expressed with perspective and from the development perspec-
respect to a specific topic, the chances that subtle tive, for several reasons. First, the roles address
issues will emerge are higher. Consequently, ad- different aspects of the development process
ditional factors are considered when decisions are (management, customer, code) and together en-
made. Third, the creation process is questioned compass all aspects of a software development
more when diverse opinions are expressed and, process. Second, such a role assignment increases
once again, this may result in a more argument- the team members’ commitment to the project. In
based process based on which specific decisions order to carry out one’s role successfully, each
are made. Finally, we believe that diversity reduces team member must gain a global view of the de-
resistance to new ideas and creates an atmosphere veloped software, in addition to the execution of

179
Teaching Agile Software Development Quality Assurance

Table 6. Roles in agile teams


Role Description
Leading Group
Coach Coordinates and solves group problems, checks the Web forum and
responds on a daily basis, leads development sessions.
Tracker Measures the group progress according to test level and task estima-
tions, manages studio boards, manages the group diary.
Customer Group
End user Performs on-going evaluation of the product, collects and processes
feedback received from real end-users.
Customer Tells customer stories, makes decisions pertaining to each iteration,
provides feedback, defines acceptance tests.
Acceptance Works with the customer to define and develop acceptance tests, learns
tester and instructs test-driven development.
Maintenance Group
Presenter Plans, organizes, and presents iteration presentations, demos, and time
schedule allocations.
Documenter Plans, organizes, and presents project documentation: process docu-
mentation, user’s guide, and installation instructions.
Installer Plans and develops an automated installation kit, maintains studio
infrastructure.
Code Group
Designer Maintains current design, works to simplify design, searches for refac-
toring tasks and ensures their proper execution.
Unit tester Learns about unit testing, establishes an automated test suite, guides
and supports others in developing unit tests.
Continuous Establishes an integration environment, publishes rules pertaining to
integrator the addition of new code using the test suite.
Code Maintains source control, establishes and refines coding standards,
reviewer guides and manages the team’s pair programming.

his or her personal development tasks. This need, words, the time invested in development tasks
in turn, increases one’s responsibility toward the relative to the time invested in role activities.
development process. Third, the need to perform The second measure is the role communication
one’s role successfully increases the team mem- measure (RCM), which measures the level of
bers’ involvement in all parts of the developed communication in the team at each development
software and leads him or her to become familiar stage. The third measure is the role management
with all software parts. If team members have measure (RMM), which measures the level of the
only a limited view and are aware only of their project management. Data illustration of these
own personal development tasks, they will not metrics, taken from a specific academic project,
be able to perform their personal roles properly. can be found in Dubinsky and Hazzan (2004b).
Alternatively, the proposed role scheme supports
knowledge sharing, participants’ involvement and Principle 7: Be Aware of Cognitive
enhanced performances. Aspects
The software quality and the quality of the de-
velopment process are reflected by three measures This principle addresses two issues. The first deals
that serve as AQ teaching-metrics. The first is the with the idea of inspiring a process of on-going
role time measure (RTM). The RTM measures and gradual improvement. The second addresses
the development-hours/role-hours ratio, or in other

180
Teaching Agile Software Development Quality Assurance

the fact that software development should be ad- view of the system (high level of abstraction) to
dressed by the individuals involved on different a local, detailed view of the system (low level of
levels of abstraction. abstraction), and vise versa. For example, when
It is clear that software development is a trying to understand customers’ requirements
gradual process conducted in stages, each one during the first stage of development, develop-
improving upon those preceding it. In many cases, ers should have a global view of the applica-
this improvement takes place in parallel to an tion (high level of abstraction). When coding
improvement in the developers understanding of a specific class, a local perspective (on a lower
the developed application. Indeed, this principle is abstraction level) should be adopted. Obviously,
closely derived from the constructivist approach there are many intermediate abstraction levels
presented in the previous discussion of Principle in between these two levels that programmers
2. Accordingly, the learning environment should should consider during the process of software
specifically inspire that feeling of gradual learning development. However, knowing how and when
and elicit reflection processes when appropriate to move between different levels of abstraction
(cf. Principle 3). does not always come naturally, and requires some
We briefly present two illustrative scenarios degree of awareness. For example, a developer may
that describe how this principle can be applied in remain at an inappropriate level of abstraction for
practice. When learners try to achieve a consen- too long a time, while the problem he or she faces
sus with respect to a topic of which their current could be solved immediately if the problem were
knowledge is insufficient, the instructor/facilitator viewed on a different (higher or lower) level of
should guide them to postpone their final deci- abstraction. The required shift to that different
sion until a later stage. Sometimes, the instruc- abstraction level might not be made naturally,
tor should guide the team to make a temporary unless one is aware that this may be a possible
decision based on their current knowledge, and step toward a solution.
explicitly state that in the future they will be This principle suggests that instructors or
able to update, refine, and even change the deci- workshop facilitators who teach agile AQ should
sion just made. In other cases when learners are be aware of the abstraction level on which each
deadlocked the moderator/instructor can stop stage of each activity is performed. Based on this
the discussion, reflect on what has transpired, awareness, they then should decide whether to
and suggest to move on, explaining that it might remain on this abstraction level, or, alternatively,
make more sense to readdress the issue currently whether there is a need to guide the participants to
blocking the development progress at a later stage think in terms of a different level of abstraction.
when the learners’ background and knowledge For example, when learners are engaged in design
can solve the said problem. activities and tend to move to details related to
As mentioned before, this principle is also re- the code level, it is important to guide them to
lated to thinking on different levels of abstraction. stay at the appropriate (higher) level of abstrac-
In a previous paper (Hazzan & Dubinsky, 2003), tion. It is further suggested that the instructor
we suggested that during the process of software or facilitator explicitly highlight the movement
development, developers are required to think on between abstraction levels and discuss with the
different abstraction levels and to shift between learners the advantages that can be gained from
abstraction levels, and explain how several agile such moves.
practices (such as, refactoring and planning game) We note that the role assignment mentioned in
support this shift between abstraction level. In the discussion of Principle 6 can also be viewed
other words, developers must shift from a global as a means to encourage learners to look, think

181
Teaching Agile Software Development Quality Assurance

and examine the development process from port their work and improve the quality of their
different abstraction levels. More specifically, developed products.
if a team member wishes to perform his or her
individual role successfully, that is, to lead the Principle 9: Emphasize the Agile
project in the direction that the role specifies, he Concept in the Context of the Software
or she must gain a more global (abstract) view of World
the developed application.
This principle closes the circle that opened with the
Principle 8: Listen to Participants’ first principle—Inspire the nature of the learned
Feelings Toward the Agile Concept concept, in our case—AQ. We believe that part
of this inspiration is related to the connections
The adoption of AQ requires a conceptual change made between the concept taught and the world of
with respect to what a software development software engineering. Since the world of software
process is. In practice, when learners express engineering has witnessed relatively many cases
emotional statements against some aspect of AQ, in which new terms emerged and shortly after
we propose to take advantage of this opportunity turned out to be no more than buzzwords, when
and encourage participants to describe the subject teaching a new concept that requires developers
of the said statement as it is manifested in their to adopt a different state of mind, it is preferable
current software development environment. As to connect the new idea to the world of software
it turns out, in many cases these descriptions development, and in our case, to connect AQ to
elicit problems in the currently used approach. other agile ideas. This can be done, for example,
Then, we explain how AQ attempts to overcome by presenting the learners with specific problems
the problematic issues just raised. For example, faced by the software industry (for example,
when a statement is made against the test-driven the high rate of software projects that do not
development approach, it is a good opportunity to fit customer requirements), illustrating how the
ask the person making this statement to describe taught idea may help overcome them. Learners
the testing process that he or she is currently us- will then, hopefully, feel that, on the one hand,
ing. In some cases, this in itself is sufficient: The they are being introduced to a new idea that is
question highlights the test-driven development not detached from the software industry world
approach toward the discussed issue, and conse- and is not just a passing fashion, and on the other
quently, in many cases, the facial expression of hand, that the new approach toward quality is-
the person expressing the objection immediately sues emerged as a timely answer to the needs of
changes. the software industry and that it will be useful to
In all teaching situations, we propose to try them in the future.
sympathizing with and legitimizing learners’ In the case of teaching AQ, the need for AQ
feelings, and being patient until learners start may be first explained and some problems related
becoming aware of the benefits that can be gained to traditional QA processes may be outlined.
from the new approach. In many cases, learners’ Such a broad perspective enables learners to
objections disappeared in part after a short while. understand the place of the agile approach in the
One plausible explanation is that they begin to software industry in general, and in particular, to
realize that the new approach might actually sup- observe that AQ is a topic that is still undergoing
development.

182
Teaching Agile Software Development Quality Assurance

suMMArY Cockburn, A. (2001). Agile software development.


Boston: Addison-Wesley.
The set of principles presented in this chapter
Cohen, C. F., Birkin, S. J., Garfield, M. J., & Webb,
aims to establish a teaching framework within
H. W. (2004). Managing conflict in software test-
which we teach agile software development in
ing, Communications of the ACM, 47(1), 76-81.
general, and AQ in particular. A closer look at
the teaching framework reveals that, in fact, its Confrey J. (1995). A theory of intellectual de-
nature is similar to that of agile software develop- velopment. For the Learning of Mathematics,
ment environments. Specifically, as agile software 15(2), 36-45.
development inspires the notion of a single com-
Davis, R. B., Maher, C. A., & Noddings, N. (1990).
prehensive framework in which all activities are
Constructivist views on the teaching and learning
performed by all team members in short cycles,
of mathematics. Journal for Research in Math-
with the different activities mutually contribut-
ematics Education, Monograph Number 4, The
ing to one another, the framework described in
National Council of Teachers of Mathematics.
this chapter also inspires an integrative teaching
framework in which all principles should be ad- Dubinsky, Y., & Hazzan, O. (2004a). Roles in agile
hered to at the same time, with different focuses software development teams. The 5th International
as appropriate. Furthermore, as the assimilation Conference on Extreme Programming and Agile
of agile software development takes place in Processes in Software Engineering (pp. 157-166).
stages, the adoption of this teaching framework Garmisch-Partenkirchen, Germany.
should also be carried out gradually, according
Dubinsky, Y., & Hazzan, O. (2004b). Using a
to the culture of the environments into which the
roles scheme to derive software project metrics.
teaching framework is assimilated.
Quantitative Techniques for Software Agile Pro-
cesses Workshop, Proceedings (and selected for
the Post-Proceedings) of SIGSOFT 2004, Newport
AcknoWLEdGMEnts
Beach, CA.
Our thanks are extended to the Technion V.P.R. Dubinsky, Y., & Hazzan, O. (2005). A framework
Fund—B. and the G. Greenberg Research Fund for teaching software development methods. Com-
(Ottawa) for their support of this research. puter Science Education, 15(4), 275-296.
Fowler, M., & Beck, K. (2002). Planning extreme
programming. Boston.
rEFErEncEs
Hazzan, O. (2002). The reflective practitioner
Beck, K. (2000). Extreme programming explained: perspective in software engineering education.
Embrace change. Boston: Addison-Wesley. The Journal of Systems and Software, 63(3),
161-171.
Beck, K., & Andres, C. (2004). Extreme pro-
gramming explained: Embrace change (2nd ed.). Hazzan, O., & Dubinsky, Y. (2003). Bridging
Boston: Addison-Wesley. cognitive and social chasms in software develop-
ment using extreme programming. Proceedings
Boehm, B., & Turner, R. (2004). Balancing
of the 4th International Conference on eXtreme
agility and discipline. Reading, MA: Pearson
Programming and Agile Processes in Software
Education Inc.
Engineering (pp. 47-53). Genova, Italy.

183
Teaching Agile Software Development Quality Assurance

Hazzan, O., & Dubinsky, Y. (2006). Teaching Silberman, M. (1996). Active learning: 101 strate-
framework for software development methods. gies to teach any subject. Boston: Pearson Higher
Poster presented at the ICSE Educator’s Track. Education.
Proceedings of ICSE (International Conference
Sommerville, I. (2001). Software engineering (6th
of Software Engineering) (pp. 703-706), Shang-
ed.). Reading, MA: Addison-Wesley.
hai, China.
Smith, J. P., diSessa, A. A., & Roschelle, J. (1993).
Hazzan, O., & Tomayko, J. (2003). The reflective
Misconceptions reconceived: A constructivist
practitioner perspective in eXtreme programming.
analysis of knowledge in transition. The Journal
Proceedings of the XP Agile Universe 2003 (pp.
of the Learning Sciences, 3(2), 115-163.
51-61). New Orleans, LA.
Van Vliet, H. (2000). Software engineering:
Highsmith, J. (2002). Agile software developments
Principles and practice. New York: John Wiley
ecosystems. Boston: Addison-Wesley.
& Sons.
Kerth, N. (2001). Project retrospective. New York:
Dorset House Publishing.
EndnotEs
Kilpatrick, J. (1987). What constructivism might
be in mathematics education. In J. C. Bergeron, N. 1
For further information about our work,
Herscovics, & C. Kieran (Eds.), Proceedings of the please visit our Web site Agile Software
11th International Conference for the Psychology Development Methods and Extreme
of Mathematics Education (PME11) (Vol. I, pp. Programming (http://edu.technion.ac.il/
3-27). Montréal. Courses/cs_methods/eXtremeProgram-
ming/XP_Technion.htm).
Lakoff, G., & Johnson, M. (1980). Metaphors we 2
The term “plan-driven” was introduced by
live by. The University of Chicago Press.
Boehm et al. (2004), who divide the software
Lawler, J. M. (1999). Metaphors we compute by. development methods prevalent today into
In D.J. Hickey (Ed.), Figures of thought: For col- “agile” and “plan-driven.”
lege writers. Mountain View, California: Mayfield 3
This volume is part of the Joint Task Force
Publishing. on Computing Curricula 2001 carried out
by the Computer Society of the Institute for
Piaget, J. (1977). Problems of equilibration. In
Electrical and Electronic Engineers (IEEE-
M. H. Appel, & L. S. Goldberg (Eds.), Topics in
CS) and the Association for Computing
cognitive development, volume 1: Equilibration:
Machinery (ACM): http://sites.computer.
Theory, research, and application (pp. 3-13). New
org/ccse/SE2004Volume.pdf
York: Plenum Press. 4
ACM Code of Ethics and Professional Con-
Schön, D. A. (1983). The reflective practitioner. duct: http://www.acm.org/constitution/code.
New York: BasicBooks. html
Schön, D. A. (1987). Educating the reflective
practitioner: Toward a new design for teaching
and learning in the profession. San Francisco:
Jossey-Bass.

184
Teaching Agile Software Development Quality Assurance

Section IV
Agile Methods and Quality:
Field Experience

185
186

Chapter X
Agile Software Development
Quality Assurance:
Agile Project Management,
Quality Metrics, and
Methodologies

James F. Kile
IBM Corporation, USA

Maheshwar R. Inampudi
IBM Corporation, USA

AbstrAct

Of great interest to software development professionals is whether the adaptive methods found in agile
methodologies can be successfully implemented in a highly disciplined environment and still provide the
benefits accorded to fully agile projects. As a general rule, agile software development methodologies
have typically been applied to non-critical projects using relatively small project teams where there are
vague requirements, a high degree of anticipated change, and no significant availability or performance
requirements (Boehm & Turner, 2004). Using agile methods in their pure form for projects requiring
either high availability, high performance, or both is considered too risky by many practitioners (Boehm
et al., 2004; Paulk, 2001). When one investigates the various agile practices, however, one gets the im-
pression that each may still have value when separated from the whole. This chapter discusses how one
team was able to successfully drive software development quality improvements and reduce overall cycle
time through the introduction of several individual agile development techniques. Through the use of a
common-sense approach to software development, it is shown that the incorporation of individual agile
techniques does not have to entail additional risk for projects having higher availability, performance,
and quality requirements.

Copyright © 2007, Idea Group Inc., distributing in print or electronic forms without written permission of IGI is prohibited.
Agile Software Development Quality Assurance

IntroductIon characteristics: It is geographically distributed,


it has no co-located developers, the resulting
Traditional software development approaches, product has high performance and reliability re-
perhaps best represented by the capability ma- quirements, and the organization’s development
turity model for software (SW-CMM) (Paulk, methodology is decidedly waterfall having gained
Curtis, Chrissis, & Weber, 1993) and its successor CMM® Level 5 compliance. Therefore, some of the
the capability maturity model for software inte- fundamental paradigms that serve as the basis for
gration (CMMI®) (Chrissis, Konrad, & Shrum, successful agile development—extreme program-
2003), focus on a disciplined approach to software ming (Beck & Andres, 2005), for example—do
development that is still widely used by organiza- not exist. Nevertheless, they were successfully
tions as a foundation for project success. While able to implement several agile practices while
the strength of traditional development methods maintaining high quality deliverables and reduc-
is their ability to instill process repeatability and ing cycle time.
standardization, they also require a significant
amount of organizational investment to ensure chapter organization
their success. Organizations that have done well
using traditional approaches can also fall victim This chapter is organized as follows:
of their success through a strict expectation that
history can always be repeated (Zhiying, 2003) 1. Background: Some history is given about
when the environment becomes uncertain. our model project team and what led them
Agile development practices have frequently to investigate agile methods. The concept
been presented as revolutionary. There is some of using a hybrid plan- and agile-driven
evidence, however, that they can offer an alter- method is also introduced.
native common-sense approach when applied to 2. Approaching Selection: How did our model
traditional software engineering practices (Paulk, project team decide which agile practices to
2001). Perhaps they can be used in part to improve use and which ones to discard? This section
the development processes of projects that do not discusses the risk-based project management
fit the usual agile model (e.g., critical systems and technical approach used.
with high availability requirements)? Indeed, it 3. Implementation: This section presents how
has been suggested that project risk should be the each selected agile practice was incorporated
driving factor when choosing between agile and into the software development process.
plan-driven methods (Boehm et al., 2004) rather 4. Impact: How did the project team know the
than overall project size or criticality. This implies implemented agile practices were providing
that certain components of any project may be some benefit? This section talks generically
well suited to agility while others may not. about some of the metrics that were used
This chapter discusses how agile methods were to compare the project to prior projects
used on one team to successfully drive software performed by the same team and the impact
development quality improvements and reduce the selected methods had on the project.
overall cycle time. This is used as a framework for 5. Future Trends: A brief discussion about
discussing the impact of agile software develop- what path will be taken to approach follow-
ment on people, processes, and tools. Though the on projects.
model project team presented is relatively small 6. Conclusion.
(eight people), it has some decidedly non-agile

187
Agile Software Development Quality Assurance

bAckground Project and Historical context

How doth the little busy bee In 2003, a project was undertaken to replace an
Improve each shining hour, existing Web application used almost daily by a
And gather honey all the day significant number of individuals (almost 450,000
From every opening flower! users). This would not be an ordinary application
rewrite, however. When the business analyzed
Isaac Watts, Divine Songs, 20, Against Idleness how the product was being used and what its
and Mischief, 1715 perceived shortcomings were, it became clear
that the application needed to be taken in a whole
This chapter introduces several concepts about new direction. A project was therefore undertaken
integrating agile software development tech- to create an entirely new application—one that
niques into a project that does not have typical would incorporate the base functionality of the
agile characteristics. The information provided original application, yet include a significant
identifies the conditions that were present at the number of functional improvements, usability
time our profiled project team began to incorporate enhancements, and external dependencies. This
agile practices into their decidedly traditional was not the first attempt at replacing this applica-
development approach. We begin with a history tion (a prior attempt ended in failure), but it was
of a project development team that was unable certainly the most bold.
to meet the expectations of its customer and was This original rewrite project became troubled
unsatisfied with the progress they were making as requirements seemed to never stabilize and criti-
toward meeting their goal of quickly develop- cal milestones were continuously missed. Though
ing a quality product that supported both high it was a medium-sized project with approximately
availability and high performance. Though the 18 individuals on the development team, there were
conditions identified are specific to this project almost as many analysts, testers, and reviewers
and project team, one will most likely find them and perhaps an equal number of stakeholders. It
familiar. had the classic characteristics of what Ed Your-
Following an overview of the project and proj- don calls a “death march”—a project in which an
ect team, a brief summary is given of some of the unbiased risk assessment would determine that
existing alternative development methodologies the likelihood of failure is extremely high (Your-
that formed the basis of the team’s decision to don, 2004). Though the project was considered a
attempt to integrate agile techniques. Though a success both in delivery and quality, the personal
short section, it provides some additional insight sacrifices were extremely costly. It left the entire
into the investigatory nature underway to improve team feeling that there needed to be a change in
the team’s results. how future projects would be managed and how
This background presents the reader with a to adapt to rapid change in the future.
contextual overview that will serve to ground the
topics discussed later in the chapter. It provides a Back to Basics
starting point from which the remaining discus-
sions are based. Because a real project team is Interestingly, even though it was recognized that
being profiled, both the name of the project and things would have to change, the first change that
the product has been obscured throughout the was made was to be sure the team adhered to what
chapter. they did not hold fast to the first time: the tradi-

188
Agile Software Development Quality Assurance

tional software engineering life cycle. Though project, their ability to control the change was
this may seem somewhat counterintuitive, part through rejection or re-negotiation—they were
of the problems faced during the original “death unable to accept late changes that might have
march” project had to do with not maintaining improved the overall product. A prime example
proper control over changes, agreeing to a scope of this was in the area of end user usability. In the
that could not possibly be contained within the time traditional software development process being
allotted for the project, and not properly evaluating used, ensuring that an application is usable had
risks and dependencies. In other words, the project to be done after the application was essentially
team needed to be able to walk before it could complete (during user acceptance). Unfortunately,
run. Since traditional development methodologies this meant that there would be no time remaining
were well known and had generally predictable in the development cycle to address any changes
results, they would provide the basis upon which prior to releasing the upgraded product. The im-
any future process changes would be based. plication was that these types of “enhancements”
would always have to wait for a follow-on release
Several Small Successes to be implemented.
The project team also began to recognize that
In our experience, it is a common occurrence that their integration and subsequent testing phases
several smaller upgrade releases follow large ap- consumed a significant part of the development
plication enhancements or new application imple- schedule. Even though the project was generally
mentations—this was no exception. As the project under control, integration had become a time of
team was re-learning the basics of the software heroic sleep deprivation to ensure the schedule was
engineering process, there were two opportunities met. It was not the same situation as occurred in
to immediately put it to work and identify which the original rewrite project, but it was significant
areas were ripe for true improvement. The first enough that the team recognized that this part of
was a 2-month cycle of enhancements. It was the development process needed to be addressed
a small project, but there was still a significant differently.
staff on board to complete the work. Unlike the
first project, this one adhered to the traditional Rapidly Changing Business Needs
software engineering process and was successful
with respect to schedule, cost, and quality. The Though our profiled project team could now be
business customer was satisfied and somewhat considered successful—after all, they were able
relieved that the delivery was uneventful. to deliver on a set of scope within a defined period
The second project of enhancements was of time at a defined cost and with good quality
slightly larger in scope, but used less staff and, results—the process modifications that they made
therefore, had a longer duration. Again, a tradi- did not allow them to keep up with the rapidly
tional software development process was followed changing needs of the business. The business could
and the project was successful with regard to not afford to have 6-9 month development cycles
schedule, cost, and quality. This second project with no changes to the original scope. The releases
became a true proof point for the team and was a they sought to put out were time sensitive. They
source of confidence in their abilities. They proved also wanted the amount of functionality contained
that they could maintain control over these types within each release to remain somewhat flexible.
of projects and deliver high quality work. On the Instead, as new ideas arose, they would be added
other hand, even though requirements change ac- to a list of ever-increasing “future requirements”
tivity was similar to what occurred in the original or handled as changes that would adjust the end

189
Agile Software Development Quality Assurance

date of the release. There was also the nagging our profiled project team. Their customer was
problem of not being able to incorporate usability not only business-savvy, but had a keen inter-
defect corrections easily into the release where est in directing which technologies were used.
the defects were found without adding a separate This meant that some portion of the technical
“usability” test period with corrections prior to the solution was imparted to the development team
final user acceptance test period. As it was, they through the requirements gathering process.
were subjecting users to usability issues that would This could include individual technologies or,
not be corrected until a follow-on release. in one instance, the final production platform’s
Finally, the business was looking for more out specifications. To accommodate these types of
of the team and the team was looking for a better requirements required a bit of experimentation
way to do things. Traditional software develop- to ensure they would work. This was something
ment practices appeared to be only part of the that the traditional development process did not
solution. They had learned to walk, but weren’t easily support since some of the requirements
sure yet how to run. themselves would derive additional requirements
once investigated.
Delivery Challenges
Hybrid Methodologies
As more and more functional enhancements were
requested by the business, the team began to run Using a hybrid of adaptive and traditional software
into additional delivery challenges. Though qual- development methodologies is not as new and
ity, cost, and schedule were under control, they radical as it may at first appear. Though some of
were unable to build in the most important features the concepts related to iterative development and
fast enough for the business. In fact, they found other agile-like techniques can be traced back to at
that their cycle time to complete a project had least two decades before the first mass-produced
actually elongated. In essence, they had traded the computer was even built (Larman & Basili, 2003),
chaos of the original schedule for its opposite and the “traditional” waterfall software development
found that both didn’t really solve their problem model had gained acceptance by the late 1960s
(though not being in chaos was infinitely better). when it was proposed that engineering disciplines
They also found that just “following the process” should be used to tame wild software schedules
had a chilling effect on their customer relationship. (Naur & Randell, 1968). It derives its name from
The practice of locking down requirements and the fact that each step has distinct input and exit
stopping change made them appear unresponsive criteria that is supported by the surrounding steps
and prone to not delivering value. Though the (Figure 1). Unfortunately, the model assumes that
initial releases following the large rewrite were a project goes through the process only once and
successful, the sense of pending frustration was that the implementation design is sound (Brooks,
becoming palpable. Again, the team recognized 1995).
that they needed to do something different. Soon after being proposed, enhancements
started to appear. Over time, several evolutionary
Technical Challenges techniques were developed as a compliment or
replacement to the basic waterfall model including
Technical challenges do not always get the same modified waterfalls, evolutionary prototyping,
attention as other facets of software development staged delivery, and the spiral model (Boehm,
when discussing the speed of delivery or quality 1988; McConnell, 1996). Each enhancement
for the final product, but it was a real concern to

190
Agile Software Development Quality Assurance

Figure 1. A traditional waterfall development APProAcHIng selectIon


model
Guess if you can, choose if you dare.

Pierre Corneille, Héraclius, act IV, sc. IV, 1674

Great deeds are usually wrought at great risks.

Herodotus, Histories, VII, 50, c. 485 – c. 425


B. C.

One of the most difficult things when imple-


menting process change is deciding which changes
to make. The entire exercise is a study in risk
management since choosing the wrong thing may
impact the team’s ability to deliver. Recall that
recognized a failing in the original waterfall ap- after the tumultuous project of 2003, our profiled
proach and proceeded to address them within the project team was able to deliver on time, on cost,
replacement models. and at a reasonable level of quality—though there
was some room for improvement in the area of
Why Use a Hybrid? quality. Their challenge was to deliver faster and
be more adaptable to changes that were brought
Why use a hybrid development model and not forward within the development cycle. They rec-
adopt a single approach? The answer to this ques- ognized that changes needed to be made to make
tion is related to the amount of risk one can afford the team’s delivery better, but they wanted to be
in their project schedule, cost, and quality. Pure sure that those changes did not undo the predict-
waterfall models operate best with systems that ability they had worked so hard to attain.
require high reliability and need to be scaleable The team approached these changes from two
(McConnell, 1996). Our profiled project team perspectives: Project management and technical.
and application has high reliability and high From a project management perspective, selected
performance as key requirements, but they also changes would need to be those that would en-
have a highly volatile business environment in hance the delivery or quality of the project. From
which the priority of functional enhancements a technical perspective, the changes would need
frequently changes. to be reasonable and able to enhance practitioner
There is also a bit of a comfort factor in alter- productivity and delivery. Making changes to
ing something one already understands; One need one’s development process is a unique experi-
only learn the new techniques that replaces the ence; No two projects are the same. However,
original rather than an entirely new process. Over there seems to be at least two constants that we
time as new techniques are introduced, the old will address in the following sections prior to
process will no longer exist in its original form discussing process selection: Fear of change and
and the organization may be following a totally overcoming that fear.
new methodology—one that meets their needs.

191
Agile Software Development Quality Assurance

Fearing change project and conservative so that they could assess


the impact and determine if the change was good
Though our profiled project team recognized for the project. Agile practices seemed to make a
that there was something that needed to be done lot of sense, but a piecemeal approach to change
to make them a better team that could adapt to (advocated by those same agile practices) also
changes, deliver more quickly, and produce high seemed prudent. They decided that before they
quality results, some feared that tinkering with implemented any change, they would make sure
what was working could push them toward the their customer understood what they were doing
ad hoc development process that they had already and was supportive. In a sense, this approach
rejected. Even though they were not delivering helped them bridge the chasm between fear of
quickly and the customer could not be character- change and the consequences of not changing.
ized as completely happy, their projects seemed It should be noted that although the project
under control and they were no longer working team was able to come to the conclusion that they
90-hour weeks. should change and was able to overcome their fears
The fear of change was manifest in several by making some practical decisions, this was not
dimensions for our profiled project team. Each an easy or quick process. It developed over time
one, though, could be counterbalanced with a and with the help of the relationships they had
fear of not changing. This made for an interesting built with others in the organization.
dance of conflicting emotions around what should
be changed and what should be left alone. On one Process selection
hand, they had proven their competence to their
executive management. If they changed the way Implementing changes within any organization
they do things and failed, they risked something takes time and must be participative at all levels
that was tied directly to their self worth. Coun- to be successful (Manns & Rising, 2005). To
tering that emotion was the fear of not changing: overcome the fear of making changes, the team
If their customer was unhappy, the view of their had decided to do it in small steps—a conserva-
competence may erode regardless. tive approach that would assist their evaluation
of the change when the project was complete.
overcoming Fear They began by addressing two areas that seemed
to cause the most trouble: Requirements priori-
Fortunately for our profiled project team, their tization and putting out a version of the release
fear of not changing eventually outweighed their to the customer early so that initial tests—and
fear of change. They were able to recognize that more importantly usability tests—could be
if they did nothing, the situation they would find completed in time to provide feedback that could
themselves in would be far worse than if they then be incorporated into the code base prior to
had not tried at all. Their customer was looking deployment. Changes would still be controlled,
for something new and if the changes could be but because there were to be multiple iterations,
presented in that light, small bumps in the road there would also be multiple integrations and
may be looked upon more as a learning experi- system tests; they would have some flexibility to
ence, than failure. incorporate small changes from the first cycle into
The project management and technical lead- the second assuming they could keep the quality
ership team began to brainstorm. They came up of the release high and they planned enough time
with a plan that would make any change they for these anticipated changes.
implemented participative at all levels of the

192
Agile Software Development Quality Assurance

When the team found they had some suc- was only partially successful and required some
cess (see “Impact”) with their initial changes, additional process changes.
they became more emboldened. They suggested
and implemented more changes. We discuss the Continuous Integration
areas that were addressed earliest in the next
several sections. They are presented along with Perhaps the most frustrating part of the develop-
the reasoning behind each so that the reader can ment process for our profiled project team was the
understand why each was chosen by the project “integration” cycle. This was where the system
team. Later in the chapter, a discussion ensues was put together so that it could be functionally
about how each practice was specifically imple- tested as a whole. Part of the frustration with this
mented from a technical standpoint and the cycle process was that there was no easy way to see
time and quality impacts of each. the entire system in operation from end to end
without going through a lot of tedious build steps.
Prioritizing Requirements To address this, the team decided that they would
need to automate their builds and would need to
One of the most difficult things facing our pro- permit any team member to create a locally run-
filed project team was their joint ability with ning version of the full system at any time.
their customer to prioritize their requirements. Addressing integration took on additional
On any given day, the priority may change. What importance with respect to iterative development.
seemed to be missing was a way to quantify the If the team wished to create rapid iterations in the
requirements in a manner that would permit a future, they could not do so without addressing
reasonable prioritization. In some cases, a require- the integration and build process.
ment may be highly desired, but its cost would
make implementation prohibitive. In other cases, Automation
a requirement may be somewhat desired, but its
cost would make implementation highly desirable. One area the team thought they could gain im-
A process was needed to quickly assess require- provements in both quality and cycle time was
ments and have the customer prioritize them so in the area of automation. It has long been un-
that the team was always aware of what features derstood that design and code inspections could
and functions were desired next. significantly and positively impact the quality of
a product, but the time to perform the inspections
Iterative Development could be prohibitive for a large product. Indeed,
testing also fell into this same category—large
Partially to address their overall product quality benefit, but time consuming. To address the
and to gain early feedback on how a release was latter concerns, the team identified automating
progressing, the team decided that some form of critical reviews and testing as one of their top
iterative development should be implemented. priorities. Tools such as JUnit, JTest, Rational
Creating products iteratively goes back to an in- Performance Tester, Findbugs (http://findbugs.
vention theory from the 1920s and 1930s (Larman sourceforge.net/), SA4J (http://www.alphaworks.
et al., 2003). It is a proven technique for address- ibm.com/tech/sa4j), and Parasoft’s WebKing
ing product quality and change. As you will see, would be used (and re-used) to reduce their cycle
the team’s first foray into iterative development time while improving quality.

193
Agile Software Development Quality Assurance

IMPleMentAtIon limitations on development as enhancements were


being considered—limitations that had the result
For the things we have to learn before we can do of increasing the amount of time and money it
them, we learn by doing them. would take to make those enhancements.
In addition, the original project team that
Aristotle, Nicomachean Ethics, II, 1, ca. 384-322 worked on the first version of the product in 2003
B. C. was quite large. Due to the ad hoc nature of that
project, no coding standards had been defined or
Deciding which processes to alter as discussed adhered to. This meant that each functional area
in “Approaching Selection” was only one facet of of the application was implemented and behaved
implementing change. Each area that was selected differently. In effect, the application had internal
required a corresponding implementation action vertical silos of discrete functionality.
(or actions). This section of our chapter focuses on Changes surrounding the quality of the ap-
those actions that were taken to address overall plication needed to address each of these issues:
quality and cycle time. Of interest are some of Defect detection and correction, architectural
the reasons why certain actions were taken. As and design dependencies, and the silo effect of
you will see, the way agility was worked into independently created functions. The sections that
our profiled project team’s project can serve as a follow provide a general overview of what was
model for other project using a hybrid develop- implemented to address each of these concerns.
ment methodology where teams are looking for We begin with a discussion about the project’s
incremental or evolutionary (rather than revolu- quality management plan. From there, we intro-
tionary) process improvements. duce the concept of “technical stories” as a way
the project team codified the refactoring of existing
Improving Quality inefficient architectural and design constructs.
Next is a description of what was done to move
Perhaps one of the most vexing problems faced the defect detection and correction curve earlier
after the tumultuous 2003 project and even in in the development cycle. This is followed by a
the small step enhancement projects undertaken description of some of the methods and tools that
in 2004, was the fact that defects were being would be used to enforce best coding practices.
discovered and corrected late in the development Finally, an explanation of how continuous inte-
cycle when they were most time consuming and gration might be used to improve overall code
most expensive to correct. Adjusting the defect quality is given.
detection curve such that it afforded an earlier
indication into what was wrong and provided the Quality Management Plan
ability to make early corrections was considered
of paramount importance to improving overall Being a traditional waterfall project with a struc-
code and product quality. tured approach to development meant that our
After taking a retrospective look back at profiled project team had implemented a qual-
how the product itself was developed, it became ity management plan for each of their projects.
clear that not everything had been created in a Typically, this plan would identify, along industry
manner that would be considered optimal. There standard lines, the percentage and aggregated
were architectural and design flaws that were not number of defects that one could expect by project
necessarily apparent when the original version of phase, how those defects would be detected (e.g.,
the application was created, but began to impose

194
Agile Software Development Quality Assurance

inspection, testing, etc.) and how they would be and simplified through refactoring. This had the
removed. net effect of reducing the cost of ownership and
Rather than discard the quality management change while improving the overall quality of the
plan, the team thought it important to take the time application by consolidating change points. The
to update it with the strategy they would employ approach the team took is similar to the “user
to address the quality of the product. Though stories” concept in extreme programming.
such a document may be derided as defying the A few possible outcomes of these “technology
“barely sufficient” nature of an agile project, the stories” include:
team found it useful to document an internal goal
for the overall detection and correction of defects • Cost reduction as a result of simplifica-
and the strategy they were going to use for their tion.
early elimination from the product. This docu- • Architecture simplification through refactor-
ment also gave them a baseline from which they ing.
could measure their intended results with their • Improvement in the throughput or perfor-
actual results. mance of an individual application module
The quality management plan, therefore, or area.
became a document that identified the goals the • Architectural changes that will re-align the
team would strive to achieve and the techniques application with the long-term strategy of
they would employ to integrate agile practices the organization.
into their development process. It no longer
specified only industry standard information to defect detection and correction
which the project would attempt to comply, but a
much higher standard to which the project team The continuous feedback provided to the devel-
wished to be held. These changes are evident in opment team through the use of iterative devel-
each of he implementation practices outlined in opment and continuous integration paired with
the following sections. Each, however, was first automation and reuse supplied them with the
identified as part of the project’s quality manage- opportunity to detect and correct defects earlier
ment plan. in the development cycle and improve overall
quality. Recalling some of the difficulties the
technical stories project team had with late usability changes and
the difficulty they had integrating the system,
One thing that was identified quickly by the two practices were introduced: Test case reuse
profiled project team was that innovation could and test case automation.
often be introduced into a project that would also
satisfy a business requirement. In other words, the Test Case Reuse
way new function was added began to have both
a technical component in addition to the business When a project is undertaken to enhance an
component. These so-called “technical stories” existing product, a common scenario that many
became part of the requirements gathered after developers face is the re-introduction of defects
each release and, later on, iteration. They were from prior releases when a new feature is added
influenced by a retrospective look at what went without understanding the overall purpose of the
well and what did not go so well during each de- module (or function). One way to combat this is
velopment cycle. As a result of these reflections, to retain the unit and functional test cases from
the architecture of the application was reduced release to release and execute them prior to and

195
Agile Software Development Quality Assurance

Figure 2. Technology-based proposals in release planning

Figure 3. Test case reuse process during each build of the system. By integrating
execution of the test cases with the build process,
one can be assured that existing functionality is
not compromised by changes made to the product;
Either the new changes are incorrect or the test
case is no longer valid. This reduces the number
of undetected defects in a release and improves
the overall quality of the application. Instead of
finding issues during integration or system test-
ing, they can be found and corrected prior to or
during each system build. The theory is that the
closer the defect is detected to when the change
is made, the easier it will be to recall what was
changed and fix it. An example of the process
followed appears in Figure 3.

Automated Test Case Execution

Agile principles encourage developers to adopt


test-driven development. Whether a project fol-
lows a pure agile approach, a hybrid approach (as
was used here), or a traditional methodology, there

196
Agile Software Development Quality Assurance

Figure 4. Automated functional test cases using Rational Functional Tester

is value in testing code in an automated fashion for client-based and Web-based applications. A
at the unit and function level. Retaining these test sample report appears in Figure 4.
cases so that all developers can execute them in
an automated fashion to ensure that their changes enforce coding Practices
do not break the system is an agile principle that
was implemented for this project team to measure One area of quality that is oftentimes not ad-
project progress, address interim code quality, dressed by a project team is the way code will
and assist in the development of new classes or be written. Documenting the coding standards
methods. It should be noted that since these test up front is helpful, but it will not ensure that an
cases were being built upon an existing product individual will not violate the project’s standards
that did not have them initially, they were first or best coding practices in general. Rather than
built against those areas that required change. implement a series of manual code inspections,
Those cases remained available as subsequent several tools were implemented to ensure best
projects were undertaken. practice compliance.
Two tools were used to automate test case ex-
ecution. The first, not surprisingly, was JUnit for Automated Code Reviewers
unit testing. For functional testing, IBM’s Rational
Function Tester was used. This latter tool easily Tools such as Parasoft’s JTest, RAD Code Re-
integrates with the build process and provides an viewer, and WebKing can be plugged right into
automated functional regression testing platform the developer’s IDE. They help ensure that code
is written according to a standard the team has

197
Agile Software Development Quality Assurance

Figure 5. Example automated code review rules

set. They also can catch common mistakes and that help them understand potential run time
identify problem areas that may need to be ad- defects either due to the way something was
dressed. Each developer on the project team was implemented or by finding architectural anti-pat-
required to install the plug-ins into their develop- terns that can reduce the application’s stability in
ment environment and execute the review process the production environment.
prior to checking the code in or integrating it into
the system build. An example of some of the rules “continuous” Integration
used appears in Figure 5.
Tools such as IBM’s Rational Application One of the extreme programming practices that
Developer Code review tool can be used to show our profiled project team readily adopted was
the details and the nature of a violation including the concept of continuous integration. Recall
the class name and the line number of the code that one of the most difficult project activities
where the violation occurred (see Figure 6). was the integration of created components into
a functioning whole. It was felt that if the inte-
Automated Static and Stability Analysis gration of the application could become more
continuous—more agile—it would be possible
Static analysis tools such as Findbugs (http://find- to see the system working earlier, identify and
bugs.sourceforge.net/) and Structural Analyzer remove integration defects in closer proximity
for Java (SA4J) (http://www.alphaworks.ibm. to when they were introduced, and enforce the
com/tech/sa4j) can be embedded into the build view that the system must always be kept in an
process to verify the quality of the build. These operational state.
tools produce reports for the development team

198
Agile Software Development Quality Assurance

Figure 6. Example code review automation (IBM Rational Code Reviewer)

Automating the Build process identified in several technical stories for


the application.
The primary barrier to continuous integration was
an onerous build process. One of the technical • Pull the latest checked-in source software
stories, therefore, was to automate the product from the library control system (CVS).
build such that it could be started by any developer • Execute automated code analysis tools on the
in their own workspace and in the integration extracted code to verify the code’s look and
environment (under the proper controls). Apache’s feel and identify any anti-patters violations
ANT (http://ant.apache.org), as the de facto stan- of best practices in the code base.
dard for build automation, would be used as the • Build an EAR package and execute all exist-
foundation for this automated build process. In ing JUnit test cases against the code package
addition to automating the build itself, the script and push the results to a build status Web
would also incorporate several of the code verifi- page.
cation steps identified earlier: functional analysis, • Install the application into the runtime en-
structural analysis, functional test verification, vironment.
coding practices, etc. • Execute the automated functional test cases
using Rational Functional Tester and publish
the build Process the results to the build status Web page.
• Execute an overall architectural quality
The following process provides a general overview check using structural analysis tools (e.g.,
of the steps to be followed by the automated build SA4J).

199
Agile Software Development Quality Assurance

Figure 7. Example static analysis report

A graphical representation of this process the results. It should be noted that these are results
appears in Figure 8. from one team and that the experiment would need
to be expanded to others to assess its validity in a
Mapping the Build Framework to the broader context. Regardless, some of the results
Development Process are rather remarkable.

Every time a developer adds code to the system Requirements Prioritization:


either as part of an iteration or as part of a release, time Boxing the Schedule
the overall integration with existing code (and code
written by others) is taken care of by the build As identified in the “Approaching Selection”
process. This process is depicted in Figure 9. section, instead of beginning with a fixed set of
requirements from which a project sizing and
project plan was derived, the most important
IMPact requirements were identified and given a rough
sizing. Based upon this rough sizing, the require-
Nothing quite new is perfect. ments were re-ordered. The schedule was broken
down into discrete “time boxes” that dictated how
Marcus Tullius Cicero, Brutus, 71, c. 106 B.C.- much would be spent and how many features
43 B.C. could be contained within a particular iteration
or a project. Anything that could not fit would be
What was the overall impact of the changes that re-prioritized into a follow-on project (or iteration).
were made? By and large, the impact was positive. This method permitted the customer to introduce
The team proved they could successfully integrate what they considered the most important features
agile techniques into a traditional development into the product and regularly deliver function to
process. What follows is a summary of some of

200
Agile Software Development Quality Assurance

Figure 8. Automated build tools stack


Automated Structural Analysis
(using SA4J like tools)

Automated Functional Test Case Execution


(using Rational Functional Tester like tools)

Automated Unit Test Cases


(using JUnit/JUnitEE like tools)

Automated Code Analysis


(using RAD Code Reviewer and FindBugs like tools)

Build Process—Foundation
(Based on ANT scripts)

Figure 9. Continuous integration using automated tools

New features Add more code

New funtionality or pending Automated functional, unit


features, if containable as per testing, & quality analysis
the time-box planning

User stories Iteration Build


Release Plan Development
Planning Iteration Plan Process

Pending work from New Iteration


previous iteration
Unfinished
Tasks

To the next fix pack or release planning

the business. Since the estimation at the beginning team was willing to help them meet their goals
was by necessity a rough order of magnitude, and change the way they do things in support of
as the team began the work additional adjust- those goals. (Note: This satisfaction rating was
ments would be made to the scope. If the size of for the entire release and most likely reflects the
a feature grew beyond what could be contained improvement in quality—discussed later—as well
within a project, it would be discarded (or, if truly as the way requirements were prioritized.)
important, the date would change). If the size of
a feature was smaller than what was originally Iterative Development
anticipated, additional features would be added
from the prioritized list (see Figure 10). Breaking each release into smaller iterations
Using this approach, customer satisfaction had a three-fold impact on the projects. First, the
increased from essentially failing on the first customer was able to see the results of built-in
project to 97.3% on the first project that used features earlier. This allowed them to re-assess
this approach—they recognized that the project the priority of the remaining requirements against

201
Agile Software Development Quality Assurance

Figure 10. Time boxed requirements prioritization

Work with the customer team Create project plans based


Create a list of features during Bundle these requirements to
to prioritize the features and the on schedule expectations of
pre-concept phase of a project create versions or releases of
delivery time expectations for the customer
the product
each of those features

changes that they may wish to implement. From continuous Integration


a customer satisfaction perspective, the team was
beginning to be seen as much more flexible—yet, Perhaps one of the biggest gains the project
the project was still under control. team saw from a quality perspective was as a
The second area of positive impact area was the result of implementing their version of continu-
team’s ability to have usability testing done on the ous integration. As previously discussed, this
parts of the application as they were produced. This involved automating the build process such that
meant that any usability defects identified could testing occurred at each run and the system
be rolled in to the next iteration and would be in always remained in a workable state. Creating
the final build rather than waiting six months for the build process cost approximately 100 labor
a follow-on project to be commissioned. This had hours to the team. The amount of time saved in
the net effect of improving end user satisfaction to integration and integration testing, however, was
above 85%—which was a significant improvement 300 hours and almost two weeks cycle time. On
from 76% given the size of the population. the project it was implemented in, the additional
The third area of impact was in the quality of time was used to contain additional features that
the final product. Since the system was being “put originally did not fit in the planned time boxes.
together” more frequently (also see the discussion For future projects, the additional time will be
on continuous integration results), the amount of factored into the schedule as available for general
time spent cleaning up integration errors was sig- development.
nificantly reduced. While the initial 2003 project
had greater than 400 user acceptance defects, less Automation
than a year later the user acceptance phase for all
of the iterations combined had three defects (one Although automation took on various forms
of severity 3 and two of severity 4). including the creation of the automated build
As we mentioned, not everything was posi- used for continuous integration, there were some
tive. The way the team initially implemented additional positive impacts to cost and quality.
iterations was not as clean as it could be. They For example, even though there was a cost to
were rushing at the end of the first iteration to get modifying automated test cases from release to
function working. This lesson learned was built release, that cost was minimal compared to creat-
into their second project—they more discretely ing a new test suite each time or executing all of
planned the iterations so that they would have the test cases manually. Some interesting statis-
enough time to put the system together prior to tics were gathered from project to project. The
the interim review by the customer. Interestingly, original project in 2003 used 12.7% of its overall
when they automated the build and began to use budget (hours) to conduct functional and system
a more continuous form of integration, this ad- testing (not user acceptance testing where most
ditional planning was no longer required. of the defects were eventually found). Through

202
Agile Software Development Quality Assurance

automation and reuse of the test case library, the has continues to show that smaller, more frequent
two subsequent similarly sized projects consumed releases have a positive impact on the overall
5.8% and 5.2% of their budget on function and quality of a software development project (see
system testing respectively. Madsen, 2005, for example). Several “heavier”
Recall that automation also added several tools methodologies such as the rational unified process
that checked the stability and quality of the code. always embraced iterations and even that has had
Perhaps the best measure of impact on the project its share of agile practices introduced as process
is that after incorporating the recommendations improvements (Ambler, 2006). We expect this
for coding standard best practices and address- trend toward smaller, incremental releases with
ing structural weaknesses, the amount of time agile components to continue.
required to maintain it was reduced by almost
10%. In a world where operation budgets are con- reviews
strained, this was considered a significant under
run. Most of it related to the reduced amount of Another future trend in agile quality management
call support from people who were having trouble seems to be the return of peer reviews. Agile prac-
using the application or finding obscure errors tices typically rely on up front test cases to ensure
that had not been caught in the project team’s quality, but some of the current literature indicates
own testing. that peer reviews still play an important role in
software development. Some recent research has
been conducted on focusing reviews on the most
Future trends important aspects of a particular project based
upon risk and the perceived value of a particular
In our opinion, the trend toward using agile soft- review (Lee & Boehm, 2005). This suggests that
ware development practices in general and as a reviews themselves may also be moving toward
way to enhance the quality of products developed a sufficiency model similar to agile. It will be
using traditional practices will continue. As with interesting to see if a review structure will appear
the profiled project team used as the basis for this as part of pure agile practices.
chapter, we also see a trend toward using risk to
identify which practices may work best in a par- More Hybrids
ticular environment. That will mean that projects
that are not thought of as being able to easily use As with our profiled project team, not everyone
agile practices to enhance quality or reduce cycle is willing or able to move to completely agile
time and cost today—such as those with high approaches for their software development either
availability requirements or high performance due to perceived complexity or performance and
requirements—may have an agile component in availability requirements. We believe that the
the future. evolutionary introduction of agile practices into
traditional organizations will continue, but altera-
smaller and More Frequent releases tions may be required for an organization to derive
value as in Svensson and Host (2005). Perhaps the
Developing a product in a piecemeal fashion largest focus area in the next couple of years will
predates computing by several decades. The be in project management. Project managers will
concept of creating incremental releases to need to not only drive the implementation of agile
products initially grew from a desire to improve practices, but also need to understand their impact
quality (Larman et al., 2003). Recent evidence on their project(s) (Coram & Bohner, 2005). In all

203
Agile Software Development Quality Assurance

of these cases, we believe risk will most likely be Coram, M., & Bohner, S. (2005, April 3-8). The
the deciding factor for when agile methods are impact of agile methods on software project
used and when they are not. management. Paper presented at the 12th IEEE
International Conference and Workshops on
the Engineering of Computer-Based Systems
conclusIon (ECBS’05), Greenbelt, Maryland, USA.
Larman, C., & Basili, V. R. (2003). Iterative and
This chapter discussed how one team was able to
incremental development: A brief history. Com-
successfully drive software development quality
puter, 36(6), 47-56.
improvements while reducing overall cycle time
through the introduction of several individual Lee, K., & Boehm, B. (2005, May 17). Value-based
agile development techniques. Through piecemeal quality processes and results. Paper presented at
change to their existing development processes, the 3rd Workshop on Software Quality (3-WoSQ),
they were able to make significant improvements St. Louis, Missouri.
over time. This common-sense approach to soft-
Madsen, K. (2005, October 16-20). Agility vs.
ware development showed that the incorporation
stability at a successful start-up: Steps to prog-
of agile techniques does not have to entail addi-
ress amidst chaos and change. Paper presented
tional risks for projects that have high availability,
at the 20th Annual ACM SIGPLAN Conference
performance, and quality requirements.
on Object-Oriented Programming, Systems,
Languages, and Applications (OOPSLA ’05),
San Diego, CA,.
reFerences
Manns, M. L., & Rising, L. (2005). Fearless
Ambler, S. W. (2006). The agile edge: Unified and change: Patterns for introducing new ideas.
agile. Software Development Retrieved January Boston: Addison-Wesley.
8, 2006, from http://www.sdmagazine.com/docu-
McConnell, S. (1996). Rapid development: Taming
ments/s=9947/sdm0601g/0601g.html
wild software schedules. Redmond, Washington:
Beck, K., & Andres, C. (2005). Extreme pro- Microsoft Press.
gramming explained: Embrace change (2nd ed.).
Naur, P., & Randell, B. (1968, October 7-11).
Boston: Addison-Wesley.
Software engineering: Report on a Conference
Boehm, B., & Turner, R. (2004). Balancing agility Sponsored by the NATO Science Committee. Paper
and discipline: A guide for the perplexed. Boston: presented at the 1st NATO Software Engineering
Addison-Wesley. Conference, Garmisch, Germany.
Boehm, B. W. (1988). A spiral model of software Paulk, M. C. (2001). Extreme programming
development and enhancement. Computer, 21(5), from a CMM perspective. IEEE Software, 18(6),
61-72. 19-26.
Brooks, F. P. (1995). The mythical man-month (An- Paulk, M. C., Curtis, B., Chrissis, M. B., & Weber,
niversary Edition). Boston: Addison-Wesley. C. V. (1993). Capability maturity model for soft-
ware, Version 1.1. Software Engineering Institute:
Chrissis, M. B., Konrad, M., & Shrum, S. (2003).
Capability Maturity Modeling, 82.
CMMI: Guidelines for process integration and
product improvement. Boston: Addison-Wesley.

204
Agile Software Development Quality Assurance

Svensson, H., & Host, M. (2005, March 21-23).


Introducing an agile process in a software main-
tenance and evolution organization. Paper pre-
sented at the 9th European Conference on Software
Maintenance and Reengineering (CSMR’05),
Manchester, UK.
Yourdon, E. (2004). Death march (2nd ed.). Upper
Saddle River, NJ: Prentice Hall.
Zhiying, Z. (2003). CMM in uncertain envi-
ronments. Communications of the ACM, 46(8),
115-119.

205
206

Chapter XI
Test-Driven Development:
An Agile Practice to Ensure Quality
is Built from the Beginning

Scott Mark
Medtronic, Inc.

Abstract

This chapter describes the practice of test-driven development (TDD) and its impact on the overall
culture of quality in an organization based on the author’s experience introducing TDD into four ex-
isting development projects in an industrial setting. The basic concepts of TDD are explored from an
industry practitioner’s perspective before elaborating on the benefits and challenges of adopting TDD
within a development organization. The author observed that TDD was well-received by team members,
and believes that other teams will have this same experience if they are prepared to evaluate their own
experiences and address the challenges.

Introduction components are then used to drive the development


process and deliver components that, by defini-
The spirit of agile methods begins with the promise tion, satisfy the quality requirements as they are
that whatever software components are built will set out in the test cases. In its purest form, the
be of high quality. Agile methods move quality developer1 begins by writing a test case that fails
assurance upstream in the software development and then proceeds to implement the functionality
process, and the most relevant of these methods is that causes the test to succeed. When this practice
the principle of test-driven development (TDD). is followed carefully, the code that becomes the
The essence of TDD is that quality assurance final product is guaranteed to pass all currently
methods are not a sieve through which applica- identified test cases.
tion code is pushed at the end of a long, drawn The goal of this chapter is to explain the
out development process. Rather, the development changes to the traditional development process
cycle begins with capturing test cases as execut- in order to drive it with quality assurance, and
able system components themselves. These testing illustrate the overall impacts on software quality,

Copyright © 2007, Idea Group Inc., distributing in print or electronic forms without written permission of IGI is prohibited.
Test-Driven Development

process velocity, and developer productivity. The Tests are “Easily” Executed by the
perspectives on TDD presented in this chapter Developer Working on the
are based on the author’s experience introducing Implementation
these techniques on four Web application develop-
ment projects in a large enterprise setting. These This is of course a very subjective metric, but is a
projects will be described and the teams’ good key requirement nonetheless. The core of the TDD
and bad experiences with TDD will be explored. practice is that running tests is part of the mo-
The intention of this chapter is to share the ex- ment-to-moment development process. For TDD
periences, both good and bad, of these teams purposes, tests should be kept at a practical level of
while using TDD so that other practitioners can granularity with a consideration toward execution
anticipate or evaluate similar effects in their own time. Low execution times ensure that these tests
environments. can in practice be run frequently and continuously
during the work of implementation.

What is test-driven Tests are at the Unit- or


development (TDD)? Component-Level

Test-driven development is the practice of imple- There are various levels of testing within the larger
menting executable tests before implementing landscape of software quality assurance such as
functional components, and using the activity of unit, functional, system, integration, and user
testing to propel the implementation of functional acceptance testing. It is certainly not the goal of
components. For purposes of this discussion, the TDD to address all of these aspects of testing. TDD
essential components of the test-driven develop- promises to increase the amount of quality that is
ment practice are the following: built-in from the start, and encourages developers
to think upfront about testability. This is achieved
• Tests are authored by the developer before by testing the aspects immediately in front of the
implementation. developer at the unit- and component-levels of
• Tests are “easily” executed by the developer implementation. A unit test is a test that focuses
working on the implementation. on a given implementation construct (a .java file
• Tests are at the unit- or component-level. in Java, a .c file in C/C++, etc.). A component test
is a test that focuses on an atomic system com-
Tests are Authored by the Developer ponent, such as an interface in Java, that might
before Implementation front a number of implementation constructs in
the implementation.
TDD is a quality improvement process that ul- As we proceed to higher levels of granularity
timately is a form of organizational change. A throughout the system, test-driven development
key aspect of this is the transformation of every starts to dissolve into more integration-oriented
developer into a tester. Organizations that have testing methods. As more and more layers are
separate roles for authoring tests have not com- integrated into the working, testable system, the
pleted this transformation—testing will remain a setup and cycle times of execution increases to
back-and-forth process of transfer. So a require- the point where some of the benefits of test-driven
ment of TDD is that the developer who will be development diminish. Some of these tests can
implementing functionality begins by writing the be automated and some can be written before
test to verify the implementation. the implementation. Automated tests written

207
Test-Driven Development

at the integration level often drive refactoring basic assertions that indicate expected behavior
more than they drive initial development. So from the implementation. The most important
integration-level tests are not the primary focus code written for TDD will be written in the test
of TDD practices. A key motivation of TDD is to cases, and this code will drive the interface of
ensure that unit-level defects do not seep into the the implementation.
integration phase where they consume valuable
time and resources. Test Fixtures

Test fixtures provide support services for tests in


the components of the way of setting up proper pre- and post-condi-
test-driven development tions. By far the most common use of test fixtures
is to prepare and dispose of necessary test data
This section will more thoroughly define the against which tests will be run. Fixtures can be
technical components or building blocks of TDD. responsible for creating test objects, establishing
There are four major components (see Figure 1) any required dependencies, or mocking.
to a TDD framework:
Test Suites
• Test cases.
• Test suites. A test suite is a collection of test cases that are
• Test fixtures. intended to be executed together as a unit. Test
• Test harnesses. cases might be organized into suites according
to functional groups, application tiers, or com-
Test Cases mon fixture needs. There is often a hierarchical
arrangement of test suites with suites containing
The test case is the primary building block for other suites and so on. Suites are used mainly
TDD. The test case is the initial code that the for convenience and to indicate which tests are
developer writes to exercise an interface and intended to be run as a group.
drive implementation. Test cases contain the

Figure 1. The components of test-driven development

208
Test-Driven Development

Test Harnesses Testers are frequently considered to be “super


users” of a system and in these cases, the overall
The test harness is the highest level component in quality of the system depends tenuously on their
the TDD framework. The harness is the founda- skills of discovery. Testers are often expected
tion that ties all of the other testing components to take requirements of varying quality and ex-
into an executable set. At a minimum, a harness trapolate them into scripted test scenarios. These
provides an execution environment in which tests scenarios are documented as a narrative and are
can be run and output captured. Harnesses might typically executed manually. In some cases, execu-
also include features to ease the process of TDD, tion of these cases can be automated but in tradi-
such as supporting services for more convenient tional practice, this is late-stage automation.
fixture building or formatted reporting of test ex- The end stages of traditional projects end up
ecution results. By far the most popular harnesses being heavy negotiation phases in which the de-
for TDD are the family of xUnit frameworks, such velopment team and sponsors pour over the set of
as JUnit, NUnit, and CPPUnit, which were based identified defects and unmet requirements. Such
on the original SUnit framework created by Kent lists are often extensive as they cover a broad
Beck for Smalltalk (Beck, 1999). range of defects across the range of functional-
ity implemented in the system. Furthermore, the
defects are not limited to integration- and deploy-
What Are Alternatives to ment-level defects (which are more understandable
Test-Driven Development? at that late integration phase), but instead include
many unit-level defects in base functionality.
Software testing has typically been treated as While these situations are certainly symptomatic
a topic to be addressed late in the development of other methodological concerns that many agile
cycle by many project methodologies. Often after practices address, TDD practices have signifi-
software components are considered “complete” cantly limited the extent of such discussions in
by software development teams, they are deliv- the author’s experience.
ered to a testing team, at which time an intensive Test-driven development often involves auto-
testing phase begins. In traditional “waterfall” mation, but test-driven development is more than
methodologies, the testing phase is literally a just the act of test automation. As we will see,
protracted phase that is ultimately considered a there are a number of testing automation practices
pre-deployment phase. This phase is essentially that are not, strictly speaking, test-driven prac-
the combination of all forms of testing (unit, func- tices—for example, using automated acceptance
tional, integration) in a single phase that occurs tools such as Fitnesse3 to write acceptance scripts
after the conclusion of most major development after implementation.
across the scope of an entire system. In more
iterative methodologies such as the Rational*®
Unified Process, a system is broken down into Background
smaller components for the purpose of construc-
tion and deployment (Krutchen, 2000). While this The perspectives on TDD presented in this chapter
is an effective risk-mitigation strategy, testing is are based on the author’s experience of applying
often still seen as a post-construction activity2 TDD to four software projects in an industrial
even though it occurs multiple times during a setting. These projects were implemented in the
given project’s lifecycle. corporate IT organization at a Fortune 250 medi-

209
Test-Driven Development

cal technology company. These projects were all report performance to upper management. This
browser-based Web applications. project consists of approximately 16,000 lines of
code and was developed by two developers and
The Projects an application architect.

Project A was an information portal targeted at The People


healthcare professionals who are customers of
the company. Users complete a self-registration The staff on all projects consisted of both em-
process, indicate their information preferences, ployees and contract developers with at least
and are required to login to view the site. The site four years of Java development experience. De-
then presents personalized navigation and content velopers had varying levels of experience with
to users based on the user’s professional specialties the specific development tools and frameworks
and geographic location. Content managers have used to build the applications, but were able to
additional access to post content to the site. This be productive with those technologies in a short
project consists of approximately 51,000 lines of time. However, only three of the developers had
code (LOC) and was developed by a team of six any prior experience writing automated program-
developers and an application architect. mer tests. The remaining developers had varying
Project B was an information portal targeted levels of informal exposure to unit testing, such
at internal field employees of the company. Users as reading articles in trade publications or books.
login to view the site and information is personal- No developers had any formal training in TDD
ized automatically based on job role information before or during these projects.
in other corporate systems. Content is personal-
ized to users based on job levels and geographic The Approach
location. Content managers have additional access
to post content to the site. This project consists of Developers used Eclipse, JUnit, and Ant in an in-
approximately 16,000 lines of code (LOC) and dividual development environment. Test coverage
was developed by a team of three developers and was focused on interfaces that were integration
an application architect. points among subsystems in the applications.
Project C was a tool to assist internal field em- Developers were expected to write their own test
ployees in generating pricing quotes for customers. classes and run them frequently through Eclipse
Users have role-based access to different customer during their regular development activity. As part
accounts and need to search available products to of the standard development environment, Ant
build a list of products for a quote. This system scripts were provided that run the entire suite of
uses remote messaging to interface with backend tests. The entire suite was run prior to deploy-
enterprise systems that provided price informa- ing builds to a testing environment, and in some
tion. This project consists of approximately 8,000 cases continuous integrations ran the test suite
lines of code and was developed by two developers on a more frequent and regular basis.
and an application architect.
Project D was a tool used by customer service
agents to track customer requests related to insur- LESSONS LEARNED
ance reimbursement. Agents interact with both AND BEST PRACTICES
customers and internal field employees when cre-
ating requests and are able to dynamically generate Overall, the development teams involved in the
reports to respond to answer status requests and aforementioned projects decided that TDD prac-

210
Test-Driven Development

tices were a beneficial addition to the projects. While this view is a bit extreme, it suggests
Developers generally felt that using TDD made a useful thought experiment for even the more
them feel more confident that their code met re- realistic TDD practitioner. A developer who is
quirements and would not require re-work. Teams properly “test-infected” will receive a functional
determined that the following lessons learned and requirement or enhancement request and will first
best practices contributed to those feelings. think about the test. Where in the test suite would
such a requirement best be verified? What are pre-
Tests Really do Need to be “Easily” and post-conditions for the functional scenario?
Executed What are boundary and exception conditions, and
what should fallback behavior be in those cases?
The notion of tests being subjectively “easy” to Beck comments that there are just two simple
execute was introduced earlier as a defining char- rules involved—writing failing automated tests
acteristic of TDD. But team members definitely before writing implementations and removing
felt that they were more inclined to execute tests duplication (Beck, 2003)4.
if they ran simply (automated test fixtures and It might not be possible or practical to first
test setup) and rapidly. The longer tests took to implement a test for every possible scenario of
run, the more frequently developers would lapse every identified requirement. But it is a sign of
into “test after” practices—just working on the healthy test-infection when a developer thinks
implementation and writing tests later. through the verification process before implemen-
tation, and implements tests for critical aspects
Smaller is Better of the implementation (most frequent, highest
risk, etc.).
Teams felt that writing “small” tests was more ef-
fective. Small in this sense meant that individual Base Test Coverage on Risk
test methods were very focused around testing a Assessment
small amount of functionality. Large test methods
tended to require large amounts of fixture setup The question of test coverage can be a bit contro-
and resetting and became more difficult to read. versial in the world of TDD. One might think that
Writing small test methods with descriptive names 100% test coverage is essential for true TDD. It’s
tended to be more self-documenting and easier possible that in a situation of doing brand-new,
to maintain over time. greenfield development with full management
support for TDD and quality that this is attainable.
The Only Implementable However, this is often not the case on development
Requirement is a Testable projects5. More often than not, TDD practices will
Requirement be introduced during the maintenance of existing
code, or there might not be full support in the
A self-respecting TDD purist would state that organization for the practice of TDD. The answer
for every functional requirement there should to the coverage question is that you should have
be a test, as a matter of principle. That is to say the proper amount of test coverage on a system,
if you are able to describe a functional business as well as that subjective term can be applied to
requirement that can possibly be implemented a given set of circumstances.
as working software, then you should also be Coverage can be measured objectively using
able to describe a software test to verify that the test coverage tools that become part of the overall
requirement was in fact implemented. testing harness. Coverage tools are responsible

211
Test-Driven Development

for reporting which lines of production code are Integrate Tests into a Continuous
executed during the execution of testing code. Integration Process
These tools might be used during the initial de-
velopment of testing code, but are more often used A perhaps less obvious gain when using test-driven
as part of integration activities to audit for proper development is that you will be encouraged to
test coverage. Summary coverage is reported in build your code more incrementally that you might
terms of the overall percentage of code that is otherwise do. Test-driven development follows a
executed during tests. Coverage tools also report simple rhythm of defining an interface, writing
specific lines of code that are not executed at all a test against the interface, and then writing the
during tests, so that additional coverage can be implementation until the test passes. This rhythm
added. Some coverage tools, such as Clover6 for lends itself very well to the notion of biting off
testing Java code, provide this detailed view in the small pieces of functionality at a time, and continu-
form of browsable HTML pages with highlight- ally expanding the implementation. Developers
ing to allow developers to more easily navigate do this with great confidence because their ever-
to untested code. growing test suite promises to alert them if any
Our teams felt that 100% coverage was not defects are introduced along the way.
practical. While the notion of 100% coverage is Test-driven development leads to a certain
appealing standing on its own, it is not always “food pellet” effect in this regard—developers
practical or possible to achieve this metric due often favor smaller increments because they are
to various concerns (schedule demands or orga- more quickly able to receive the feedback on
nizational support, for example). Our teams used whether they have introduced defects. This fact
informal processes of identifying key areas of makes test-driven development a very natural
risk, based on the following criteria to identify enabler for increased agility on projects.
where test coverage was most critical: As this behavior becomes more and more
common during the daily individual develop-
• Requirements were compliance-oriented. ment process, teams also are better positioned
• Functionality required interfaces with other to implement a continuous integration practice.
systems. Continuous integration is an important agile
• Implementation required contributions from development technique in which the process of
other teams. integrating is automated. In continuous integra-
• Functional components required more ex- tion, a scheduled and automated process pulls the
pensive integration testing iterations (due latest code from source control and then compiles,
to resource availability, time-consuming tests, packages, and deploys the code to an integra-
manual testing processes, etc.). tion environment. This process is run extremely
frequently—often multiple times during the work
Our teams identified requirements for testing day. The goal of continuous integration is to alert
during the high-level design process. While decid- the development team as soon as possible when
ing questions of overall design direction, the teams there are conflicting changes and allow the team
would also identify which functional areas were to to respond sooner than in a more traditional pro-
be the focus of TDD. This approach proved to be cess of integrating manually and less frequently.
a successful method of gaining the advantages of Some continuous integration frameworks, such
TDD in critical areas, while mitigating concerns as CruiseControl7, include additional features
around time spent in test development. such as email notification of build success or
failure, and Web-based reporting of test results

212
Test-Driven Development

that greatly enhance a team’s ability to respond These mock objects are used just for the purpose
to integration issues. of testing, and implement the minimum amount
Teams following TDD practices are much bet- of behavior that is required by objects or compo-
ter positioned for continuous integration because nents that are under test. There are almost always
they will have a rich set of automated tests ready extra objects created in test scenario as part of
to be run. Running a full suite of automated tests the fixture. But the key difference between those
is a valuable aspect of continuous integration, so objects and mock objects is that mock objects are
TDD teams will be far ahead of teams that are stand-ins or façades for a more complex system
writing tests later or not at all. Test-driven teams of objects. The other test objects included in the
will arguably also have a more “well-gardened” set fixture are typically valid object instances that
of tests that play well together, as the developers consist of invented test data, but are valid object
are in the habit of running tests continuously in instances nonetheless.
their own development environments. The use of mock objects is invaluable when
Continuous integration could be considered a there is critical testing to be performed around
form of test-driven packaging and deployment. objects with complex runtime dependencies. Some
The practice of writing tests first encourages production-quality frameworks, such as the Spring
developers to implement a design that is easily framework8, include mock objects that do most of
testable. Likewise, the practice of setting up a the heavy lifting so the developer can focus more
continuous integration environment encourages on writing the core tests. However mocking can
developers to implement a build and deployment also add significant overhead to test fixtures if
process that is easily automated. Many more teams the developer is solely responsible for creating
practice TDD than practice continuous integration the mock objects. In these cases, the developer
and there is far more literature on the practice of should consider the return on effort for creat-
TDD. But teams that practice TDD should consider ing a more elaborate fixture, or should consider
continuous integration the next major step down refactoring critical logic out of dependent objects
the path of improve code quality. to increase testability.

Use Mocking to Address Teams Feel More Confident Making


Components with Runtime Changes
Dependencies
Our teams felt much more confident making
A frequent issue in writing automated unit tests significant functional changes when TDD was
has to do with the issue of runtime dependencies. used. This feeling was especially evident when
Production code often has more elaborate depen- fixing defects discovered during the integration
dencies beyond the inputs to a given method, which process or when implement enhancements to
are typically parts of the test fixture. Examples are existing functionality. When developers could
dependencies on the availability of data sources, begin these tasks by executing a passing test suite
remote services, file system resources, and trans- and then writing new failing test (or modifying
ports (such as an HTTP environment). The answer existing tests as appropriate so that they failed),
for addressing these additional dependencies is they were much more confident that they were
the use of mocking. meeting the requirements they were given.
Mocking involves the use of objects that im-
personate more complex runtime components.

213
Test-Driven Development

Teams Feel More Confident about in literature (Beck, 1999), our teams certainly felt
the Design more confident in practice that refactoring was
much easier to address when code was written
TDD arguably encourages better design because using a TDD approach.
the interface developer must first think of the The code travels with its own suite for re-
client’s needs. The test is the first client of the certification, so changes can be more safely made
implementation and the developer is the first later. The existence of ready-to-run tests enables
customer. The test is also a form of software maintenance developers to more confidently ad-
documentation, which again increases overall dress enhancements and ensure system stability
quality. The test is a readable form of functional during later updates.
documentation that explicitly defines a functional
software component. While this form of docu- Loose Coupling and
mentation might not adequately address higher Component-Based Design
business concerns or concepts around the func- Enable Testability
tional requirements, it can explicitly demonstrate
business rules in action. Tests might even been As we have discussed previously, the practice
seen as a form of interactive documentation, as of TDD requires upfront thinking about design
they can continually be added to when exploring because the developer is writing a client before
boundary conditions or new requirements. In our the implementation. Before arriving at that
experience, these factors contributed to a higher point, some basic principles of good application
level of design satisfaction on teams. architecture and design can be applied in order
to ensure that the overall system is constructed
TDD as a Refactoring Enabler in a highly testable fashion.
Loose coupling of components is perhaps
As a follow-up to the previous point, teams con- the most important principle that applies. Well-
firmed that TDD enabled much more productive defined interfaces between subsystems greatly
refactoring. While this point has been discussed enhance the developer’s ability to start small and

Figure 2. Example of subsystems in an enterprise Web application

214
Test-Driven Development

build a well-tested component for integration • Is there a “culture of testing” on the team,
into a larger overall system. At the very least, so that test-driven development practices
development teams should agree on high-level will be consistently followed?
subsystems or tiers and discuss interface needs
between those components. Testers become a new type of subject-matter
Figure 2 illustrates a typical subsystem ar- expert (SME) for developers on the topic of writing
chitecture for a Web application with access to a tests. Testers at the very least can help developers
local database as well as remote services. identify key rules for testing and corner cases that
A component-based architecture such as this will drive refactoring. On larger teams or more
enables a given subsystem to more easily be critical systems, the testers might take an even
developed in isolation using TDD techniques. more active role, at least at the outset. Testers
Implementation considerations of other sub- might pair program with developers when writing
systems can be safely disregarded so that the interfaces and initial tests.
developer can focus on the core implementation
of the given subsystem. We will later see how Integrate Testing Best Practices into
dependency mocking can assist with crossover Coding Best Practices
areas and integration points.
Use of loosely coupled subsystems as a de- Writing tests involves writing additional code and
sign technique has additional long-term benefits test code should follow coding guidelines just as
for defect isolation during maintenance phases. the implementation code does. But for testing
Future developers will have a much easier time code, teams should additionally define standards
isolating defects to a given subsystem, and will test-specific concerns. The following items are
more likely be able to address defects by modify- examples of topics to cover when defining testing
ing the test suite and implementation for just a best practices:
given subsystem.
• Proper approaches for setting up test fixtures
New Roles for Architects and Testers programmatically.
During the Development Process • Process for setting up environments—such
as loading test data or frameworks for creat-
Test-driven development certainly empowers ing mock objects.
developers to become their own first testers. As • Methods for assembling test cases into test
important as this is, there are also impacts on suites.
the traditional roles of application architects and • Scripts and processes for executing suites.
functional testers in the TDD world.
Architects must be able to ensure that the
overall application design encourages testability. CHALLENGES IN TDD
Architects must consider issues such as the follow-
ing and determine their impacts on testability: While teams felt overall that TDD was an effec-
tive practice, it is not without its challenges. Many
• Are there runtime dependencies that must of these are perhaps the natural experiences of
be mocked for testing? teams that are new to TDD, but there were real
• Are subsystems and components properly considerations in our experience.
isolated for testing discrete functionality?

215
Test-Driven Development

Difficult to Get Started with TDD not designed with automated testing in mind9 it
will likely require some amount of refactoring to
Our experience was that many developers were become testable.
interested in TDD, but had a hard time getting The process of introducing automated tests
started writing their first test classes. Developers onto existing untested code should not be done
seemed confused about how to write assertions wholesale, but should rather be done gradually
around code that did not yet exist or weren’t quite in keeping with Agile principles of building to
sure where to begin writing tests within the context requirements and continuously delivering value
of a class design they had in mind. A mitigation (rather than embarking on extremely long term
strategy for this issue is to use mentoring or pair- re-engineering efforts). The introduction of testing
ing to help developers get their first tests written, should be considered part of the defect and en-
at least at a high level. A more experienced TDD hancement process. The required process change
developer can write initial rough tests, and coach is that all defects will be verified with failing tests
the newer TDD developer through the process of before being fixed, and passing tests will be writ-
expanding the tested scenarios. ten against affected areas before implementing
There are sometimes organizational factors at test-first enhancements.
work here. When there is a setting that encourages The developer must refactor the interface that
“just getting things done” or very rapid delivery, requires testing in order to make it testable. This
developers sometimes had a difficult time carv- usually involves breaking dependencies and sim-
ing out time to write their first tests. Even if they plifying the interface so that an elaborate fixture
have some tests written before implementation, is not required. A less desirable alternative is to
writing tests was sometimes dropped lower on implement mocking for the dependencies. This
the priority list in favor of showing progress on is less desirable because developer-implemented
functional code. If teams want to adopt TDD mocking is considered less valuable overall than
practices, our experience was that they needed refactoring the production code to improve code
to allow developers periods of lower productiv- quality. And improving code quality is the primary
ity during early stages of adoption to acclimate goal of TDD in the first place!
themselves to the TDD approach. Fowler (2004) described this process of gradual
improvement over time while progress to an over-
Unique Challenges with TDD and all vision of reengineering as the “StranglerAp-
Existing Code plication.” Fowler models his description after the
Strangler vine, which symbiotically grows on top
There is a tremendous volume of existing pro- of a tree, but eventually overcomes and kills the
duction code that has no existing automated unit tree. Likewise, introducing automated tests and
tests, and a significant portion of total developer TDD practices onto existing code should be seen
time in an organization is spent maintaining this as a Strangler vine that will eventually kill off the
existing code. While it might not be as easy to last bits of untestable code from a system.
introduce TDD practices on such code, it is not
impossible. Our teams found that the quality of Coverage is a Recurring
the overall design was the largest determining fac- Conversation
tor for how challenging it will to introduce TDD.
Obviously, better designs with more isolation and Our teams felt that 100% coverage was not a
loose coupling will lend themselves more easily to practical goal in our environment, so instead
automated testing. But in any event, if code was pursued partial coverage based on informal risk

216
Test-Driven Development

assessment. A consequence of this direction Automation Alone does not Make for
was that appropriate coverage was an ongoing Test-Driven Development
conversation. Although the team valued the
agile nature of determining test coverage from a It is worth emphasizing that there are many forms
business value standpoint, conversations on the of automated testing, but automation alone does
topic were by definition very subjective rather not make these test-driven development practices.
than objective. Teams pursuing deliberate partial The following are some typical automated test-
coverage should be prepared with strategies for ing practices, and while they certain contribute
bringing such conversations to closure so they to overall system quality, they do not strictly fall
don’t consume valuable development time. under the umbrella of test-driven development.

But are Tests Just More Code to User Interface Integration Testing
Write? And isn’t this Someone
Else’s Job? Full integration tests are sometimes run at the
user interface level. Scripting is used to simu-
For developers that are new to unit testing and late user actions in the actual user interface, as
test-driven development, writing test cases in a means of full regression testing of all involved
code might just appear to be additional work. It system components. But in this case the system
certainly looks like additional work—its extra must be functionally complete for the tests to be
code that they didn’t have to write before! Writ- executed, so this practice is certainly not driving
ing tests is an investment in the future. Some development.
developers will immediately see the value of
TDD; others will need to stick with it for awhile Load or Stress Testing
before realizing the value. Reluctant developers
will gradually come around as they see tests in Load or stress testing is the practice of simulat-
other areas of an application fail unexpectedly ing heavy usage in a system. This is sometimes
after making changes. The test suite will start to done to verify a non-functional requirement for
be less of a burden and more of a safety net. system usage, such as number of concurrent us-
Sometimes there is resistance to TDD not ers or transaction throughput. In other cases, this
because it implies additional tasks but because is a form of resiliency testing to determine the
it seems to imply additional responsibility. Tra- usage level at which some system components
ditional role delineations might have developers will fail or malfunction. This method of testing
thinking that they are responsible for design and is almost exclusively done through automation
implementation and someone else is responsible and scripting. But here again the system must be
for finding defects. The answer here lies in the functionally complete for the tests to be executed,
fact that the developer’s responsibility is to imple- so this practice is not driving development.
ment the requirements, and TDD should be seen
as an advantageous method for ensuring those User Acceptance Testing
requirements are met.
User acceptance tests are increasingly being
executed through automation using tools such

217
Test-Driven Development

as Fitnesse. These tools allow users to specify might be of value to readers from other perspec-
the fixtures around tests, and then execute the tives such as maintaining staff morale and com-
tests themselves. There are ultimately coded test mitment to quality.
cases that execute behind the scenes, using the Overall, these findings and experiences make
provided fixtures. But this type of testing is not TDD a harder prospect to “sell up” in a large
considered TDD for the obvious reasons that it organization. Without more conclusive objective
is automated, is not executed directly by the de- data, teams wanting to introduce TDD practices
veloper, and is executed after the implementation into their organizations need to base their cases
rather than before. on less tangible benefits, or do their own objec-
tive evaluations in their own environments to
Objective Productivity and Quality determine if TDD is well suited.
Improvements are Debatable
what’s next for
Several studies (Erdogmus, Morisio, & Torchiano, test-driven development?:
2005; George & Williams, 2003; Geras & Miller, Future trends
2004; Maximilien & Williams, 2003, Reifer, 2002)
have explored the effects of using TDD vs. “test The practice of TDD is well defined in current
last” or “no test” development and assessed the literature and it is gradually becoming a standard
impacts on developer productivity and product behavior in the development process, especially
quality. Many studies did indicate a positive im- for teams that embrace extreme programming
pact on product quality (Erdogmus et al., 2005; (XP) or agile techniques.
George et al., 2003; Geras et al., 2004; Maximilien Integrations and plug-ins for many popular
et al., 2003), in one case even asserting that de- IDEs provide useful tools for test generation and
fects dropped by 50% (Maximilien et al., 2003), execution. There are also many useful reporting
but researchers often had small sample sizes that tools to help teams digest summary test execution
they considered to be threats to validity. Changes results when running a large test suite. However
in productivity were reported to be either neutral many of these tools currently help developers
(Erdogmus et al., 2005) or negative (Erdogmus generate skeleton test suites that still require code
et al., 2005; George et al., 2003; Maximilien et to become useful tests. Improvements to these
al., 2003). The author does not have quantitative tools might come in the form of integration with
data around productivity on the four projects code analysis tools that will suggest assertions to
in question, so cannot comment objectively on put inside the tests themselves. The ruby on rails
productivity. While researchers have various development framework automatically generates
explanations for these findings, there is not defini- stub test classes for declared implementation
tive, objective evidence to say that TDD makes classes independent of an IDE integration—this is
developers or teams more productive. considered a core service of the framework10. This
Interestingly enough, a survey (Reifer, 2002) concept of integrating tests and implementation
indicated an increase in productivity when us- will likely become more common in development
ing TDD; the survey was not coupled with any frameworks as the practice of TDD increases.
objective assessment. This fits with the authors Core language enhancements will certainly
experience—all developers using TDD practices influence how TDD is practiced, with features such
on these projects shared that they felt more confi- as assertions, annotations, and other declarative
dent in their designs and code, and that they felt programming11 techniques playing a major role.
more productive. These less measurable benefits Many current TDD practitioners believe that tests

218
Test-Driven Development

should be kept as focused as possible, and that tests References


with elaborate fixtures should really be broken
apart into smaller tests. This will probably not Beck, K. (1998). Kent Beck’s guide to better
be the case as more and more languages include smalltalk. Cambridge, UK: Cambridge Univer-
the above features. These features can be used sity Press.
to perform equivalent tests on production code
Beck, K. (2002). Test-driven development: By
during execution, and therefore will encourage
example. Boston: Addison Wesley.
developers to skip writing tests at a very fine-
grained level and instead focus on writing higher Erdogmus, H., Morisio, M., & Torchiano, M.
level integration tests. (2005). On the effectiveness of the test-first ap-
proach to programming. IEEE Transactions on
Software Engineering, 31(3), 226-237.
Conclusion
Fowler, M. (2004). StranglerApplication blog
entry on martinfowler.com. Retrieved January
There are many ways that TDD can take root in an
30, 2006, from http://www.martinfowler.com/
organization, team, or individual. At the organiza-
bliki/StranglerApplication.html
tion level, it can be the top-down promotion of the
idea that quality is everyone’s responsibility, not George, B., & Williams, L. (2003). A structured
just the designated Quality Assurance team. At experiment of test-driven development. Informa-
the team level, it can be a means of saving cost tion and Software Technology, 46, 337-342.
and time in the development cycle by ensuring
that the expensive cycles of human-performed Geras, A., Smith, M., & Miller, J. (2004). A
integration tests are used wisely for performing prototype empirical evaluation of test driven
true integration tests rather than discovering development. Paper presented at 10th International
defects that should be caught earlier. At the indi- Symposium on Software Metrics (METRICS
vidual level, it can be the realization that writing ’04), Chicago.
tests first can prevent tedious re-coding later and Krutchen, P. (2000). The rational unified pro-
can be far easier than breakpoint debugging for cess: An introduction. Boston: Addison-Wesley
ensuring that code meets expectations. Professional.
There are many benefits to adopting TDD,
but it is not without challenges. Learning new Maximilien, E. M., & Williams, L. (2003). As-
behaviors, making additional decisions around sessing test-driven development at IBM. Presented
coding standards, and deciding on test coverage at the 25th International Conference on Software
are just a few challenges teams will confront when Engineering, Portland, OR.
adopting TDD. Awareness of these challenges Rainsberger, J. B., & Stirling, S. (2005). JUnit
will help teams address them upfront, and might recipes. Greenwich, CT: Manning Publications,
also serve as an example for teams to continually Co.
evaluate what challenges they face in their own
environment. TDD is not a panacea for all test- Reifer, D. (2002). How good are agile methods?
ing concerns in developing software, but it can IEEE Software, 16-18, July/August.
certainly contribute to a team’s commitment to
improving the quality of their software.

219
Test-Driven Development

Additional RESOURCES 3
See http://fitnesse.org/ for additional infor-
mation.
JUnit: http://www.junit.org 4
Beck eloquently and concisely states that
CPPUnit: http://cppunit.sourceforge.net/ TDD “encourages simple designs and
PyUnit: http://pyunit.sourceforge.net/ test suites that inspire confidence” (Beck,
NUnit: http://www.nunit.org/ 2003).
DBUnit: http://dbunit.sourceforge.net/ 5
The authors of JUnit Recipes (Rainsberger,
JWebUnit: http://jwebunit.sourceforge.net/ Stirling, 2005) note that they almost always
HttpUnit: http://httpunit.sourceforge.net/ need to deal with legacy code. The value of
HtmlUnit: http://htmlunit.sourceforge.net/ applying TDD to existing code should not
CruiseControl: be underestimated.
http://cruisecontrol.sourceforge.net/ 6
See http://www.cenqua.com/clover/ for ad-
FitNesse: http://fitnesse.org ditional information.
Clover: http://www.cenqua.com/clover/ 7
See http://cruisecontrol.sourceforge.net/ for
additional information.
8
Spring provides very useful mocks for HTTP,
ENDNOTES JNDI, and JDBC components. See http://
www.springframework.org for additional
*
Rational® Unified Process is a registered trade- information.
mark of IBM Corporation.
9
Automated testing is a non-functional re-
1
For the sake of simplicity, all comments will quirement, and in this case the developer
refer to a single developer running tests. In is really enhancing the code to meet new
practice, TDD is a very common practice requirements.
combined with pair programming in the 10
See API documentation at http://www.
extreme programming (XP) methodology. rubyonrails.org/ for additional informa-
Pairing is another valuable but sometimes tion. Test stub generation is built into the
controversial topic altogether. “scripts/generate model” command.
2
RUP purists will note here that the RUP 11
Declarative programming is the practice of
is considered a use-case driven process, stating end conditions as fact declarations,
and use cases are seen as predecessors to and allowing an underlying framework to
test cases. From a process standpoint, the take care of procedural concerns to arrive at
requirements are perhaps more readily test- the declared state. Procedural programming,
able or lend themselves to testability, but the on the other hand, is defined by algorithms
process itself is not test-driven in the sense that are responsible for processing and state
that it does not specify the construction of transition.
testing components before functional com-
ponents. TDD can nonetheless be applied
to a process based on RUP.

220
221

Chapter XII
Quality Improvements from
using Agile Development
Methods:
Lessons Learned
Beatrice Miao Hwong Arnold Rudorfer
SIEMENS, USA SIEMENS, USA

Gilberto Matos Xiping Song


SIEMENS, USA SIEMENS, USA

Monica McKenna Grace Yuan Tai


SIEMENS, USA SIEMENS, USA

Christopher Nelson Rajanikanth Tanikella


SIEMENS, USA SIEMENS, USA

Gergana Nikolova Bradley Wehrwein


SIEMENS, USA SIEMENS, USA

AbstrAct

In the past few years, Siemens has gained considerable experience using agile processes with several
projects of varying size, duration, and complexity. We have observed an emerging pattern of quality as-
surance goals and practices across these experiences. We will provide background information on the
various projects upon which our experiences are based, as well as on the agile processes used for them.
Following the brief discussion of goals and practices, this chapter will present the lessons learned from
the successes and failures in practicing quality assurance in agile projects. We aim at informing fellow
agile developers and researchers about our methods for achieving quality goals, as well as providing
an understanding of the current state of quality assurance in agile practices.

Copyright © 2007, Idea Group Inc., distributing in print or electronic forms without written permission of IGI is prohibited.
Quality Improvements from using Agile Development Methods: Lessons Learned

IntroductIon discussion will lead up to the section on lessons


that we have learned so far and then conclusions
Since the declaration of the agile manifesto (Beck for improving QA in future agile projects.
et al., 2001) in February 2001, agile software de-
velopment methods have enjoyed a proliferation
leading to the spawning of variants and a prosely- bAckground
tizing of agile methods as silver bullets (Brooks,
1987). Many Siemens organizations are turning Within this section, we introduce two Siemens
to agile methods in order to shorten product de- in-house agile processes, along with seven projects
velopment timelines. Siemens Corporate Research in which they were employed. The first process,
(SCR), the R&D center for Siemens in the U.S., named S-RaP (an acronym for Siemens Rapid
has even formed its own agile development group. Prototyping), is a UI (user interface)-centered
This chapter will discuss project experiences that workflow-oriented approach that targets primar-
this SCR group has been involved in to show how ily the exploration of complex business require-
quality is approached in agile development. ments. The second process, entitled UPXS, is a
The background section that follows will combination of traditional and agile practices
provide an overview of seven projects in which in- (Unified Process (Jacobson, Booch, & Rumbaugh,
house agile processes were used. Next, there will 1999), eXtreme Programming (Beck, 1999), and
be a discussion of common quality assurance (QA) Scrum (Schwaber & Beedle, 2001)) that aims to
goals and practices amongst these projects. This

Figure 1. S-RaP process model (Nelson & Kim, 2004) (image by Kathleen Datta)

222
Quality Improvements from using Agile Development Methods: Lessons Learned

support full-blown product development (even S-RaP development is concentrated around


product-lines). two key artifacts:

Storyboard
sIEMEns AgILE ProcEssEs
The features planned for development are or-
s-raP ganized into workflows. These workflows are
pictured and described in the context of stories
The S-RaP (Gunaratne, Hwong, Nelson, & Rudo- within the Storyboard. An example of one such
rfer, 2004; Hwong, Laurance, Rudorfer, & Song, Storyboard appears as Figure 2.
2004; Nelson & Kim, 2004; Song, Matos, Hwong, The Storyboard is the requirements and test-
Rudorfer, & Nelson, 2004; Song, Matos, Hwong, ing specification for the developers and a means
Rudorfer, & Nelson, 2005; Tai, 2005) process to establish and communicate a common product
evolved to provide rapid prototyping solutions vision among all stakeholders. It is evolved itera-
for Siemens customers. An S-RaP project starts tively, integrating customers and domain experts
with the identification and prioritization of a set to work together with the development team to-
of business features by the customer and proceeds ward the identification of new, and clarification
according to the “time-boxing” technique (Mc- of existing, requirements. Due to the limitation
Connell, 1996). The features with higher priority of static content, the Storyboard alone might not
are developed first and then the remaining features be capable of clarifying the full semantics of the
are addressed as time permits. An illustration of user interface and the workflow interactions.
the iteration, concurrency, and coupling of the This problem is solved by the availability of an
S-RaP process is presented in Figure 1. interactive prototype early on.

Figure 2. Sample screenshot of Storyboard (Song et al., 2005)

223
Quality Improvements from using Agile Development Methods: Lessons Learned

Prototype in S-RaP, UPXS prescribes the creation and use


of more traditional artifacts, though they are cre-
During development, the software prototype ated iteratively and evolve throughout the project.
provides the customer with a working representa- These artifacts include use cases, requirements
tion of the final deliverable at an early stage. This documents, and software architecture documents.
gives the customer a hands-on testing experience Project management is performed using project
with what has been developed, which helps to and iteration backlog documents to maintain a
validate existing ideas and oftentimes generates prioritized record of remaining tasks. and burn-
new ones. The developers start the prototyping down charts are used to track sprint progress.
and testing activities as soon as some workflow Daily Scrum meetings allow synchronization of
features become stable. They select the develop- team members and the escalation of any blocking
ment tasks autonomously and provide the team points for the Scrum team. Similarly, a daily Scrum
leads with coarse time-effort estimation. of Scrums meeting facilitates communication
Note that both activities—Storyboarding and between Scrum teams and gives management an
prototyping—run quasi-concurrently. While the ongoing awareness of project status. Addition-
UI designers and requirements engineers model ally, the Scrum of Scrum aids in coordinating
the UI and its functionality in the Storyboard, the distributed teams.
developers implement the related features in the An important motivation behind UPXS is to
prototype. The iterative, quasi-concurrent evolu- provide greater predictability and risk manage-
tion of these two artifacts allows dynamic con- ment to project leaders. For this reason, UPXS
sideration and integration of the customer needs takes daily and weekly progress as an input for
(requirements) in the process and supports the feature selection and prioritization for coming
delivery of a product which meets these needs. iterations. Although the manner is not as hands-
on as in S-RaP, product walkthroughs at the
uPXs end of each iteration keep the product owner
well informed of the current state and quality
UPXS (Pichler, 2006; Smith & Pichler, 2005) is of the evolving software deliverables. With the
an agile development methodology that combines four major phases into which iterations are
principles from the unified software development grouped—Inception, Elaboration, Construction,
process (UP), XP, and Scrum. Developed for a and Transition—there are also milestone check-
high-profile Siemens project, the process was points for project management to evaluate the
designed to address the needs of a large distrib- overall progress of the project.
uted agile project. With a foundation of Scrum’s
team structure and activities, UPXS adds the Agile Projects
project timeline model and phases of UP, along
with iteration and task planning and development Over the past few years, the processes previously
practices from XP. described were employed in a number of different
Similar to S-RaP, UPXS is executed in time- projects. The experiences mentioned in later sec-
boxed iterations of 10 to 20 working days. Itera- tions are taken from the seven projects we present
tions begin with the selection and prioritization in this section. Table 1 outlines the specific agile
of a subset of features to implement from the characteristics of these projects and is followed
product backlog. The initial backlog is created by by more in-depth descriptions.
the product owner to establish and prioritize the
full set of features in the final deliverable. Unlike

224
Quality Improvements from using Agile Development Methods: Lessons Learned

Table 1. Project characteristics

Project A1: Medical Marketing underlying database layer to enable dynamic


Prototype configuration of workflows and application data.
Thus, the customer desired a more maintainable
Project A1 was an S-RaP project focused on and adaptable solution that was still reliable and
building upon an inherited prototype to produce also had a high fidelity UI.
a marketing demo of new advanced features and a
modernized look and feel for an emerging software Project b: Medical requirements
product. The application ran in a Web browser and Elicitation Prototype
used simple HTML and JavaScript technologies.
Deadlines were fixed but features were often Project B is a smaller S-RaP project that produced
negotiated during the actual development. Since a prototype starting from a vague statement of
the product was intended for marketing purposes, customer needs. There was no existing software
the customer needed a reliable solution with a upon which to base this prototype. Thus, it was
high fidelity UI. critical to the project’s success for requirements
to be elicited and refined efficiently. Develop-
Project A2: Medical Marketing ers participated in defining the requirements by
Prototype providing suggestions on how to model the inter-
action features that were not yet fully specified,
When the customer in Project A1 desired an which contributed to their practical viability. The
advanced set of features that could not be easily customer’s main desire was to elicit, specify, and
done with its existing architecture, Project A2 verify requirements for features of a new product.
was born. Project A2 was also an S-RaP project, The development of a high-fidelity UI prototype
but unlike its parent, A2 produced a prototype delivered not only the clarified requirements but
that consisted of a 3-tier architecture with an also a demonstration tool that could be used for
HTML-based UI, a server component, and an collecting further feedback from prospective
underlying database layer. The customer had clients.
decided to incorporate more workflows and an

225
Quality Improvements from using Agile Development Methods: Lessons Learned

Project c: Medical Product D. The main goal of this project is to produce a


high quality UI that integrates functionality from
Project C is another S-RaP project that produced the legacy applications in a performance-enhanc-
a small 3-tier product. Although S-RaP was ing and highly intuitive way. At the same time,
originally developed for prototyping purposes, this product serves as a source of requirements
this project showed that the prototyping process elicitation and refinement for Project D.
could also support the development of a finished
commercial product. Project C lasted 1.5 years Project F: building technologies
and began as a prototype used to explore UI, requirements Elicitation Prototype
ease-of-use, and performance issues, after which
development began on a second prototype that Project F is the smallest S-RaP project yet, which
evolved into the final deliverable. The practice aimed to elicit, refine, and mature the requirements
of S-RaP principles helped us collect useful in- for a next generation product. This prototype cli-
formation that influenced the requirements and ent-server Web application was intended to serve
design of the final solution. In terms of quality as a form of requirements specification for the
goals, the focus was initially on high security, development of a new product that would integrate
so as not to compromise personal data, as well functionality from and replace several legacy
as a highly attractive and easy-to-use UI. Once applications. Since the functionality stemmed
these goals were met, the focus shifted towards from existing applications, the focus was more
performance. on developing an innovative, high-fidelity UI that
would still be intuitive and useful to customers
Project d: communications Platform of the existing applications.

Project D is a UPXS project that began with a


mostly centralized co-located team and has ex- QuALIty AssurAncE:
panded into a worldwide-distributed project to goALs And PrActIcEs
develop a groundbreaking platform upon which
future communications applications will run. In “QA (for agile methods) is looking at the same
true agile manner, this n-tier service-oriented deliverables (as with plan-driven methods). But
framework continues to be developed in parallel the process used to create the deliverables does
with Project E, supporting its ongoing needs. affect how QA works” (McBreen, 2002). Our
With a final deliverable that has no UI, this proj- experiences have shown us that the cycle of cus-
ect had quality goals focused on achieving high tomer involvement—constant re-estimation, and
reliability, portability, maintainability, security, constant reprioritization of scope and features—is
and performance. an inherent mechanism of agile methods that leads
to high software quality.
Project E: communications Product
common Quality goals and
Project E is a UPXS project with a large number Practices
of distributed teams working on a product that
will replace several legacy applications. The Web- Although each of our projects focused on their
based application interfaces with databases and own set of quality goals, there were several com-
communication hardware, and runs on the frame- mon goals that were important to all of them.
work that is simultaneously evolving in Project The following outlines these goals and the QA

226
Quality Improvements from using Agile Development Methods: Lessons Learned

practices that we applied to achieve them in one customer’s requirements. These needs should be
or more of our projects. captured in the requirements; however, a situation
of this nature can arise when there is a mismatch,
Goal 1: The final deliverable should exhibit a miscommunication, or omission of key project
high degree of correctness of implementation. requirements.
By ensuring that the customer is involved
Incorporating testing practices as soon as in every aspect of the project, from planning of
possible and on multiple levels (unit, integration, requested features and definition of requirements
and system) was a technique we used to ensure to continued verification of software deliverables,
correctness of implementation. For example, in misconceptions are reduced, and the result is a
our UPXS projects, developers wrote unit tests, product more in line with the expressed customer
which were continuously run as part of the build needs.
process. Simultaneously, a test team developed
and ran integration and system tests. Goal 3: The final deliverable is easy-to-under-
A similar measure of correctness in our S- stand, easy-to-learn, and easy-to-use.
RaP projects was achieved by acceptance testing,
which directly involved the customer. Unlike Since the customer is the key stakeholder who
traditional acceptance testing that starts once the decides if the final deliverable is attractive, easy-
final product is delivered, acceptance testing in to-understand, easy-to-learn, and easy-to-use, our
S-RaP was a constant and continuous process. technique for achieving this goal focuses on early
With the end of each iteration, the customer could and frequent customer involvement. From very
execute acceptance tests on the part of the system early stages, we involve the customer in hands-on
that was delivered. walkthroughs of the working software. The early
Collective ownership was another technique feedback from this method drives development
used to help ensure correctness of implementation toward achieving this goal right from the outset.
by encouraging developers to look at and improve In our S-RaP projects, the Storyboard drove the
each other’s code. This form of peer review, like customer feedback cycle.
the XP practice of pair programming, increases
knowledge sharing amongst developers, and can Goal 4: At any stage of development, code is easily
expose deficiencies in the implementation. In our analyzable, modifiable, and extensible.
UPXS projects, this resulted in explicit commu-
nication of improved or best practices for specific Throughout the development of the software
development tasks on several occasions. deliverable, it is necessary to accommodate con-
stantly changing requirements without requiring
Goal 2: The final deliverable is well suited to the significant rework, as well as embrace require-
expressed needs of the customer. ments for new features. Several practices we have
successfully used to maintain code simplicity
One of the key practices we have used to include keeping designs simple and refactoring,
achieve this goal is to incorporate the customer as discussed in Lesson 9, which can be found in
in planning and verification activities throughout the Lessons Learned section.
the project. Without beginning-to-end involve- Additionally, since later modifications to
ment of the customer in a project, it is possible software are often necessary, we practiced test-
that the resulting software is unsuitable for driven development to ensure that these changes
the customer’s needs despite meeting all the are smoothly integrated. Unit tests are particularly

227
Quality Improvements from using Agile Development Methods: Lessons Learned

useful for ensuring early and continuous regres- a significant aid to requirements gathering and
sion testing. The availability of a large number of forming an understanding and consensus between
tests of sufficient breadth and depth of functional- team members charged with different roles and/or
ity, in combination with high code coverage, is a bringing different skills and perspectives to the
significant contributor to achieving modifiability, table (e.g., domain knowledge vs. UI and interac-
because it provides developers with the confidence tion design vs. implementation skill.
to make changes knowing that they have a suite In our S-RaP projects, we used Microsoft Of-
of unit tests as a safety net. fice PowerPoint as a tool to present the sequence
that illustrated a feature of interest, earlier intro-
duced as the Storyboard. All stakeholders tied
LEssons LEArnEd to a Storyboard could add screen wireframes, or
screenshots from the evolving product or related
From the seven different project experiences that applications, and then use the presentation edit-
this chapter draws upon, each with a different set ing facilities of PowerPoint to annotate the image
of goals, we learned many lessons about the ap- with the desired product functionality. Similarly,
plication of our agile methodologies and practices. the notes section of the PowerPoint presentation
This section generalizes these lessons and presents was used for the textual description of the specific
them in their order of significance. interactions and data issues related to each slide’s
illustration. Though not without its shortcom-
Lesson 1: Use “living” documents whose lives ings, we found the Storyboard to be effective in
are determined by the project’s needs. providing information that is useful to software
developers, while preserving the immediate in-
Our experience generally confirms the vi- tuitive nature of a graphically aided interaction
ability of development with a reduced emphasis sequence.
on producing detailed documentation, which is Documents that succinctly capture the most
one of the values of the agile manifesto (Beck et relevant requirement details from stakeholders,
al., 2001). In both the prototyping and product- like the Storyboard, are very useful from the
oriented projects, we saw that the most important development team standpoint. When formal re-
forms of documentation were the “living” docu- quirements engineering (RE) processes are used,
ments, which informally captured multiple views the result can be very detailed, inter-correlated
of a specific problem and addressed different documents that still fail to present the global view
stakeholders’ concerns. Such living documents that connects the requirements to their purpose.
were available to all team members for editing, From our project experiences, it has made a big
thereby constituting a collaboration and com- difference when the development team pushes for
munication medium. Most of the targeted docu- the use of consolidated, interactive communica-
ments that dealt with a specific architectural or tion formats that embody specific input from all
product-related issue had a short shelf life and stakeholders in a project (i.e., UI, Usability, RE,
became stale and out-of-sync with the evolving etc.). Though its contents may prove redundant
code base. We have found that the best way of with the artifacts of other contributors, it will en-
representing and discussing requirements is in a able more efficient progress—the results of which
form that is very close to both the users’ intuitive should eventually be captured more formally.
understanding of needs, and to the developers’ We have also experienced projects without
understanding of context and presentation for the living documents. Often times the lack of these
solution. Such a collaborative medium has been documents, also referred to as “boundary objects”

228
Quality Improvements from using Agile Development Methods: Lessons Learned

(Gunaratne et al., 2004), leads to frustration within solution cycle between the developers and their
teams, and miscommunications between teams. customers. It is our experience that a product
Without these documents, team members often owner or domain expert, faced with an open-ended
struggled to find correct and up-to-date informa- question on what they would like to see in a given
tion pertinent to their tasks. These documents feature, is more likely to make a detailed deci-
provide a necessary medium for communication sion if they are provided with examples that they
amongst and across teams to ensure a common can use to reason about their preferred solution.
understanding. Since the domain expert is commonly a critical
resource, providing them with some exploratory
Lesson 2: Development needs to be proactive with results related to the decisions under consideration
the customer by providing solution alternates in helps to maximize the impact of their involvement.
a form easily grasped by the customer. We have seen very good results from doing some
Storyboarding of viable solution alternatives and
The agile development team is responsible for adding that information to the decision request
ensuring the project progress, and that implies presented to the client.
that they must push for the identification and
implementation of solutions for any problems Lesson 3: Inexpert team members can be agile;
that the product needs to address. The customer however, the learning curve will be significant for
or product owner is responsible for making deci- those who lack technical expertise.
sions on project direction, and doing it in a timely
manner in order to allow the developers to proceed One common complaint about agile develop-
on the priority areas. The general loop of decision ment is that in most cases their success depends
requests starts with the development group, which on having teams of experts (Turner & Boehm,
identifies an issue that needs clarification, and 2003), both in the technical and the application
then shifts to the product owner, who may need domains. On the contrary, in our agile experiences,
to ask other stakeholders for more information we have seen team members with less-than-expert
before a decision can be made. There are two domain knowledge quickly adapt to developing
specific approaches to improve the efficiency of in an agile environment. Most of our projects
the decision-making process: included a significant number of team members
who had minimal experience and knowledge in
• Imposing decision deadlines on the product agile development and the project’s domain. In
owner, and Projects A1 and A2, developers who had a mid-
• Proactively providing the product owner level proficiency in the selected software technol-
with a selection of viable solutions (instead ogy but no domain knowledge were able to start
of just asking a general question about the contributing within a couple days.
issue). This is not to say that no technical expertise
or domain knowledge is required for new mem-
Short decision deadlines are a simple way of bers to be integrated into an agile development
tightly integrating the product owner into the time process. Our experience has been that members
schedule constraints of the development team. with below-level technical skills will face a steep
The proactive approach of partially elaborating learning curve that is magnified by the nature
promising solutions before submitting them to the of agile development. The quick evolution of
product owner for a decision plays a much more the developed code means that less experienced
important role in speeding up the innovation and developers cannot benefit from any stable code

229
Quality Improvements from using Agile Development Methods: Lessons Learned

infrastructure to use as a reference. For instance, Lesson 4: Agile methodologies must be practiced
one such developer in Project E had good domain with a culture of proactive communication to allow
knowledge but below-average technical skills, new members to acclimate quickly.
and this individual was never able to reach a
level of parity with the other developers. On the With practices such as self-documenting code
other hand, pairing new members with experts (Martin, 2003; McConnell, 2004) and just-enough
decreased the learning time for new members. documentation (Beck, 1999; Turner & Boehm,
Daily meetings, as used in Project B, helped in 2003), the successful execution of agile develop-
making performance issues more transparent. ment is dependent on team members receiving
It has also been observed that new members information through electronic correspondence,
need to adjust to the unfamiliar demands of an informal discussions, meetings, or the code itself.
agile process. For example, developers’ code One side effect of using minimal documentation
changes have to be completed, integrated, and is that there is no explicit source explaining how
tested in hours or days, instead of weeks. Develop- people in the development team know what they
ers also need to be able to shrug off the fact that a know. “Agile methods rely heavily on commu-
new decision, project constraint, or requirement nication through tacit, interpersonal knowledge”
could suddenly make their envisioned designs or (Turner & Boehm, 2003). From the standpoint of
previous work obsolete. Additionally, as customer new team members, it is difficult to identify the
demands change during product development, new correct sources for necessary information. In S-
code segments and interfaces may appear that RaP, we address this problem with the Storyboard,
need to be learned quickly. Code refactoring can but in general, we found that it is important for
change an interface that was finally agreed upon all team members to proactively communicate
last week to something completely different this with new members to help them transition into
week. Developers also have to learn to fix or work the project.
around broken builds to avoid being blocked—un-
able to continue with development. These are just Lesson 5: Agile development needs agile project
a subset of the demands we have seen placed on planning (Song et al., 2004).
developers in an agile environment.
Although most developers with adequate Project planning should be the most agile part
technical experience found the agile process intui- of agile development, starting with a coarse scop-
tive, we have also seen technically skilled team ing and chunking of deliverables, and then refin-
members, unaccustomed to agile environments, ing the estimates as the progress provides more
having a difficult time adjusting. On more than data. In agile development, a great emphasis is
one occasion, especially in Project E, we experi- placed on achieving timely delivery against tightly
enced team members who could not adjust to the scheduled milestones. Unfortunately, estimates
more free-form nature of agile processes. Scrum for project deadlines may often be derived from
masters or other leaders had to follow a more only the initial understanding of requirements,
prescriptive approach with these team members. as was our experience in Project E. Since this set
Small, detailed tasks were often specified, and of requirements is expected to be incomplete and
specific milestones, within iterations, were set for vague, such estimates will often be unreliable. In
these tasks to be completed and then reviewed. the case of Project E, unrealistic deadlines set
in the early stages were perceived as a source of

230
Quality Improvements from using Agile Development Methods: Lessons Learned

problems throughout the project due to continu- well-partitioned vertical slices. In Project E, for
ously reported delays. In this particular project, example, after one of the collocated development
we were able to get back on track with the pre- teams moved to Greece, a vertical slice was as-
set milestones through task reprioritization and signed to this team, and this move caused virtually
scope adjustment. no disruption in the project schedule. For projects
A1 and A2, we used instant messaging, telecon-
Lesson 6: To achieve high customer satisfac- ferencing, and online meetings to compensate for
tion in agile development, collecting novice user lack of collocation.
feedback is just as important as regular customer Depending on the size and scope of the project,
feedback. our “small teams” consisted of 2 to 12 members.
These smaller teams generally benefited from
The most visible strength of agile development quick informal discussions with members working
is in being able to achieve high customer satisfac- on similar tasks. However, with larger teams of
tion. Customers that are highly involved in the more than 12, such as in Project E, this practice
definition and refinement of project goals tend to proved to be oftentimes more distracting than
be happier with the final result. An interesting beneficial.
effect of the constant involvement of customer
representatives (i.e., product owners or domain Lesson 8: Decomposing project tasks to assign to
experts) is that their expectations are affected. different teams works best with vertical slices.
In Project B we realized this could also have a
negative impact when a separate customer repre- Across our projects, we have seen multiple
sentative was presented with the final prototype ways of decomposing the projects for concurrent
and found it not-at-all intuitive, even though the development. Decomposition into vertical slices of
customer representative who had been involved functionality, where each sub-team was respon-
with the project had been very satisfied with the sible for a UI segment and shared responsibility for
intuitiveness of the UI. Thus, the perception of its supporting layers, worked very well, provided
intuitive quality of the product can be quite dif- that the sub-teams communicated about their work
ferent for a first-time user. Novice user feedback on common components. Continuous integration,
would not only have helped in discovering this nightly builds, and constant regression testing also
usability issue, but also in estimating the training helped to alleviate the headaches of integrating
needs and detecting any embedded idiosyncrasies multiple vertical slices in projects D and E.
that detract from the product’s overall quality. Although decomposition into horizontal layers
worked well if the infrastructure layer had stable
Lesson 7: Collocation, when necessary, is requirements that did not require refinement, it
best practiced within small teams (Song et al., can also lead to more problems with synchroni-
2004). zation. In Projects D and E, two simultaneously
evolving projects, where the latter depended on
Although collocation is a key practice of the former, horizontal decomposition was used (in
many agile development methodologies that addition to vertical decomposition), and this raised
foster informal, lightweight communication and complex issues of compatibility and synchroniza-
leads to quick effective problem solving, it is not tion between co-dependent iterative development
critical for all project teams to be collocated. Full- activities. The communication that was needed
time collocation or even physical or geographic in order to synchronize these activities was at the
proximity is not required for teams working on

231
Quality Improvements from using Agile Development Methods: Lessons Learned

level of what is usually only available within a That said, one caveat on this approach emerges
team, not between collaborating teams. from Project E: The act of refactoring copy-pasted
Another benefit of doing vertical decomposi- portions of code is only manageable when the
tion of project functionality is that it allows partial copy-pasted fragment has not proliferated too
decompositions and sharing of tasks between much in the code base. In Project E, the presen-
teams. The shared tasks encourage the sharing tation-layer (Java Server Pages) was developed
of developers across teams, and allow members separately but concurrently by several developers
of distinct teams to take over the communication in distributed teams to meet a specific visual lay-
and coordination responsibility for the specific out/look-and-feel. However, even as these pages
shared components. produced correct output, their internal document
structures were different enough to create a main-
Lesson 9: Where practical, postpone refactor- tenance nightmare without refactoring. The sheer
ing until several instances of the part under number of these pages, coupled with the speed
consideration (component, behavior, etc.) are with which they were completed, amounted to a
implemented. sizeable refactoring task; estimates for the ad-
ditional effort were difficult for the development
Many of our projects were characterized by team to make.
parts that were largely similar to each other. For The task of refactoring is a complex undertak-
example, Projects A1 and A2 included interac- ing that is comprised of three separate subtasks:
tions that significantly resembled each other. For Recognizing an appropriate refactorable chunk,
Project E, many UI implementation aspects varied devising a refactoring solution, and adjusting/re-
only slightly in design. Such strong similarities, placing the code that would be made obsolete by
coupled with agile development’s rapid nature and that solution. The point of this lesson targets the
its emphasis on doing just enough for a specific first of these subtasks to avoid premature over-en-
delivery, lead quite naturally to the use of a copy- gineering of such code bits—a lesson we consider
and-paste style of software development. We found quite important. The point of this caveat, however,
that implementing several features independently is to warn against the potential bottleneck that the
in this manner accentuated the points of com- last subtask can become in agile development. If
monality, as well as the points of difference. This too much code is subject to refactoring, then the
translated into implementation-level requirements additional effort to adjust/replace this code will
that might not have otherwise been foreseen. It be difficult to estimate and can be unexpectedly
is precisely these requirements that provided the substantial.
strongest guidance to refactoring. Finally, there are situations where the devel-
While this approach has certain drawbacks, opment team has far more control and internal
it is important to note that its negative effects knowledge, and where the early and proactive
are mostly indirect. For example, copy-and-paste engineering of reusable and scalable solutions is
leads to more maintenance work on the code or mostly a positive approach. The overall software
embedded documentation, but it generally does architecture for a product, for example, will usu-
not lead to functional errors in and of itself. We ally be defined very early in the project, and these
have found that the opposite approach of trying aspects tend to remain largely stable. Wherever
to over-engineer reusable implementations too the development team can identify improvements
early tends to lead to both types of problems, to the architecture or components which they
functional failures and increased code develop- consider useful from the development reuse stand-
ment and maintenance cost. point, those are more likely to be stable since they

232
Quality Improvements from using Agile Development Methods: Lessons Learned

often do not depend on the modifications of the dedicating a major portion of this chapter to the
explicit user interaction which may be requested lessons that we have learned.
by the customer. From the implicit suggestions in the lessons
learned section for improving QA in agile projects,
Lesson 10: A high level of customer satisfaction we feel the most important is: Actively attempt
can still be achieved, even if the resulting deliv- to capture and exploit informal communications.
erables do not entirely meet expectations. Our experiences have shown how valuable the in-
formation such as electronic correspondence, side
Due to the increased emphasis on customer discussions, and even code itself can be. When we
communication and involvement in agile pro- used Storyboards in certain projects, we found that
cesses, we have found that the resulting customer this way of capturing the informal communica-
satisfaction is based less on the quality of the tions between stakeholders helped new developers,
deliverables than in traditional approaches. Cer- as well as customers, get up to speed quicker and
tainly, the quality of the product still matters, but exposed difficult-to-predict issues. Moreover, in
the quality of the working relationship can be projects where informal communications were
just as important. In customer feedback surveys not captured, extra individual efforts were often
from Projects A1 and A2, an appreciation for the made by team members to ascertain relevant
quality of the interaction with the development information in order to understand requirements
team was expressed alongside noted deficiencies or complete programming tasks. Although the
in the final software deliverable. This suggests use of this particular living document is not a
that when the customer feels that their needs are cure-all, the informal knowledge that it stores has
well understood and is pleased with the commu- helped us achieve a high level of software quality
nication and interactions during the project, the in functionality and usability.
likely result is a satisfied customer. For our own purposes, this chapter has also
suggested that it is important to identify quality
goals early on in the project, even though they
concLusIon may change. Not only does this keep the entire
team mindful of these goals but it also allows
Quality assurance has been an integral part of for the planning of QA practices that will help
agile development that has stemmed from pro- us achieve them. In this way, QA can become
cess-inherent practices as well as practices for agile—if a new quality goal is introduced in an
addressing specific quality goals. What makes iteration, appropriate QA practices can be selected
quality assurance work so differently (McBreen, and incorporated.
2002) with agile projects is the way that quality As the agile development group at Siemens
goals are defined and negotiated throughout the Corporate Research, we are interested in iden-
project. From the seven project experiences that are tifying metrics for measuring software quality
discussed in this chapter, we were able to identify in agile projects. Although the success of QA
several common high-level quality goals and the practices in agile development projects is often
different practices that were practiced to achieve measured by customer satisfaction, we recognize
them. Not every technique used was implemented the need for measuring how agile processes and
perfectly in our projects, and not every technique other factors influence software quality. We found
was able to achieve a quality goal on its own. We that the specific ISO (ISO/IEC, 2003) metrics for
attempt to address these areas of deficiency by measuring software quality were often vague,

233
Quality Improvements from using Agile Development Methods: Lessons Learned

irrelevant, or unsuitable. With better metrics, McBreen, P. (2002). Quality assurance on agile
we hope to make more concrete contributions to processes. Software Craftsmanship Inc., Talks.
advance the understanding of quality assurance Retrieved May 3, 2006, from http://www.mcbreen.
in agile projects. ab.ca/talks/CAMUG.pdf
McConnell, S. (1996). Rapid development. Red-
mond, WA: Microsoft Press.
rEFErEncEs
McConnell, S. (2004). Code complete (2nd ed.).
Beck, K. (1999). eXtreme programming explained: Redmond, WA: Microsoft Press.
Embrace change. Addison Wesley.
Nelson, C., & Kim, J. S. (2004, November).
Beck, K. et al. (2001). Manifesto for agile software Integration of software engineering techniques
development. Retrieved November 21, 2005, from through the use of architecture, process, and
http://agilemanifesto.org/ people management: An experience report.
Proceedings of Rapid Integration of Software
Brooks, F.P. Jr. (1987, April). No silver bullet:
Engineering Techniques, 1st International Work-
Essence and accidents of software engineering.
shop, RISE 2004, LNCS 3475 (pp. 1-10). Berlin &
Computer Magazine, 20(4), 10-19.
Heidelberg: Springer-Verlag.
Gunaratne, J., Hwong, B., Nelson, C., & Rudorfer,
Pichler, R. (2006, January 19). Agile product devel-
A. (2004, May). Using evolutionary prototypes to
opment: Going agile at Siemens communications.
formalize product requirements. Paper presented
Presented at OOP 2006, Munich, Germany.
at Workshop on Bridging the Gaps II: Bridging
the Gaps Between Software Engineering and Schwaber, K., & Beedle, M. (2001). Agile software
Human-Computer Interaction, ICSE 2004, Ed- development with Scrum. Prentice Hall.
inburgh, Scotland.
Smith, P. G., & Pichler, R. (2005, April). Agile
Hwong, B., Laurance, D., Rudorfer, A., & Song, risks/agile rewards. Software Development, 50-
X. (2004, April). User-centered design and agile 53. Retrieved May 3, 2006, from http://www.ddj.
software development processes. Paper presented com/showArticle.jhtml;jsessionid=H1VRQ0BO1
at Workshop on Bridging Gaps Between HCI and INWEQSNDBECKH0CJUMEKJVN?articleID
Software Engineering and Design, and Bound- =184415308
ary Objects to Bridge Them, 2004 Human Fac-
Song, X., Matos, G., Hwong, B., Rudorfer, A., &
tors in Computing Systems Conference, Vienna,
Nelson, C. (2004, November). People & project
Austria.
management issues in highly time-pressured
ISO/IEC 9126: Software engineering—Product rapid development projects. Paper presented at
quality. (2003). Switzerland: ISO. EuroSun 2004, Cologne, Germany.
Jacobson, I., Booch, G., & Rumbaugh, J. (1999). Song, X., Matos, G., Hwong, B., Rudorfer, A.,
The unified software development process. Read- & Nelson, C. (2005, August). S-RaP: A concur-
ing, MA: Addison Wesley Longman. rent prototyping process for refining workflow-
oriented requirements. Proceedings of the 13th
Martin, R. C. (2003). Agile software development:
IEEE International Conference on Requirements
Principles, patterns, and practices. Prentice
Engineering (pp. 416-420). IEEE Conference
Hall.
Publishing Services.

234
Quality Improvements from using Agile Development Methods: Lessons Learned

Tai, G. (2005, May). A communication architec-


ture from rapid prototyping. Proceedings of the
2005 Workshop on Human and Social Factors
of Software Engineering (pp. 1-3). New York:
ACM Press. DOI= http://doi.acm.org/10.1145/
1083106.1083120
Turner, R., & Boehm, B. (2003, December).
People factors in software management: Lessons
from comparing agile and plan-driven methods.
The Journal of Defense Software Engineering.
Retrieved May 3, 2006, from http://www.stsc.hill.
af.mil/crosstalk/2003/12/0312Turner.pdf

235
236

About the Authors

Lars Bendix is an associate professor at Lund Institute of Technology, Sweden, where he initiated
the Scandinavian Network of Excellence in Software Configuration Management as a framework for
collaboration between academia and industry. Software configuration management has been one of his
main research interests for more than a decade. Bendix teaches the subject at university, has given several
tutorials for industrial audiences, and has worked with many companies to improve their configuration
management practices. He is also involved in his department’s software engineering teaching that is
based around the use of eXtreme Programming. He received his master’s degree in computer science
from Aarhus University, Denmark (1986) and his PhD from Aalborg University, Denmark (1996).

Eleni Berki is an assistant professor of software development at the Department of Computer Sci-
ences, University of Tampere, Finland. Previously she was a researcher/principal investigator at the
Information Technology Research Institute and assistant professor of group technologies in Jyväskylä
University, Finland. Berki obtained her PhD in process metamodelling and information systems method
engineering (2001) in UK. Her teaching and research interests include testing, security and trust, virtual
communities, information and communication technologies, computational models, multidisciplinary
approaches for software engineering, knowledge representation frameworks, and requirements engineer-
ing, whereon she supervises MSc and PhD students. She has worked as a systems analyst, a designer,
and an IS quality consultant in industry, and has a number of international academic and industrial
projects. She has been active in the development, delivery, and coordination of virtual and distance
e-learning initiatives in collaboration projects in European and Asian countries. She has authored and
co-authored more than 50 publications in world congresses, international forums, books, and journals
and has given a number of talks in international conferences. Berki has been a professional member
of the Institute of Electrical and Electronic Engineers (IEEE), the British Computer Society (BCS),
and the United Kingdom Higher Education Academy within which she participates in organising and
scientific conference committees, reviewing, and evaluation, and other collaboration projects. She has
been a visiting lecturer in a number of UK Universities, the University of Sorbonne Paris-1 in France,
and University of Crete in Greece.

Copyright © 2007, Idea Group Inc., distributing in print or electronic forms without written permission of IGI is prohibited.
About the Authors

Lindsey Brodie is currently studying for a PhD at Middlesex University, UK. She holds an MSc in
information systems design. She edited Tom Gilb’s latest book, Competitive Engineering. Previously
she worked for many years for International Computers Limited (ICL), UK, carrying out technical
project support, product support (operating system and database support), and business process and
management consultancy. Brodie is a member of the British Computer Society and a Chartered Engineer
(MBCS CITP CEng).

Yael Dubinsky is a visiting member of the human-computer interaction research group at the De-
partment of Computer and Systems Science at La Sapienza, Rome, Italy, and an adjunct lecturer in
the computer science department at the Technion-Institute of Technology. Her research examines the
implementation of agile software development methods in software teamwork, focusing on software
process measurement and product quality. She received her BSc and MSc in computer science and PhD
in science and technology education from the Technion-Israel Institute of Technology. Dubinsky is a
member of IEEE and IEEE Communications Society.

Barry Dwolatzky is professor of information engineering and director of the Information Engi-
neering Research Programme at the University of the Witwatersrand, Johannesburg, South Africa.
After obtaining his PhD from the University of the Witwatersrand (1979), he spent 10 years in Britain
carrying out post-doctoral research at UMIST in Manchester, Imperial College in London, and at the
GEC-Marconi Research Centre in Chelmsford, Essex. He returned to his alma mater as a senior lecturer
in 1989. Dwolatzky’s current research interests are in software engineering and in the use of geospatial
information by utilities in developing countries. He is academic director of the Johannesburg Centre
for Software Engineering (JCSE) at Wits University.

Torbjörn Ekman is a researcher at Lund Institute of Technology, Sweden, where he has been working
within the LUCAS Center for Applied Software Research for the last five years. He is currently working
in the PalCom integrated project in EU’s 6th Framework Programme. His interest for software configura-
tion management in agile methods started during the development of an eXtreme Programming course,
which has now been running for four years. Other research interests include tool support ranging from
refactoring aware versioning to compiler construction. Ekman received his master’s degree in computer
science and engineering (2000) and his PhD (2006) from Lund University, Sweden.

Eli Georgiadou is a principal lecturer of software engineering in the School of Computing Sci-
ence, Middlesex University, London, UK. Her teaching includes comparative methodologies, evalu-
ation of methods and tools, systems development, software quality management, and knowledge and
project management. She has worked in industry in the UK and in Greece, and has extensive expertise
in curriculum development and pedagogic issues gained in the UK, in Europe (primarily in Greece,
Spain, and Finland), and further afield (such as in China, Egypt, and Vietnam). Georgiadou’s research
includes software quality, requirements engineering, information systems development methodologies,
metamodelling, measurement, knowledge management, and process improvement but also in pedagogic
issues, such as resource based open and distance learning. She has published over 90 refereed papers in
journals and international conferences. She has organised and chaired a number of international confer-
ences, workshops, and technology transfer initiatives. She currently coordinates the European Affairs
and International Exchanges in her school and serves on various reviewing and scientific committees.

237
About the Authors

Tom Gilb has been an independent consultant, teacher, and author since 1960. He works mainly
with multinational clients; helping improve their organizations, and their systems engineering methods.
Gilb’s latest book is Competitive engineering: A handbook for systems engineering, requirements engi-
neering, and software engineering using planguage (2005). Other books are Software inspection (Gilb
& Graham, 1993) and Principles of software engineering management (1988). His Software metrics
book (1976, Out of Print) has been cited as the initial inspiration (IBM, Radice) for what is now CMMI
Level 4. Gilb’s key interests include business metrics, evolutionary delivery, and further development
of his planning language, Planguage.

Beatrice Miao Hwong is a member of the technical staff in the Requirements Engineering Program
of the software engineering department at Siemens Corporate Research in Princeton, NJ. She has led
efforts most recently in process tailoring and requirements engineering in automotive, medical, and
automation business units of Siemens. Hwong has a BS in electrical engineering from Tufts University,
an MS from Cornell University, an MS CICE from University of Michigan, and a PhD in computer
engineering from Rutgers University.

Maheshwar K. Inampudi is the lead IT architect for IBM’s On Demand Workplace expertise loca-
tion system (BluePages, and several other intranet applications). His additional responsibilities include
the architecture and solution design for several of IBM’s internal offerings as well as collaborating with
the CIO’s office and IBM Research in helping design applications using the latest SOA methodologies.
He helps showcase IBM’s emerging technologies such as WebSphere eXtended Deployment (XD)
and IBM’s IntraGrid Grid Computing Architectures. Inampudi holds a BS in computer science from
Pune University and is currently pursuing a certification degree in advanced project management from
Stanford University. Recent interests include leveraging emerging technologies, such as autonomic
computing and grid computing.

Jim F. Kile is a PMI certified project management professional (PMP) and senior business area
manager at International Business Machines Corporation working in Southbury, CT. He is responsible
for managing a team of more than 135 individuals worldwide who develop, deploy, and maintain ap-
plications in support of IBM’s internal corporate human resources. Kile holds a BBA in management
information system from Western Connecticut State University (1989), an MS in information systems
from Pace University (1995), and is currently pursuing his doctorate at Pace University. Throughout his
career, he has created and piloted different project management and software development methodolo-
gies to improve the art and science of software development.

Monica McKenna is a member of the technical staff at Siemens Corporate Research, USA. She has
more than 20 years experience in software design and development.

Scott Mark is an enterprise application architect for Medtronic, Inc, the world’s leading medical
technology company. His primary areas of expertise are the application of agile methods in the archi-
tecture and design of personalized information portals. He has applied agile methods in the context
of dynamic content personalization for several large-scale, globalized systems. He has significant ap-
plication development leadership experience, including disseminating development best practices and

238
About the Authors

pattern-based design approaches in a large enterprise. He is skilled in the use of agile modeling and test-
first development practices to enable lean project execution. Scott is a member of the Java Community
Process (JCP) organization and was an early participant on the Expert Group for the JSR 170--Content
Repository for Java Technology specification. He also has a strong background in technical writing and
online information architecture and delivery.

Gilberto Matos is a member of the technical staff in the requirement engineering and rapid proto-
typing group at Siemens Corporate Research, USA. He has been involved in a number of internal and
external software prototype and product development projects within Siemens over the last 8 years,
mostly in technical lead roles. His research is centered on the methods and software support tools for
faster and more accurate representation of user requirements in an executable form. Matos received his
PhD in computer science from the University of Maryland at College Park.

Atif Memon is an assistant professor at the Department of Computer Science, University of Mary-
land. He received his BS, MS, and PhD in computer science in 1991, 1995, and 2001 respectively. He
was awarded a Gold Medal in BS. He was awarded Fellowships from the Andrew Mellon Foundation
for his PhD research. He received the NSF CAREER award in 2005. Memon’s research interests include
program testing, software engineering, artificial intelligence, plan generation, reverse engineering, and
program structures. He is a member of the ACM and the IEEE Computer Society.

Ernest Mnkandla lectures in the School of Information Technology at Monash University, South
Africa. He has submitted a PhD thesis at the School of Electrical & Information Engineering at the
University of the Witwatersrand, Johannesburg, South Africa in the area of agile software development
methodologies. He has lectured in this area and has presented several papers on agile methodologies
and project management within Africa, Europe, and the Pacific Islands. Mnkandla completed a Btech
(honours) in electrical engineering at the University of Zimbabwe (1992) and completed an MSc (Comp.
Sc) at the National University Science and Technology in Zimbabwe (1997). His current research is
in the adoption and quality assurance issues in agile methodologies. Mnkandla also does research in
security policies for the implementation of wireless technologies.

Vagelis Monochristou holds a BSc in applied informatics from the University of Macedonia, Depart-
ment of Applied Informatics (Thessaloniki, Greece), as well as an MSc in insurance and risk management
from the CITY Business School, (City University, London, England). Since 2003, he is a PhD Candidate
in the department of applied informatics in the University of Macedonia (Thessaloniki, Greece), and
his research has been focused on the area of agile methods and the possibilities of their adoption in the
Greek IT Market. Since 2000, Monochristou works as an IT consultant and has significant experience
in business modelling, user requirements analysis as well as in software project management.

Christopher Nelson is an associate member of the technical staff in the software engineering depart-
ment of Siemens Corporate Research, Princeton, NJ. His research has been in the areas of UI intensive
software, agile processes, and global software development. Nelson received his BS in computer science
and engineering from Bucknell University. He is currently attaining his master of software engineering
degree from Carnegie Mellon University, Pittsburgh, PA.

239
About the Authors

Gergana Nikolova is a graduate student in computer science at the Technische Universität München.
She recently worked within the rapid prototyping and requirements engineering group in the Software
Engineering Department at Siemens Corporate Research. Niklova has contributed greatly towards the
definition of a reference model for S-RaP (Siemens Rapid Prototyping)—an in-house prototyping pro-
cess. Thus, her research focus has been in software development processes, particularly requirements
engineering and rapid prototyping.

Orit Hazzan is an associate professor in the Department of Education in Technology and Science
at Technion–Israel Institute of Technology. Her research interests are in human aspects of software
engineering, particularly relating to agile software development and extreme programming develop-
ment environments. She is coauthor (with Jim Tomayko) of Human Aspects of Software Engineering
(Charles River Media, 2004). She received her PhD in mathematics education from the Technion–Israel
Institute of Technology. Orit is a member of ACM and the ACM Special Interest Group on Computer
Science Education.

Jörg Rech is a scientist and project manager of the Fraunhofer IESE. He earned a BS (Vordiplom)
and an MS (Diplom) in computer science with a minor in electrical science from the University of Kai-
serslautern, Germany. He was a research assistant at the software engineering research group (AGSE)
by Prof. Dieter Rombach at the University of Kaiserslautern. His research mainly concerns knowledge
discovery in software repositories, defect discovery, code mining, code retrieval, software analysis,
software visualization, software quality assurance, and knowledge management. Rech published a
number of papers, mainly on software engineering and knowledge management and is a member of the
German Computer Society (Gesellschaft für Informatik, GI).

Arnold Rudorfer is the program manager for requirements engineering with worldwide responsibil-
ity at Siemens Corporate Research in Princeton, NJ. He has more than 12 years experience in product
development and business consulting leading international projects. His main research interests are agile
development techniques, requirements engineering as well as product management and marketing of
software products. Rudorfer enjoys working with customers and his high-performance team to deliver
solutions to Siemens businesses. Also, he is a certified Bootstrap and SPICE assessor.

Kerstin Siakas is an assistant professor at the Department of Informatics at the Alexander Techno-
logical Educational Institute of Thessaloniki, Greece since 1989. Her teaching includes software quality
management, management information systems, and project management. She has developed and led
large information systems projects in multinational companies in both Sweden and Greece. She has a
PhD in software quality management from London Metropolitan University. Her research spans a range
of issues in information systems quality, requirements, knowledge, and outsourcing management, in
particular in cultural and organisational issues of the software development process, but also in pedagogic
issues, such as technology based distance learning. Siakas has published around 50 refereed papers in
different journals and international conferences.

Xiping Song is a senior member of the technical staff in the Software Engineering Department at
Siemens Corporate Research, USA. In over a decade of working at Siemens, Song has been involved in

240
About the Authors

many software development projects. He has worked as an architect for the Soarian project, designing
the architecture for this key Siemens health service product. He designed the load-balancing strategy for
deploying the product at the Siemens data center. Now, he is focusing on research on medical workflows.
Song received a PhD from University of California at Irvine.

Grace Yuan Tai works as a member of the rapid prototyping and requirements engineering group
within the Software Engineering Department at Siemens Corporate Research, USA. She is normally
based in Princeton, but was working in Munich on a globally distributed agile project while working on
this book chapter. She came to Siemens with a BS in computer science from the University of Michi-
gan and has contributed to the research area of human and social factors in software engineering. Tai
will continue to pursue her research interests as a master’s student at RWTH Aachen starting October
2006.

Rajanikanth Tanikella is an associate member of the Technical Staff in the Software Engineering
Department of Siemens Corporate Research, Princeton, NJ. Aside from software quality and testing
related projects and prototypes for mobile devices, Tanikella has been involved in a number of agile
development projects. He holds a BS in computer science from the State University of NY at Stony
Brook and a MS in computer science from the New Jersey Institute of Technology. In his abundant free
time, Tanikella does office work.

Qing Xie received her BS degree from South China University of Technology, Guangzhou, China
(1996). She received the MS degree in computer science from the University of Maryland (2003). She
is currently a PhD student in the Department of Computer Science at the University of Maryland. Her
research interests include software testing, software maintenance, mutation techniques, and empirical
studies. She is a student member of the ACM, the IEEE, and the IEEE Computer Society.

M. Vlachopoulou is an associate professor at the University of Macedonia, Department of Applied


Informatics, Greece. Her studies include:

• Degree in business administration, Aristoteles University of Thessaloniki, Greece.


• Degree in law, Aristoteles University of Thessaloniki, Greece.
• Postgraduate degree studies in marketing, University of Mannheim, Germany, and MBS in busi-
ness administration, Aristoteles University of Thessaloniki.
• PhD in marketing information systems, University of Macedonia, Department of Applied Informatics,
Greece.

Vlachopoulou’s main fields of research include: marketing information systems, e-business/e-marketing


models, internet marketing plan, e-learning, new technologies and informatics in marketing, electronic
commerce, ERP, and CRM systems, supply chain management (SCM) systems, knowledge management,
e-supply chain management, e-logistics, virtual organization/enterprise modeling, and agile methods.
She is the author and co-author of several books, mainly in the area of e-marketing, and has numerous
publications in International Journals, Volumes, and International Conference Proceedings.

241
About the Authors

Bradley Wehrwein is an associate member of the Technical Staff in the Software Engineering
Department at Siemens Corporate Research in Princeton, New Jersey, USA. He received his BS in
computer science from the University of Massachusetts. His research interests include user interface,
Web technologies, and agile software processes.

242
Index 243

Index

A smell 100
automated static 198
acceptance test 84 automation 193,  203
activity 5
adaptability 74 B
adaptive
ecosystem 163 big modeling up-front (BMUF) 75
systems development (ASD) 12 black-box testing 117
adjustability 5 brainstorm 81
agile build
concept 182 management 140
development 136–153,  187 process 199
information systems development (AISD) 23
method 24,  56–70,  74
C
engineering (AME) 41 capability maturity model (CMM) 32
metrics 32 career development 158
quality 23–55,  24,  171 COCOMO 31
assurance 114–135 code
software annotation 96
development 1,  90–113,  171–185 inspection 95
method 1–22 smell 100
testing 119 collaboration 164
workforce planning 154 commitment 39
Agile Alliance 2 communication 74,  158,  164,  178
agilist 9,  75 compatibility 11
agility 3–4,  32,  39,  46 competency integration 159
annotation language 96 comprehensive testing 114
anti-pattern 100 concurrency control 140
architectural

Copyright © 2007, Idea Group Inc., distributing in print or electronic forms without written permission of IGI is prohibited.
244 Index

configuration flexibility 4,  107


audit 149 forward engineering 34
audits 139 functional testing 117
control 139,  148 future information research management (FIRM) 63
identification 139,  148
status accounting 148 G
continuous integration (CI) 67,  141,  144,  150,  202 gap analysis 161
control flow graph (CFG) 118 geek-speak 75
correctness 11 Gilb, Tom 58
cost glass-box testing 118
estimation model 31 graphical-user interface (GUI) 114–135
reduction 195 Ripper 128–129
crash testing 116,  120,  129 Ripping 128–129
culture 159
customer 38,  72,  78 H
collaboration 74
human dynamics 154–170
D
I
decision-making 26
defect impact estimation (IE) 59,  62
classification scheme 95 in-action reflection 178
detection 194 independence 107
management system 94 information systems development (ISD) 23
depth of reasoning 23–55 method (ISDM) 25
design flaw 100 integration 150
dexterity 5 integrity 11
double maintenance 143 iterative 3
dynamic systems development method (DSDM) 26 development 202

E K
ease of use 11 key process area (KPA) 157
efficiency 11 knowledge 9,  37
efficient 5 management (KM) 38
empowered workgroup 159
ETHICS 26–27 L
evaluation and assessment (E&A) 156 language 85
event-flow learner
graph 127,  130 -learner communication 178
model 121 -teacher communication 178
Evo method 68 library control system 200
extendibility 11 lightweight 5
extreme lines of code (LOC) 210
character 82 low-risk 5
programming (XP) 12,  15,  34,  39,  75–
76,  84,  93,  155 M
F machine-readable 108
mature process 32
face-to-face communication 74,  164 maturity 157
fear 192 mentoring 159,  168
finite state machine (FSM) 119 method engineering (ME) 41
Index 245

micro-didactical arrangement (MDA) 104 quantification 56


modal quantitative performance management 159
dialog 126 questionnaire 82
window 126
modeless window 126 R
motion 5 re-engineering 34
motivation 39 re-structuring 34
N re-use 34
refactoring 34,  94,  142,  146
nimbleness 4 annotation language (RAL) 107
novice user 119 regression testing 118
release management 141
O return on investment (ROI) 28
on-action reflection 178 reusability 11
open architecture 68 reverse engineering 34
organizational performance 160 risk
assessment 211
P removal 63
robustness 11
pair role
effectiveness 166 assignment 181
performance 166 communication measure (RCM) 180
programming 90 management measure (RMM) 180
role 164
viability 166 S
parallel work 141,  143
participatory culture 159 satisfaction 39
pattern 100 scientific 5
people capability maturity model (P-CMM) 155 Scrum 14
performance management 158 self-organizing 3
persona 81 Siemens
personnel 162 Corporate Research (SCR) 222
quality 155 Rapid Prototyping (S-RaP) 222
plan-driven smoke testing 120,  129
quality assurance (QA) 173 social interaction 177
Planguage 59 software
planning game 142 configuration management (SCM) 136
portability 11 development 26,  30,  171
predictable 5 engineering (SE) 102
productivity 207 inspection 93
prototyping 224 process
improvement (SPI) 28
Q modeling 12
product metrics 94
quality 1,  6–7,  23,  25,  30,  58,  206–220 project management 12
assurance (QA) 2,  9,  84,  136,  171,  186– quality 90–113
205,  221–222 assurance (SQA) 95,  99
defect (QD) 92,  100,  102–103 requirements specification (SRS) 71
discovery 99 testing 94,  117
improvement 207,  221–234 stability analysis 198
test 144 stakeholder 30,  61,  117
246 Index

participation 75
statistical process control (SPC) 25
story-writing workshop 82
storyboarding 224

T
tacit knowledge 164
taglet 96
team planning 154
test
-driven development (TDD) 142,  146,  206–220
harness 209
timeliness 11
total quality management 24
traditional software development 172
training 158

U
unidirectional 73
usability 8
test 192
user
acceptance test 217
interface (UI) 222
interview 82
requirements 71
role 80
stories 71–89

V
variable finite state machine (VFSM) 119
verifiability 11
version control system 139

W
waterfall
model 71
software development 190
work environment 158
workforce planning 159
workgroup development 158
work habits 177

You might also like