Sunteți pe pagina 1din 10

An Agile Request For Proposal (RFP) Process

Jennitta Andrea
ClearStream Consulting
jennitta@clrstream.com

Abstract project constraints (time, cost, architecture, process, etc.)


and issues an RFP document to candidate vendors.
The Request For Proposal (RFP) process can be agile Stage 2: Proposal. Vendor assesses the requirements
and efficient. At a high level, the key to achieving this is and delivers their response, which includes their proposed
to specify requirements just in time and containing just solution, constraints, and cost estimates. If the RFP
enough detail. This paper applies the following XP specifies local adaptations to industry standard business
practices and concepts to the RFP process: acceptance rules and processes, customization of an existing vendor
tests, business value, iterative & incremental delivery, on- product may be proposed.
site customer, pair development, planning game, spike, Stage 3: Evaluation. Company evaluates the
story, velocity, and yesterday’s weather. In addition, the responses and selects a vendor based on a consideration of
following concepts are combined with those from XP to how well their proposal meets the requirements and
achieve maximal benefit: user-goal use case, context satisfies the project constraints, notably time and cost.
diagram, level of detail, and decision tree. Stage 4: Implementation. Company and vendor
The contributions of this paper to the agile community implement the solution.
are two-fold: describing a practical application of XP
concepts to a non-programming project; and making use 1.2. Agile Methodologies
case style requirements processes more agile.
For in-house development, companies are
1. Introduction experiencing the benefits of agile methodologies as a way
to help reduce risk and successfully keep up with the pace
Current economic conditions and competitive realities of changing business requirements and priorities. Lean
are forcing many companies into an unfamiliar state of Manufacturing [1] summarizes how these goals are
flux. IT organizations are facing the daunting challenge achieved: reduce waste (work efficiently) and reduce
of delivering software systems while the supported inventory (work just in time, produce just enough).
business processes undergo radical change due to When requirements and business priorities are stable,
downsizing, mergers, or market expansion. Increasingly it is considered prudent to look ahead at up-coming
faced with reduced budgets, tighter timelines, and requirements and proactively build flexibility into a
increased competition, companies are in search of software product in order to cost effectively support future
strategies for working smarter and doing more with less. capabilities. However, when priorities and requirements
Among the list of successful strategies for achieving this are in a state of flux, it pays off to be more reactive. Any
end are purchasing package software, and employing agile work done beyond the current release horizon could end
methodologies. up wasted because tomorrow, brand new requirements
may replace the ones that were important today. This is
1.1. Request for Proposal the heart of the philosophy behind agile methods.
Extreme Programming (XP) [2] is one of several agile
Purchasing package software or outsourcing software methodologies, and is a sound strategy for minimizing the
development rather than building custom systems in-house amount of work required in order to deliver a high quality,
are viewed as sound strategies for reducing the overall highly valued software product. XP can be summarized
cost of ownership. Request For Proposal (RFP) is the by its four core values: communication, simplicity,
business process a company executes in order to find the feedback, and courage. These values are supported by a
vendor and/or product that best meet their criteria. A set of practices: the planning game, small releases,
simplified list of the high level stages in the RFP business metaphor, simple design, testing, refactoring, pair
process include: programming, collective ownership, continuous
Stage 1: Specification. Company specifies the system integration, 40 hour week, on-site customer, and coding
requirements (functional and non-functional) and general standards. XP thrives in a software development context
consisting of a small, co-located team.
1.3. A Blind Date are a common form of documenting functional
requirements for an RFP. A use case captures the essence
What if we introduced these two strategies (RFP and of a users interaction with the system to achieve a
agile) to each other? Are they compatible? Would their measurable business goal. A use case succinctly describes
union achieve synergy and yet preserve their original all of the possible scenarios for this interaction (main,
essence? When should we play matchmaker? When alternative, and failure), and describes the expected
should we stay well enough alone? outcome. Use cases appear to be out of favor with XP
This paper explores the application of agile concepts proponents, possibly because they tend to be developed in
and key XP practices to a non-programming project, the a waterfall fashion.
RFP process, to enable making the best product choice XP introduces the concept of stories as a form of
while optimizing scarce resources: time and money. The functional requirements specification that easily adapts to
ideas contained in this paper are based on several changing business priorities. A collection of stories is
experiences. The core of the content stems from a project identified for the current release of the system. Initially
initiated to assess a short list of vendor products being the stories are sketchy, intended to be ‘promises for
considered as a replacement for an aging, homegrown, conversations’ that will occur between the customer and
safety-critical system. The sophistication and criticality of developer within the release. During these just in time
the system meant that the effort for the RFP requirement conversations, the requirements for a story will be
specification stage was expected to be substantial. Thus explained to the level of detail necessary to enable the
the company explored ways to streamline RFP process, developer to implement and test the story. It is not
finding a balance between ensuring that all requirements considered necessary to document the requirements in a
were accounted for, and the level of detail necessary to form other than source code. Stories for future releases
properly evaluate the candidate vendor products. These remain sketchy until they are actually going to be
initial ideas were further refined after the author implemented. Stories are effective for planning and
experienced the RFP process from the other side of the depicting the essence of system requirements, given the
fence – as a vendor responding RFP’s rather than as a ideal situation of having the customer on-site.
company issuing them. These other experiences shed
light on how difficult it is to produce an accurate estimate 2.2. Use Cases Meet Stories
when the requirements within a RFP are too sketchy. All
of these experiences have been further refined by Use cases are appropriate for formally documenting
reflecting upon how they can be improved with the correct the functional requirements of a system because all related
application of established agile practices. scenarios are succinctly grouped together, providing a
Section 2 covers techniques for optimizing the RFP big-picture overview. However, use cases are not a good
specification stage, and introduces the concepts of levels unit for planning. Typically, the various scenarios
of detail, decision tree, and embedding stories into use belonging to the same use case have different priorities,
cases. An example is introduced that is used throughout thus, a software release does not develop an entire use
the rest of the paper. Section 3 describes an agile case at once. In addition, not all scenarios in the same use
approach to the RFP specification stage by adding other case need to be described to the same level of detail.
XP practices to the techniques introduced in Section 2. Stories, on the other hand, are a more appropriate unit for
Section 4 describes an agile approach to the RFP planning. Each story, by definition, has a uniform
evaluation stage, in particular for evaluating package priority, and is small enough to be developed within a
software compliance to the requirements. single software release. Unfortunately, stories do not have
the level of detail or rigor needed for a situation, like a
2. Optimizing the RFP Specification Stage RFP, where the customer and vendor are separated by
time and distance, and must rely on documentation rather
2.1. Use Cases vs. Stories than conversations.
What happens when we take the best of both worlds?
A typical RFP specification process and a typical agile There is no reason why use cases have to be developed in
requirements process are at opposite ends of the spectrum a pure waterfall fashion, even for the RFP process where
in terms of sequencing of tasks and the format and content all requirements are needed up-front. Instead of
of the requirements. specifying all use cases to the same level of detail, a
By necessity, the RFP specification process is a big- decision-making strategy can be used to determine the
up-front-requirements activity. The RFP issued to the minimum detail needed for each use case in order to base
vendors must contain all of the system requirements that a credible estimate upon it. Furthermore, the concept of
the company expects the vendor to support. Use cases [3] story can be embedded within a use case to facilitate a
finer grained decision-making process. Finally, the Pre-Condition • nothing
concept of business value can be applied effectively to the
planning of the requirements specification process. Success • Volume created (archived state)
and associated with the specified
Box, and Chart.
2.3. Levels of Detail
• Box / Chart is created if it did
not exist previously.
The Agile RFP Process begins with clear definitions of
• User name and date of action
the various target levels of detail for capturing the use
placed in audit log.
cases. The example use case shown throughout this
section is based on the specification of a small system that Failure • nothing
is used by hospitals to archive inactive patient records Example 1: Identity Level
(called volumes). A patient is identified by a chart
number, and may have one or more volumes. A volume is 2.3.2. Outline Level. This level provides a sketch or
essentially a file folder that contains treatment details for a outline of the requirement. Typically this level is useful
patient. If a patient has not received treatment for five or for facilitating a quick estimate when there is significant
more years, their volume is considered to be inactive. prior experience in the subject area. The use case consists
Before boxes of inactive volumes are physically sent to an of all the things contained in identity level (shaded in grey
off-site storage location, a user enters the data associated and truncated by ellipses), as well as:
with each volume into the system. The use case that • The full main scenario to one level of detail
supports this is called Create Volume. Other use cases • The list of important failures, without resolution
associated with this system support the correction of data details
entry errors, and the tracking of the location of the volume • The list of important alternatives, without details
and box as it moves from point to point. Note: this system The standard use case template is modified slightly to
was not actually part of an Agile RFP Process as accommodate the overlaying of stories onto the use case.
described in this paper, but it is one of the few real For example:
examples that the author is able to make public.
Create Volume: …
2.3.1. Identity Level. This level identifies the system Pre-Condition …
behavior. A use case at this level contains enough Success …
information to allow the reader to unambiguously Failure …
recognize the requirement, assuming the reader already Story Description
understands it. This level is typically used for identifying S1.Basic 1. User enters volume information.
system scope and for preliminary assessment of the Functionality 2. User requests that the
existence of behavior in an existing system. Due to the information be saved.
lack of details, it is not recommended as the basis of 3. System validates information.
estimation or custom development. The use case consists [F2. User Input Validation]
of the following elements: 4. System saves information in a
• Description of the users goal new Volume and places Volume
• Expected system state before the use case begins in archived state.
• Expected system state after the use case succeeds or 5. System adds the Volume to the
fails designated Box.
For example: 6. System adds the Volume to the
designated Chart.
Create Volume: A Volume is entered into the system 7. System records the transaction in
for the first time. The user is prevented from creating a the audit log [G1. Audit]
duplicate volume. If the box and/or chart specified by S2. User [3] Duplicate Volume
the user do not already exist, the system will create them Input
as a side effect. Validation [3] Missing information

