As promised, how to Escape The Oubliette…
So here you are, part of a team at the bottom of the defect & debt pit. What now?
The simple fact is, there’s no one answer but there are a selection of tools and there is a key.
The key comes courtesy of a comment from Jim Highsmith during one of his sessions at Agile 2010 – my paraphrasing below…
“Teams facing technical debt need both debt reduction and debt prevention strategies.”
When teams face technical debt they pick away, removing it piecemeal. After all, you have to eat an elephant one bite at a time right?
Trouble is, that only works if the elephant isn’t growing as fast as you’re chewing.
You need a two-pronged attack – what I like to call “topping and tailing”. The “top” is all the incoming issues and build-up of new debt. This is where you need to stop the bleeding. The “tail” is the backlog of existing debt. It’s already there – gently rotting in the corner of your product.
Topping
If you’ve read my post on stopping the bleeding, this is the crux of “topping”. You may have a variety of strategies for this but here’s the fundamentals.
Incoming Customer Defects
Ringfence enough capacity to address defects as soon as they come in. Make sure your burn rate matches your incoming rate. If you’re strapped, it’s your call whether you only cover high severity issues but for my money, I’d hit them all. A multi-year build-up of low severity issues makes products ugly, no pleasure for the users and a series of minor problems rapidly becomes a major burden and a big debt buildup.
Addressing every incoming defect doesn’t mean fixing every one. Whilst I generally recommend you do, when trying to dig yourself out of an oubliette the bigger issue is how to keep your goal achievable.
Be critical. The big, nasty bugs are usually pretty obvious but what about the rest?
-
- Is it low severity and not important?
- Is it quick & cheap to fix? – Just fix it.
- If it’s not – Can you put a safety rail around it? Document it as a limitation or even ignore it?
- Is it low severity and not important?
Negotiate with your customers and make an explicit decision to fix now or never. Once decisions are made, communicated and agreed, close the defects in your backlog.
Getting these conversations happening immediately makes customers far happier than pretending they’ll just go away and never making a decision. (but not quite as happy as fixing their issues).
Incoming Internal Defects
The story here is the same. I’ve called it out independently as many companies and teams do.
Those incoming internal defects speak volumes about your approach to quality.
Get the discipline in place to fix them when you find them or be brutal and admit which ones will never be fixed but don’t pussyfoot around!
- If you provide a service to other internal teams, treat them as customer defects.
- If they’re raised by your own team, are they on new code or exposing existing issues?
- On new code, fix them! – No excuses .
- On existing code, the problems are already there. You need to decide if what you’ve done has made it more visible or harder to work with than before and make a judgement call. Fix now or never, resolve or close.
In the next article in this series I’ll cover debt prevention…