Agile Testing: Key Points for Unlearning

January 27, 2012

8

"He who knows to unlearn, learns best."

— Anonymous

When quality assurance teams and management who have adopted Agile practices first put the ideas to work, they face a significant impediment in unlearning the traditional mind-set and practices that experience in traditional practices has instilled in them.

The following are some of the key aspects that need to be unlearned before attempting to deploy Agile practices, from a QA perspective:

  • The testing team needs to be independent and independently empowered in order to be effective.
  • Without a separate test strategy and test plan, it's tough to manage testing.
  • The V-model for verification and validation cannot be applied in an Agile sprint.
  • Independent testing teams don't do white-box testing.
  • The value of testing is realized only when defects are logged.
  • Automation is optional and is required only when regression testing is needed.
  • Testing nonfunctional aspects, such as performance of the system, is not possible in a sprint.
  • Testing must follow planning, specification, execution, and completion sequentially.
  • We don't have to write new test cases for detected defects.
  • Poorly written code is not the testing team's focus, as long as the code addresses the required functionality.
  • Test-process improvement models do not address aspects of Agile testing.

Let's look at these assertions one by one.

The testing team needs to be independent and independently empowered in order to be effective.

Traditionally, testing teams have had followed different organizational styles: having no independent testers while developers perform the testing, having independent testers within the development teams, having independent testing performed by a separate division within the organization — even outsourcing independent testing. Often the testing team would like to be empowered and report directly to a senior project manager rather than to the development or the technical lead. The logic, or at least the perceived logic, is to allow the testing team to report and escalate technical defects without potential inhibitions from the technical lead.

The Agile testing mind-set change that's required is that the testers are an integral part of an Agile team. Their focus is to deliver a quality shippable product at the end of each sprint and to achieve the "done" state for the backlog items committed without any technical debt. The testers report to the Agile team and are accountable to the product owner or the business.

Without a separate test strategy and test plan, it's tough to manage testing.

A test strategy document can typically be defined at the organizational level, the division or portfolio level, or even at the product level. Seldom must the test strategy be defined for each project, unless the project is large and the duration spans many years. The project-specific test approach is documented in the test plan for the project.

In the case of Agile projects, the test approach can be documented in the release plan, and the sprint-specific testing activities during sprint planning. A separate test plan may not be required. However, having a test strategy at a level higher than the project could be useful, especially when the organization is undergoing transformation to Agile. The test strategy can define the Agile testing practices and the techniques to be followed across the organization or division; subsequently, Agile teams can adopt one or more of these practices while defining the test approach in the release plan for the particular project.

The V-model for verification and validation cannot be applied in an Agile sprint.

Within an Agile sprint, verification and validation are addressed by adopting Agile practices, such verifying whether INVEST criteria for documenting requirements is followed, creating and reviewing evocative documentation and simple design, reviewing visual modeling, holding daily stand-up meetings, reviewing radiator boards, following continuous integration, refactoring, running automated development tests and automated acceptance tests, holding focused reviews, and enhancing communication by having the product owner and customer on the team.

The following figure shows an Agile V-model for verification and validation, as compared to the traditional V-model:

Independent testing teams don't do white-box testing.

Independent testing teams traditionally focus on black-box testing, possibly shrugging off any responsibility related to low-level testing. However, in Agile projects, testers play a significant role in automated development and acceptance tests. Agile testing is continuous and seldom staged. Agile testers need to understand the design and code-level aspects in order to effectively perform testing for a sprint. While the developers take the lead in unit testing, the Agile testing team shadows the low-level testing efforts and leads the automation aspect.

The value of testing is realized only when defects are logged.

While the value of testing lies in early detection of defects and ensuring that the shippable product is of good quality, Agile teams need to unlearn the defect numbers-game mind-set. Teams may perceive that more detected defects indicates better performance of the testing team. As a result, many cosmetic defects are logged.

This should be managed. The Agile testing team directly contributes to the "done" state of the product backlog item, which essentially means that a backlog item cannot be considered done unless it passes testing. Agile testing teams must make use of the radiator boards to effectively radiate the information on the status of the backlog items.

Automation is optional and is required only when regression testing is needed.

Automation is not optional; it's an essential aspect, especially when the business is trying to improve the time to market for its products. Agile teams working at peak velocity adopt such practices as continuous integration, automated development tests, and automated acceptance tests. Without automation and application of tools, the team cannot achieve the desired agility.

Testing nonfunctional aspects, such as performance of the system, is not possible in a sprint.

Sometimes it may not be possible to perform testing of nonfunctional aspects, such as system performance, within a sprint. However, this can be addressed by having a separate release sprint during release planning. The release sprint can address the required nonfunctional testing and also perform a cycle of acceptance testing to ensure that the system works after any defect fixes. Rigorous integration testing may not be required if the system was continuously integrated and tested by leveraging automation.

Testing must follow planning, specification, execution, and completion sequentially.

The aspects of planning, specification, execution, and completion are highly relevant in Agile testing. However, we need to understand that Agile testing is continuous, not staged. While one backlog item may be marked "done," another item could be in its specification stages. Some teams follow the practice of updating a backlog item as "done" only when the test cases are automated for the backlog item.

We don't have to write new test cases for detected defects.

