The Five Star Regression Suite

The Five Star Regression Suite

If you regularly design, plan & run tests on a software product or solution, you almost certainly have a regression suite of tests that you execute with some frequency.

Depending on your team size and the maturity of your test processes, It's likely that your regression suite is:

  • mostly manual
  • time consuming
  • a bit of a pain to execute each time

...(and yes I know you are working towards automating it, everyone is!)

It's actually not uncommon to see large, naturally risk-averse companies with regression test suites that take 1-3 days (with a team of people) to execute each time.. and if you think that this sounds painful and a waste of time, I agree.

(Waste: noun - an unnecessary or wrong use of money, subtances, time, energy, abilities etc) 

I have seen large test teams complete release regression testing before Thursday lunch then before their sandwich is even digested, start working on the execution for the following Thursday's release.

When do they test new features? When do they plan new tests? Who knows...

"How does this happen and how do we fix it?" you say...

Well I'm glad you asked..lets get into it..

Like anything, these things don't get out of hand overnight, they are the result of lots of small inefficiencies, compounding over time.




In my experience, here are five (not all) of the main culprits:

1. You have weekly releases:

I'm not saying this is wrong, quite the opposite in fact.

The value of 'more frequent' releases is well understood (I'm not going to talk about this here).

I'm just saying, the more frequently you release, the more times you have to execute the regression pack, the more of a burden your regression becomes to the team. Simple maths.

Break up your regression tests into executable modules that you can align to system releases, consider creating a shorter, more aggressively prioritised pack for the occasional 'quick' execution, you'll need it.

2. You have multiple scrum teams working on different initiatives or parts of your solution (some teams may be offshore):

Multiple teams means multiple goals and it can be hard to make one of those goals 'an efficient and effective, centralised regression suite'.

There are:

  • overlapping tests
  • multiple test tools
  • differing data needs
  • training and communication issues

...all of these are challenges that can affect the health of your regression suite (and of those that have to execute it!).

Bring the teams together regularly to discuss the goals of your regression suite and the standards for inclusion. Make one team/group accountable for it's health and usefulness but make the mission clear.

3. It's free entry into your Regression Suite:

Without a quality gate, there's no quality.

Here's the scenario.. you have created a new feature or improved an existing process, and you have created and executed some (maybe lots) of manual and automated tests to prove that feature.

The work gets released to production with no issues and everyone is high-fiving...so far, so good.

You get asked for a set of tests from your test suite top be included into the centralised regression suite (the suite of tests that will be executed each time there is a release on the system in which your feature is built).

Being naturally risk-averse (you're a tester right?) you give them everything you have. I mean, most of it is automated right, how long can it take?

Well..lets say it takes:

30 minutes to execute these for the sake of argument...

Then, multiply this process by however many scrum teams you have (usually between 4-10)... lets say 4 teams

(so 4 x 30 mins = 2 hours).

Then lets imagine you are releasing weekly, a noble and common goal.

So in this scenario you are adding two hours worth of regression tests, to a centralised regression suite, each week.

Assuming you're releasing 48 weeks of the year (allowing for change freezes) thats 48 x 2hrs,

this equals a whopping 96 hours (12 Days) of regression tests added each year!

Trim the fat.

Protect the integrity of your regression pack. Put a quality gate on entry.

4. You don't have a centralised test team responsible for maintenance:

When your teams are aligned to projects there is often no budget allocated for a centralised testing team/function.

Regression suites are not static artefacts, they need to be maintained.

It makes sense that the team that created the tests maintain them but they can't do that when they are busy with the next piece of work.

Having a centralised test team that is responsible for the regression suite allows it to be efficient, effective and maintained to a high standard.

Ownership creates pride, pride creates good work. The opposite is also true.

5. You have the wrong tests

Before you try and make your regression test faster through automation, make sure that the tests you have deserve to be there.

Only high business impact tests should be included, review each test carefully and consider what would happen if it failed, how would the business suffer? How else would this issue come to light? What would the impact be to business revenue and/or reputation?

It can be tempting to include everything but this can quickly get out of hand (as in point 3 above).

If you struggle with assessing priority (and you're trying to reduce the time it takes to execute your regression pack) then use this simple trick;

If this regression test failed would we still go live?

If the answer is yes then strip it out, it's not important enough.




Regression testing is a simple concept, but that doesn't mean that it's easy (to do well).

The most important thing is to strive for the continuous improvement of your regression suite (as with all of your practices and processes).

Keep the conversation open and flowing and invite insights from the team on a regular basis. Discuss what works well, what could be improved etc.

Lets not forget the Grace Hopper quote:

The most dangerous phrase in the language is, 'We've always done it this way.'

Regression testing, when done correctly is the best example of the Pareto Principle at work...

80% of the value from 20% of the effort,

or 80% of the high business impact testing coverage from 20% of the tests.

To view or add a comment, sign in

More articles by Gary "The Defect Doctor" Brookes

Insights from the community

Others also viewed

Explore topics