Thursday, July 31, 2008

What can be done if requirements are changing continuously?

What can be done if requirements are changing continuously?

A: Work with management early on to understand how requirements might
change, so that alternate test plans and strategies can be worked out in advance.
It is helpful if the application's initial design allows for some adaptability, so that
later changes do not require redoing the application from scratch. Additionally, try
to...

Ø Ensure the code is well commented and well documented; this makes
changes easier for the developers.

Ø Use rapid prototyping whenever possible; this will help customers feel
sure of their requirements and minimize changes.

Ø In the project's initial schedule, allow for some extra time to
commensurate with probable changes.

Ø Move new requirements to a 'Phase 2' version of an application and use
the original requirements for the 'Phase 1' version.

Ø Negotiate to allow only easily implemented new requirements into the
project; move more difficult, new requirements into future versions of the application.

Ø Ensure customers and management understands scheduling impacts,
inherent risks and costs of significant requirements changes. Then let
management or the customers decide if the changes are warranted; after all, that's their job.

Ø Balance the effort put into setting up automated testing with the expected effort required to redo them to deal with changes.

Ø Design some flexibility into automated test scripts;

Ø Focus initial automated testing on application aspects that are most likely to remain unchanged;

Ø Devote appropriate effort to risk analysis of changes, in order to minimize regression-testing needs;

Ø Design some flexibility into test cases; this is not easily done; the best
bet is to minimize the detail in the test cases, or set up only higher-level
generic-type test plans;

Ø Focus less on detailed test plans and test cases and more on ad-hoc
testing with an understanding of the added risk this entails