Traditionally, it hasn't been a practice for a test team to go back to specify a test case for a detected defect, especially for defects detected during exploratory testing. One of the key pain points for not doing so is the process of re-baselining the test case document and running around for signatures, since this is a change from the planned baseline. However, adapting to change is one of the Agile framework's foundational aspects. In Agile testing, new test cases are specified for detected defects that don't already have an associated test case, and the test case is subsequently included in the automation test cases suite.

Poorly written code is not the testing team's focus, as long as the code addresses the required functionality.

This is related to the point above ("Independent testing teams don't do white-box testing"), that independent test teams traditionally focus only on black-box testing and may be unconcerned with the quality of the code as long the code performs the required functionality. But the value add from the testing team can be significant if it can provide early feedback and also identify technical debt by focusing on the code-level aspects during verification and during validation or testing. This is one of the key Agile-testing mind-set changes required for a new Agile tester.

Test-process improvement models do not address aspects of Agile testing.

In fact, we do have the ability to measure and improve Agile testing, using standard industry models. Test-process improvement methods such as TPI NEXT advocate business-driven test process improvement in an Agile environment by prioritizing the key areas of focus. This facilitates an Agile testing mind-set by mapping Agile principles with specific, prioritized areas. TPI NEXT also provides specific "improvement suggestions" for the checkpoints in priority areas of Agile testing.

Conclusion

Although the task of performing testing is not very different in principle in Waterfall, iterative, or Agile, the Agile mind-set and its testing practices provide effective new means to achieve the desired results. The agility lies in the Agile practices, rather than in the overarching process itself.

Share on Facebook    

Article Comments

  1. Amit Garg said on 28 Jan 12 12:14:
    Many think of agile sprints as a 'mini' Waterfall. The aspect of testing especially is perceived to be functional and non-functional testing stacked in a staged manner within a sprint and not continuous. The Agile V-Model summed it all well. The unlearning is the key...
  2. Sanjay Sudhakar said on 29 Jan 12 21:15:
    I personally faced challenges when my team did not unlearn the defect numbers-game mind-set which affected the entire team's balance. This if managed well along with QA folks who are creative in performing exploratory testing would make the quality of deliverable extremely good.
  3. Sanjay Sudhakar said on 29 Jan 12 21:15:
    Great article especially for those who perceived agile testing as a separate activity. As Amit said Agile V Model summed it all well.
  4. Subramani Dharmar said on 30 Jan 12 10:30:
    Good article to know the things that we need to unlearn before moving from waterfall model of testing to Agile Testing.
  5. Madhu Venantius Laulin Expedith said on 07 Feb 12 14:13:
    Posting a comment from a colleague, Sathianarayanan: One of the crucial aspects of a team which implements agile process is to get the test team buy-in. We faced severe difficulties in this area as they were resistant to changing their existing processes by simply saying "This will not work for us. Let dev team follow their own processes and we will adhere only with the timelines". Finally higher management had to step in to enforce this.
  6. Dr. Sanjeev Raman said on 08 Feb 12 19:10:
    I managed a project for a major retail client HQ in the West Coast. Our goal was to release dozen retail e-commerce sites in multiple languages. When I took the project over from a previous PM, I was forced to work with their offshore QA model. To make a long story short, I agree with every point you made in this article. I was given an onsite QA Lead to be on my "Scrum" team and he was responsible for coordinating all the QA testing for each sprint. Ironically, he was a certified scrum master (CSM) but he insisted on a black box, manual testing approach and only committed to doing QA when we were "code complete" for each sprint. Given that their QA team out numbered our Scrum team 3 to 1, we could not fix all the bugs within the timebox sprint to complete the stories, which put us in a very difficult situation. Another issue with their testing approach is that they gave no consideration to troubleshooting what the root causes were for the defects nor did they believe in automation. Their attitude was that the "developers" has to figure it all out, fix everything, and give us a clean build to retest. Most of our requirements were around data and permutations and they insisted to test each of the 6,000 permutations manually by scaling up more people offshore. (I brought in a highly skilled data analyst and we automated the testing within a week but faced strong opposition in the process). I raised all these concerns to the Director of QA and how we need to be more agile (and even outlined a transitional plan). But, given the bureaucracy and her wanting to do empire building, she was not interested in my concerns. In the end, as I was leaving, they brought a certified scrum coach (CSC) to work with a new PM. The last I checked, the only retail e-commerce sites to go live were the ones I managed when I was there and its been several month since I left...
  7. Madhu Venantius Laulin Expedith said on 12 Feb 12 23:49:
    Thanks for all your comments. QA Organizations strive to be on the critical path for the minimum time-span. Testing team potentially will be on the critical path for the longest duration if traditional mindset is not unlearned and this may cause significant delays in the release of the software.
  8. Bill Rinko-Gay said on 16 Feb 12 08:39:
    As a QA manager with over 30 years' experience, I find the entire development team needs to stop thinking of QA as a separate activity. Within the Scrum team, quality output is part of the definition of done. The team is as much on the hook for writing code that can be tested automatically as it is for automating the tests (note, I am not dividing the team into developers and testers on purpose). There may need to be testing when the work of multiple teams is integrated, but that is still part of the whole process, not a separate test activity. One of my greatest success stories came about in a non-Agile world only when the Development manager recognized his role in good quality assurance, and re-architected his entire code base for testability. We went from being unable to produce a quality release in 9 months to producing high-quality releases every 6 weeks, and that without Agile. Just imagine what an Agile team can do when it doesn't remove QA from the development domain.

Please login to comment on this article.