G1. Audit [7] Log Transaction


S3. Auto- [5] Box doesn’t exist
create [6] Chart doesn’t exist

Example 2 Outline Level


The main scenario represents a single story. For S3. Auto- [5] Box doesn’t exist
completeness, all steps for the main scenario are create a) System creates Box
described, even though some are optional (e.g. steps 3 and b) System records transaction in the
7). One or more alternate / failure scenarios are grouped audit log. [G1. Audit]
together into a story. Some stories span multiple use c) Use case resumes at step [5]
cases (e.g. Audit). A different numbering scheme may be [6] Chart doesn’t exist
used to consistently reference the general stories across all a) System creates Chart
of the use cases (e.g. G1 = general story 1). b) System records transaction in the
To further reduce ambiguity and misinterpretation, an audit log. [G1. Audit]
initial business object model may be developed to create a c) Use case resumes at step [6]
common glossary. The details for the important business
rules are also documented. Only the concepts mentioned Example 3 Detail Level
in the use cases and business rules are defined in the The business object model is enhanced as appropriate.
glossary. All of the business rules are documented.

2.3.3 Detail Level. This level provides the reader with 2.3.4. Acceptance Tests Level. This level adds specific
the full details of the system behavior. Typically this acceptance test cases for each story contained in a use
level is useful for facilitating an estimate when there is case specified at detail level, thus enabling the recipient to
some prior experience in the subject area. This is unambiguously determine whether the requirement has
commonly viewed as the minimum level needed to base been met. This level is valuable when assessing a
out-sourced custom development on. The use case system’s compliance with a requirement. This is the
consists of all of the things contained in outline level recommended level for estimation of custom development
(shaded in grey and truncated by ellipses), as well as: when there is little or no prior experience in the subject
• All of the failures, with resolution details area. A beneficial side effect of developing the
• All of the alternatives, with details acceptance tests is to find holes in the use cases. The use
For example: cases can then be updated to be more rigorous and
correct.
The number of acceptance tests for a story is a
Create Volume: … function of the number of input parameters and the
Pre-Condition … number of different pre-condition states that apply. A
Success … minimum set of tests that provide full coverage can be
Failure … constructed through careful analysis of the unique and
Story Description significant combinations of these variables. For example,
the list of tests for the sample use case is:
S1.Basic ...
Functionality
S2. User Input [3] Duplicate Volume Story Tests
Validation a) System detects another Volume S1.Basic Basic success test
with the same chart number, Functionality
volume number and site.
b) System informs the user of the S2. User Input Duplicate volume test
error. Validation
c) Use case terminates. Invalid input tests (one per input field,
[3] Missing information and one per combination of fields)
a) System informs the user of the G1. Audit Log Enhance the other tests a new post
missing fields. condition indicating how the audit log
Use case terminates. should have been changed
G1. Audit Log [7] Log Transaction S3. Auto- Auto create chart test
a) System asks Logging System to create Auto create box test
record the transaction providing:
creation user and creation date, Auto create box and chart test
and sets version number to 1.
b) Use case resumes after step [7] Example 4 List of Tests for Create Volume
An acceptance test should be written declaratively, as
it is a specification for setting up the preconditions and
verifying the expected results [5]. It should not include enough information to respond with credible, accurate
any details relating to how these activities are done, estimates.
leaving all options open to how the data is created (real-
production data, pre-created local / global test fixtures,
clean slate approach, etc) and how the tests are performed Identity Level
(e.g. manually, or automated through any number of
mechanisms, e.g., FIT, xUnit, record & playback, etc). An
example specification for one of the acceptance tests
listed above is: a. enough
yes
detail?

