There is a perception in the software development fraternity that Agile Is Good; Waterfall Is Bad. Here the notion of “Agile” is often intrinsically linked to software delivery and involves Stand-Ups, Scrums, Sprints, Epics, User Stories and other artifacts. And yet Agile-run projects still fail to deliver! How can that be? The simple answer is often because there is a fundamental misconception as to what matters when you undertake to become “Agile”.
I’ve drawn on Frank Sinatra’s apparently extensive experience in Agile development (bear with me) and tried to collate some of the main issues I see with the adoption of Agile techniques that will cause delivery failure. I specifically mention Scrum and Kanban but there are many other buzzwords to choose from including Extreme Programming (XP), Crystal, Dynamic Systems Development Method (DSDM), Lean Development, and Feature-Driven Development (FDD). For reasons that will become apparent I’m not leaning towards any one in particular. So let’s work through some of the key issues that will guarantee your project crashes and burns in a fireball of recrimination and shredded Post-It notes.
The Product Owner
The basic premise of Agile is that it is primarily geared to facilitate user involvement, not to give a software team rules and regulations to guide their daily lives. The list of process components and artifacts should be considered simply tools that are used to manage the user engagement with the process rather than the holy grail of software delivery. Without an engaged and empowered Product Owner (who is either a user or their proxy) your development and delivery process might just as well read:
1. Navigate the maze
2. Ford the moat
3. Slay the dragon
4. Scale the tower
5. Rescue the damsel (or male variant)
6. Get the gold
I chose the words “engaged” and “empowered” carefully. If your Product Owner cannot make time for prioritisation of the product backlog then your development team will be flying blind. I’ve always maintained that if the development team are prioritising workloads (features/bug fixes) then there is a problem. I like to put it simply for the dev team: If developers are prioritising tasks and the release screws up then it’s their fault. If the Product Owner is prioritising them then the blame sits with them and the developers are protected under the CYA principle. If the user cannot make time to review the product at the end of each sprint and provide effective feedback then you risk building on top of wholly unstable foundations and your entire build may need to be refactored some way down the line, potentially at great expense in terms of time and resources. And your development team in general and ScrumMaster in particular will most likely take the blame for the failure of the sprint or project. So the ScrumMaster is key here, as the project “fixer”, in ensuring that the Product Owner’s engagement is adequate. Failure is also near-guaranteed if the Product Owner does not have the full support of the user base in steering the project. An example of a risky plan would be if a team is put together with an externally-hired Business Analyst (BA) to document and present the users’ requirements. It is very hard for someone with no legacy presence in the firm to come in and immediately gain everyone’s trust. It is extremely easy for users to disengage and both users and developers alike to point at the BA when things start to slip. Disintermediation is preferable wherever possible to avert such possibilities.
Focussing On The Detail But Neglecting The End State
Agile is A Bad Idea if you the workload is well defined and you have a hard deliverable and delivery date. This is a sweeping statement that requires clarification. Some agility is fine intra-project, within prescribed boundaries. But if there is a regulatory change coming up and your firm will be out of the market if you don’t ship a minimally viable product (MVP) before the go-live date then there is likely to be zero-optionality as to the content of the MVP. Either it ships (and you get pizza+beer) or it doesn’t (and you get a P45). There may be some degree of optionality with respect to the order in which components ship but the finished product must be compliant. No amount of bells and whistles are going to make up for the fact that you’ve lost regulatory compliance.
A question. Did your organisation plan it’s Windows XP migration using Agile techniques? I’m guessing not. Some projects have a hard, well-defined end-state (e.g. no desktops running XP) and a reasonably clear path to it:
1. Check legal contract permits migration
2. Identify all applications running on XP
3. Build a new Windows 7/Windows 10 desktop image
4. Plan application migration order
5. Plan desktop/user migration
6. Migrate applications to new images
7. Migrate desktops/users
8. Terminate XP support
Although this looks like classic Waterfall. essentially there are opportunities for Agile in steps 4,5,6 and 7. Notwithstanding the fact that we need to understand the overall complexity of migrating all the applications, we could get started immediately; some desktops can probably migrate straight away because they are only running shrink-wrapped software. Other migrations may hit a blocker so will need to move left on the Agile Board. But at all points we need to consider the overarching hard deadline which is the date XP support is withdrawn. It’s easy to focus on the complexities of the current sprint and neglect the complexity of the blockers and the Product Backlog, thus leaving it too late to add to the team’s resources, or introduce an additional team onto the project. Epics can’t sit on the Product Backlog without being broken down into accurate User Stories that can be ascribed effort. When you have to ship on time you really need to know how much work you have left. Clearly I’ve chosen an anomalous example here but it illustrates the point.
Over Prescription
Doing Agile isn’t producing a list of artifacts using a specific toolkit. It’s specifically not prescriptive. The Agile Manifesto is only 68 words long and it’s worth reviewing to circumvent the hyperbole:
“We are uncovering better ways of developing
software by doing it and helping others do it.
Through this work we have come to value:
Individuals and interactions over processes and tools
Working software over comprehensive documentation
Customer collaboration over contract negotiation
Responding to change over following a plan
That is, while there is value in the items on
the right, we value the items on the left more.”
From <http://agilemanifesto.org/>
So according to the Agile Manifesto, Agile is not:
• A methodology
• A specific way of developing software
• A framework or process
• A toolkit
Agile is a set of values and beliefs. There are also a set of 12 principles to support these values. You can read them at the agilemanifesto.org site but essentially they boil down to developing software that satisfies the customers’ requirements (which may change as we go along) as soon as possible. To achieve this business and developers need to be joined at the hip, and developers need to be motivated and trusted. Finally, and this is the key point I want to labour here, the team needs to organise itself and repeatedly reflect on how it could operate more effectively by retuning its processes. So meetings and artifacts are mechanisms and tools to enable the team to follow Agile beliefs. They are not a list of pre-requisites that will dictate the success of a project.
The Process Has To Work For You
You can’t take decisions based on what another team do. Trying to mimic another team won’t work since every team and project is different. Scrum may work on one project, but Kanban might work better on another. Similarly not every component is necessary for every project. In the early days of UML, frustrated by the plethora of artifacts seemingly required, my “fintech” development team instead developed what we called “Booch Lite”. This was a slimmed down version of Booch’s methodology that worked for us at the time. We had a pipeline of bugfixes and enhancements for an equities trading platform and a request list for new feed handlers, each of which was a new development. So it was part production support, part greenfield (or green-ish-field) development. What is key here is that every <team, project> tuple is different, so the components of whatever process you choose can be slimmed-down or cannibalised to fit the machinations of your team and your project. Following the rules verbatim suggests you’re not thinking about the process you’re following, just executing it rote. You will either end up gnawing your own arm off in frustration, waste a lot of time producing useless stuff, fail to deliver in a timely manner, or more likely all three. As a consequence you need to do it your way, and make the process work for your team and project. If it does not, scrutinise and refactor it. Eat, Sleep, Code (and refactor your process), Repeat.
Over-Dependence On Process And Artifacts
An over-dependence on artifacts is a corollary of over-prescription, or at least blindly following a process is. I’m breaking it out as a separate section because there are many organisations trying to sell their process as The One True Faith. Although it pains me to admit it you don’t need a bank of Microsoft Surface Hub 2’s for your Agile board. You don’t even need sticky notecards no matter how many vendors try to sell you theirs just because they have just the right luminescence or range of colours to denote disparate semantics. You need a means of communicating and rendering the status of your tasks. Pick the one that works for you. A physical board of some description is handy because you can huddle round it, but having a something on a shared online medium can work. This is essential when there your team is geographically distributed, although not having the team in the same room is always going to adversely affect performance in many ways (so should be avoided if possible). Naturally this can be mitigated by having a bank of Surface Hubs in each location. I wish you the very best of luck explaining that to your CFO.
Context Switching
Each time a developer has to drop what they’re doing and pick up another task there’s a context switch. Every context switch incurs a cost in terms of time. I am speaking from personal experience having lived-through the frustration of having to mothball a development branch which you know will need to be merged into the trunk with considerable pain at some point in the future. The key to reducing context-switching is to limit Work In Progress. This is the “Dev” column of your Agile board and needs needs to be restricted. It may be that a number of tasks are blocked because you’re failing to communicate properly. It may be that the sprint planning was flawed. It may be that your ScrumMaster sucks. The issues need to be addressed at the Sprint Retrospective if you’re operating Scrum, or at a suitable point such as after the next release if you’re doing Kanban.
Conclusion
Why is it that we even care about Agile? Simply put, because Waterfall is an All-Or-Nothing, Death-Or-Glory gamble. You spend an age and a half planning the process down to the last detail then start the build. There are clearly some well documented weaknesses to this approach:
1. There is little or no opportunity to take corrective action along the way as is the case with Agile. If some detail comes to light part way through the process unpicking Waterfall plans is hugely challenging. Similarly if your user takes a look at the part finished product and wants a change there’s very little room for manoeuvre. With Scrum a subsequent sprint can pick up a remediation task. With Kanban, if a user demo throws up an issue, a remediating task can go into the “To Do” column of the Agile Board more or less immediately.
2. If some of the details of the project are not yet clear, with Agile you can get on with developing some of the components that are known and prioritised by the Product Owner. With Waterfall you’re stuck because you can’t show your milestone plan until you know everything you need to deliver, and therefore risk therefore risk never having a practical delivery date.
In my experience Agile does work well when there’s a Product Backlog comprising various bug fixes and enhancements that need prioritising. This is typically the BAU development process we all know and love, but user engagement remains key to ensuring that the current workload constitutes the most important tasks. Agile can work for standalone software development in general, even with a prescribed completion state, provided there is a realistic and ongoing review of the Product Backlog to ensure the project is adequately resourced.
If I had to pick one, the most crucial takeaway is that for Agile to be a success an empowered and engaged Product Owner is key. Wars over the relative merits of Kanban versus Scrum versus the latest flavour development methodology are irrelevant if you have no direction from the stakeholders. Many developers don’t feel comfortable engaging with stakeholders, but the sooner they learn to communicate the better your product and process will be.
So how is it that Frank Sinatra was a skilled Agile advocate? Because the lyrics to “My Way” are a lightly coded allusion to his experience as a ScrumMaster(*):
And now, the end is near (the Sprint finish)
And so I face the final curtain (project completion)
My friend, I’ll say it clear (and quickly at the Daily Scrum Standup)
I’ll state my case, of which I’m certain (the User Story)
I’ve lived a life that’s full (the “To Do” column of Agile Board)
I’ve travelled each and every highway (to track down the Product Owner for the Sprint Review Meeting)
But more, much more than this (since the Product Backlog is much greater than the Increment)
I did it my way (choosing those artifacts that work for our team and project)
Regrets, I’ve had a few (most notably the tasks that moved left on Agile Board)
But then again, too few to mention (because blockers were removed before the Sprint Review meeting)
I did what I had to do (both following Planning Poker and the Sprint Retrospective meeting)
And saw it through without exemption (all the tasks reached the Release column)
I planned each charted course (to the next product Increment)
Each careful step along the byway (every Post-It through every column through every Sprint)
And more, much more than this (because more tasks were added to the Product Backlog following the Sprint Review meeting)
I did it my way (see narrative above).
(*) Maybe.