S1. Basic Functionality: Basic Success Test


no
Pre conditions
Box1 Exists, contains Volume1
Outline Level
Chart1 Exists, contains Volume1
Volume2 Does not exist
Process Parameters
b.
Box # 1 complex?
no

Chart # 1
Volume # 2 yes
Patient Name <unique string>
c. life /
Year Last <ten years ago> mission no Detail Level
Contact critical?
Archive Date <today>
Post conditions yes

Volume2 Exists with appropriate patient Acceptance


Tests Level
name, year of last contact and
archive date Figure 1 Custom Development Decision Tree
Box1 Contains Volume1 and Volume2
All use cases for the target system are initially
Chart1 Contains Volume1 and Volume2 developed to identity level. There is no need to further
develop common stories (e.g. save, print, open, etc)
Example 5 Acceptance Test beyond this first level (a). Unique stories that are easily
understood (b) are described in less detail than those that
2.4. Decision Making Strategy are more complex (c). Life / business critical
requirements (c) are specified at the greatest level of
Acceptance tests level represents much more detail and detail. The number of requirements defined to each level
several orders of magnitude more effort than identity level of detail varies from system to system, depending on the
one, so it is important to have an effective strategy for nature of the system itself.
assigning a target level to each use case. A number of Figure 2 depicts a different decision-tree used for
different forces should be considered when making the making the final vendor product selection from a short list
assignment, such as the: familiarity, uniqueness, of vendors / products. The driving force behind the
complexity, business-criticality, and life-criticality of the decision making process is to facilitate answering two key
requirement. These considerations are typically linked questions. The first question is: how much information is
together into a decision tree to help guide the decision required to determine whether the vendor product meets a
making process. Each RFP process must review the requirement? The follow up question is: if the vendor
forces relevant to their circumstances and define a product does not meet the requirement, how much
decision tree accordingly, as the next two examples information is required to produce an accurate estimate
illustrate. for custom development?
Figure 1 illustrates a simple decision-tree that is used
to determine the level of detail for each requirement for a
custom out-sourced system. The driving force behind the
decision making process is ensuring the vendor has
Identity Level Step 2: Prioritize. Assign relative business value to
each of the requirements as a way to prioritize the rest of
the work.
Step 3: Evaluate. Assign target level of detail to each
a. Vendor
yes
b. Industry requirement in order to develop the requirement to just
supported? Standard? enough detail for the purposes of the RFP.
Step 4: Complete. Finish writing each requirement to
no, (must develop) the target level of detail. This work proceeds in priority
order during time-boxed iterations.
no The three key roles in this process are customer,
Outline Level
business expert, and requirements analyst. The customer
knows the business priorities for the system and makes
strategic planning decisions. The business expert
c. understands the requirements and can articulate them.
Developed vendor
By?
The requirements analyst is skilled at facilitating and
recording the requirements as use cases / stories. Several
in house passes will be made over the list of use cases in order to
properly account for the orthogonal concepts of business
value and level of detail. Business value determines when
d. Can we e. Critical /
estimate?
no
complex?
a requirement will be captured, level of detail determines
how much of the requirement is captured.
yes ye
no s
3.1. Sketch the System
Acceptance
Detail Level
Tests Level
The first step is to sketch out the skeleton of the
Figure 2 Package Software Decision Tree system in order to clearly understand the breadth of its
capabilities. Develop a simple context diagram [4] to
As before, all use cases for the target system are identify all of actors (human and computer) that will
developed to identity level. The first question, assessing interact with the system. Capture the goals of the actors
vendor support of the requirement (a), is answered at a as user-goal use cases [3] written at the identity level, as
high level, for example by reviewing product previously described. The user-goal use cases summarize
documentation or talking to the vendor representative. the core capabilities of the system that satisfy measurable
Industry standard stories (b) that are well known, and business goals in that they automate the steps of a business
widely supported are minimally specified. Unique stories, process. As a rule of thumb, expect roughly ten to thirty
which require custom development (c), are specified in user-goal use cases for a typical business system. For
greater detail. In-house development of familiar example:
functionality (d) requires less detailed specifications
because prior experience can be used to guide the Actor Goals User Goal Level
estimates. Highly complex or life / business critical Use Cases
requirements (e) are specified at the greatest level of Archiver Enter data • Create Volume
detail. Quality Verify data • Create Volume
Control entered correctly • Update Volume
3. An Agile RFP Specification Process • Update Chart
• Update Box
If applied judiciously, the target levels of detail and the Supervisor Send box to • Update Box
decision tree can prevent the waterfall approach to the storage State
RFP specification stage. The agility of the RFP process Manager Track progress • Get Activity
can be further increased by marrying the concepts of use
Report
case and story and by applying XP planning game
Requestor Retrieve archived • Update Volume
concepts to the requirements specification stage.
volumes / boxes State
A high level summary of the Agile RFP Specification
• Update Box
Process is:
State
Step 1: Sketch. Define the breadth of the system’s
capabilities at a high level. Example 6 User Goal Level Use Cases
3.2. Prioritize the Requirements Use Case Business Value Level
Create Volume must acceptance tests
The customer ranks each use case in terms of its Update Volume must acceptance tests
overall business value. At this stage of the requirements Update Chart must outline
planning game, the use case as a whole is assigned Update Box must outline
business value. The priority of a requirement determines Update Box should identity
when it will be specified. The highest priority State
requirements will be developed first; if time runs out the Update Volume should identity
lower priority requirements may not be developed to their State
actual target level. The fact that the use case contains Get Activity could identity
multiple scenarios, each of which potentially has a Report
different business value is taken into consideration later if
necessary. An example of a simple business value priority Example 8 Assign Level of Detail to Use Cases
system is: All use cases that are assigned identity level are now
• Must Have (High): essential functionality to support essentially finished. Next, develop the remaining use cases
the core business goals; the system has no value to the outline level of detail in order to expose the stories
without it. contained within the use case. Finally, use the decision
• Should Have (Medium): necessary functionality but tree to assign a target level of detail for each story, instead
not core; important functionality that improves the of a single level of detail for the use case as a whole. The
efficiency of the business. following example extends the previous one by including
• Could Have (Low): functionality that makes the the stories and assigning the level of detail to each story:
system easier to use; there are alternate ways to meet Use Case / Story Business Value Level
the need (some of which are manual). Create Volume must
• Not Needed: functionality is not required. These use S1. Basic Functionality detail
cases should be dropped from the list immediately. S2. User Input Validation detail
For example: S3. Auto Create acceptance tests
Use Case Business Value Update Volume must
Create Volume must S4. Basic Functionality detail
Update Volume must S5. User Input Validation detail
Update Chart must S6. Auto Create acceptance tests
Update Box must Update Chart must
Update Box State should S7. Basic Functionality detail
Update Volume State should S8. User Input Validation outline
Get Activity Report could Update Box must
Example 7 Assign Priority to Use Cases S9. Basic Functionality detail
S10. User Input Validation outline
3.3. Assign Target Level of Detail Update Box State should identity
Update Volume should identity
According to their business value priority order, the State
use cases are again reviewed and assigned a target level of Get Activity could identity
detail using the decision tree as a guide. Many different Report
stakeholders will be involved in this decision-making G1. Audit should detail
process including: customer, business expert, vendor, and
internal IT staff. For a large system with many scenarios Example 9 Assign Level of Detail to Stories
associated with each use case, it’s worth employing a Even for a very simple example like this, the finer
multi-step approach to the decision making process. The grained level of analysis results in a considerable
first step is to determine the level of detail for each use timesavings in the overall requirements specification
case. The following example extends the previous one by stage. Notably, the initial assessment of the Create
adding the ‘Level’ column: Volume use case resulted in acceptance tests level.
Further investigation indicated that only in one out of four
stories actually requires acceptance tests – a substantial
savings in time.
3.4. Complete the Requirements Example 10 Assign Priority to Stories
While the stories will continue to be packaged together
The team now has enough information to develop a into a single use case document, they may be developed at
release plan for the RFP specification stage. Consistent different times in addition to their different levels of
and credible estimates for the RFP Specification stage can detail. Now the finer grained list is re-sorted based on
be achieved by creating benchmark estimates, which are business value and the release plan negotiations resume.
established through a requirements spike. The time taken The release is broken down into iterations to enable
to capture one of the typical use cases / stories to each of refinement of the plan based on measured velocity.
the target levels of detail is recorded. In XP jargon, these
The actual work of requirements specification
benchmark values become yesterday’s weather. The
proceeds with the customer on-site for interview sessions
remaining requirements are estimated based on a
and just-in-time consultation. The concept of pair-
complexity comparison – use the benchmark estimates if
development is also relevant to the requirement
the complexities of the requirements are comparable,
specification phase. Pairing two customers having
otherwise adjust the estimate accordingly.
knowledge of the same subject area improves the
The remainder of the planning game follows fairly completeness and accuracy of the information given to the
closely to the original. Use cases / stories are ‘fit’ into a business analyst. Pairing business analysts as they
time-boxed release based on business value and estimated document the requirements improves the quality and
time. If the estimates exceed the allotted time, a finer consistency of the use cases.
grained approach to planning is required. The high It is useful to capture the requirements as an XML
priority use cases targeted to outline level or greater are document, and create at least two XSL style sheets to
given a finer grained priority. Each story within the use format the information. One style sheet creates a
case is assigned it’s own business value. The following summary of the requirements, containing use case / story
example extends the previous one by assigning business name, priority, and a link to the detailed information.
value to each story: This style sheet may also group or sort the stories
Use Case / Story Business Value Level independently of the use case they are associated with, for
Create Volume example the stories may be sorted based on their priority.
S1. Basic must detail This summary view acts as the vendor’s worksheet, and
Functionality may include other columns, for example, vendor estimate.
S2. User Input should detail The other style sheet formats each use case as a whole,
Validation with each story taken to its target level of detail, much like
S3. Auto Create must acceptance tests Examples 1 – 4.
Update Volume
S4. Basic must detail 4. An Agile RFP Evaluation Process
Functionality
S5. User Input should detail The principle focus of this paper is on the
Validation requirements specification stage of the RFP process. This
S6. Auto Create must acceptance tests section provides some high level guidance for optimizing
Update Chart the evaluation stage when the RFP is focused on selecting
S7. Basic must detail package software. The evaluation stage of an RFP for
Functionality selecting package software can be time consuming, as the
S8. User Input should outline vendor system is evaluated for compliance against the
Validation stated requirements. In these cases, it is advisable to take
Update Box advantage of the business value and target level of detail
S9. Basic must detail assigned during the specification stage. Use cases /
Functionality stories with high business value are evaluated first. These
S10. User Input should outline requirements are frequently associated with go/no-go
Validation decisions; the remainder of the evaluation may be
Update Box State should identity terminated if the vendor does not satisfy one or more of
Update Volume should identity these key requirements. Business value also determines
State who does the assessment: the company typically assesses
Get Activity could identity high business value requirements; the vendor may be
Report asked to self-assess medium or low business value
G1. Audit should detail requirements.
The level of detail associated with the requirement approaches were merged together. Stories were
suggests the techniques and level of rigor used to assess embedded within the structure of a use case to facilitate
compliance. For example: fine-grained control of the timing and level of detail of the
Identity Level. Reading the available product requirements specification phase, while preserving the
literature and talking to a vendor representative may be detail and big-picture inherent in a use case. This
sufficient for determining compliance. prepared the way for using the planning game (business
Outline Level. Hands-on usage of the product is value, estimating, velocity, yesterday’s weather, releases,
performed to verify that the main scenario of the use case iterations, spike, etc) to bring more rigor and accuracy to
is properly executed. Simple verification is performed to the planning of a requirements-centric project.
ensure that the product detects the failure conditions; the Furthermore, it enabled the process to adapt to changes in
handling of the failure conditions is not emphasized. requirements and/or priorities as they occur during the
Detail Level. In addition to the assessment done at requirements specification stage. Introducing many of the
outline level, the product is used hands-on to verify the other non-programming XP practices in the RFP process
proper handling and resolution of: failure conditions, substantially increased the efficiency and quality of the
alternate scenarios and the stated business rules. This RFP document. On-site customer and pair development
verification is ad-hoc because formal acceptance tests improve the quality of the information captured in the
have not been developed. requirements specification. And finally, including
Acceptance Tests Level. The acceptance test suite is acceptance tests in RFP as appropriate, substantially
executed. This involves setting up the data required for improves the communication of critical requirements.
the specific scenarios, and using the product to execute When should we play matchmaker? When should we
the story under test and verify the results. If time, money, stay well enough alone? When contemplating the
and technical considerations permit, the acceptance test purchase of a vendor package that represents a significant
suite may be automated to ensure continual compliance as investment, the company’s choice must be made carefully
the product evolves. based on an accurate vendor response. Hence the
The results of the assessment are recorded according requirements included in the RFP must be complete and
to whether there was a fit (full compliance of the unambiguous. At the same time, a cost-conscious
requirements), or a gap. A gap can be more explicitly company aims to streamline the RFP process as much as
categorized as: partially met (part exists and is correct, possible. The Agile RFP Process attempts to satisfy the
part does not exist), incorrect (exists but is incorrect), and competing goals of comprehensiveness and cost
does not exist. The final stage of the vendor evaluation is effectiveness while specifying the requirements for an
the analysis of the list of complete and partial gaps. The RFP.
business value associated with the unsatisfied requirement The good news is that the RFP process can be made
guide the assessment of the gap. more cost effective through the application of agile
The gaps for the highly valued requirements are practices. This paper also presents the case that better
examined first. These requirements must be met, thus vendor choices are made as a result of this approach
time is allotted to considering if they can be satisfied. because there is specific guidance about how to specify
Some complete or partial gaps may have to be filled by and evaluate the key requirements. Finally, although XP
custom development. The XP planning game can be was intended for programmers, the concepts and
employed to explore and estimate the cost of this custom principles are more widely applicable. The Agile RFP
work. The developer role for the planning game could be Process is just one example where a non-programming
played by internal IT staff, the vendor and/or third party activity can make use of the insights and practices offered
organizations, depending on who is best suited and/or by XP.
most cost effective to do the work. The use case may
have to be taken to more detail in order to facilitate the 6. Acknowledgements
estimation process.
The author would like to thank the clients whose projects
have provided the opportunities to gain the experiences
5. Conclusions described here. Special recognition goes to Peter Arato
and Michael Davis from Canadian Pacific Railway: their
First, a recap of the questions the paper set out to
engaging questions and insightful comments are at the
address.
core of these ideas. Special thanks also goes to The
What if we introduced these two strategies (RFP and
Calgary Health Region (Gladys Glowacki, Peggy
agile) to each other? Are they compatible? Would their
Colborne, Diane Talbot, Carmen Kubbernus and Ron
union achieve synergy and yet preserve their original
Fitzpatrick) for permission to use excerpts from the
essence? The best qualities of two different requirements
Offsite Chart Tracking Application analysis model to as
the basis of the example used throughout the paper. The
author also thanks the colleagues who reviewed and
commented on drafts of this paper, in particular Gerard
Meszaros and Lougie Anderson.

7. References
1. Ono, Taiichi, Toyota Production System: Beyond
Large-Scale Production, Productivity Press, 1988.
2. Beck, Kent, Extreme Programming Explained,
Addison Wesley, 2000.
3. Cockburn, Alistair, Writing Effective Use Cases,
Addison Wesley, 2001.
4. Fowler, Martin, UML Distilled: Applying the
Standard Object Modeling Language, Addison
Wesley, 1997.
5. Meszaros, Gerard, Shaun Smith and Jennitta Andrea,
“The Test Automation Manifesto”, XP Agile Universe
Conference, 2003.

S-ar putea să vă placă și