Projects that use the Agile development process fail 65% of the time versus lean engineering at 21% and a new method called Impact Engineering at 10%, according to a new study conducted for the book Impact Engineering. I was intrigued by headlines about the study—and by the clever marketing technique of using a survey to help sell a book. The marketing worked on me, given that I just bought and read the book.
The Method Itself, Or The Implementation?
The Agile development process was introduced about 20 years ago as a reaction to more strict development methodologies. At that time, multiple rigid and highly serial “waterfall” development methods were most popular. However, waterfall project management was not well aligned to the needs of software development and lacked the means to adjust effort based upon feedback throughout the development process.
Agile was revolutionary because it replaced waterfall’s long development cycles that were planned out potentially months in advance. Agile is based upon short development cycles—often two or three weeks—called sprints. Sprints are highly iterative and have multiple feedback loops built into the process, which means that change and risks are easy to intercept and fix. The increased collaboration this fosters led to a more transparent management style that meshed well with software startups, which were the early adopters of Agile methods.
Over the years, Agile became more robust, and multiple variants (such as Scrum and Kanban) were developed to meet the needs of diverse development teams. But each of these variants holds true to the original Agile principles. Agile processes are now the de facto approach for software development in many organizations of all sizes.
When I dug into the results of the study and the book, I wondered whether the issues were with Agile itself or the improper implementation of it. As someone who’s seen Agile succeed and fail, I have learned that failure is often the result of other factors, rather than the method itself. So I remain somewhat skeptical about the study’s conclusion that a different approach is required. Also, it should be noted that the results came from a survey of 600 developers from the U.S and U.K., so it’s not a global representation of Agile development.
Below are the key findings of the survey, followed by my own thoughts on the study’s validity based on three of its key findings.
Issue No. 1: Being Able To Discuss And Address Problems Quickly
I completely agree that practices that ensure psychological safety will have a significant impact on success. But the way this is presented by the Impact Engineering proponents suggests that Agile does not support psychological safety—which is not true. The whole point of Agile is for issues to be raised as soon as possible in standup meetings and addressed by the right leaders in the organization via a well-communicated escalation process. So is this an Agile issue or an organizational cultural issue?
Beyond that, I have also seen waterfall implementations fail because of a lack of psychological safety. My take is that when leaders and developers embrace Agile, that needs to come with an embrace of an entirely new level of transparency and trust. When a product team is working under the pressure of a date that was set too early in the process, or the team is being punished for unexpected setbacks, leadership can lose the trust required to make any project a success, Agile or otherwise. To put it another way, when devs don’t feel safe to speak their minds, they will not share critical information to ensure that a proactive solution can be found sooner than later.
Issue No. 2: Project Requirements Are Accurately Based On The Real-World Problem
I think a poor requirements definition will impact a software development project no matter which development process is adopted. But again, Agile has mechanisms to handle requirements collection and refinements really well. First of all, a major component of well-implemented Agile is the creation of “epics” and “stories” (which are proxies for requirements). While previous methods stressed the role of a product manager owning a unitary requirements document, Agile is a more collaborative affair, where team leads and architects are involved early as the requirements are documented and prioritized.
Beyond the team, another key aspect of Agile is letting customers and business partners into the process by hosting product demos early and often to gather feedback. This is absolutely essential to make sure the requirements are correct. It helps the development team understand not only the requirements but also the various nuances of how the problem should be solved. If the development team is taking the word of only the product managers and not interfacing directly with the outside stakeholders, the chances of failure are much higher. Again, transparency and communication are the keys to success.
That said, I think that I can understand why this perception exists with Agile, because I have seen it myself. In fact, bad requirements gathering was a critical reason that I, too, was anti-Agile for a while. My experience is that when teams aren’t well trained in Agile, they tend to focus too much on the rapid development aspects. Another part of the challenge is that Agile is often sold as being “faster,” which it can be in the aggregate due to reduction of rework. But my sense is that Agile is really about being “more nimble.” This misunderstanding creates the requirements challenge. That’s because the best way to go faster is to operate a vacuum. However, the best way to be more nimble is to listen and iterate.
Issue No. 3: Not Having To Work On More Than One Project At A Time
I was surprised to see this particular result. When I have worked with Agile experts and coaches, they often note that pooled or shared resources are harder to manage in Agile, and that the developers themselves should shoulder more testing and DevOps responsibilities. The idea is for the Agile team to be small and athletic. This is why Agile can fail in larger organizations that operate in functional silos. So, in this case I would have expected Agile to perform worse—but it didn’t.
However, the book notes that there seems to be a point of diminishing returns. Dealing with two projects at a time is good, but having more than four to juggle seems to have a negative impact. This result also suggests that maybe it’s not so much about having multiple projects versus people being assigned multiple full-time workloads, leading to burnout and mistakes.
Again, Agile has mechanisms for capacity management, and a good scrum master will be able to manage team capacity against burn-down statistics to ensure good balancing—which is not always the case with other development methods. So, upon further reflection, this one may hold up.
My Conclusion: I Just Don’t Think It’s Agile’s Fault
I am very agreeable to the argument that Agile is hard to deploy in many environments and may not be the best answer in every case. In this connection, it’s probably worth noting that I have been beaten up by multiple executives when I have suggested that Agile is the wrong way for their group to operate under a specific set of circumstances. In my experience, these are usually the same executives who want to see work done faster, but have no willingness to invest in the change management—and the candid feedback, including feedback on their own decisions—that’s necessary to make Agile a success.
In short, if you want to improve how you make products or apps, you need to consider every aspect of the organization and what you are trying to achieve before you decide which method to use.
So, What Did I Think Of The Book?
Like I said earlier, while the survey is a clever marketing mechanism, Impact Engineering ended up being less of a new approach and more an indictment of Agile gone wrong. That is unfortunate, since another unique thing about the book is that it uses a fictional storyline about a project to communicate its points. This would have been a very engaging way for the author to couch doing Agile correctly for a non-technical audience—versus making an argument against Agile.
Another miss in the book is that after the happy ending to the story, there is a very thin conclusion that has a very basic call to action. It would have been a lot more impactful to have a couple of chapters after the storyline with tips and tools on how to make Agile projects better. Since the book did not have that, I’ll close with my best three tips to make Agile work.
Getting The Most Out Of Agile
First, there are many variants of the Agile method and not all of them will be the best fit for you and your team. It’s even hard to say that one variant is better for this technology or that one. What determines the best fit is actually the nexus of the team’s workstyle and the technology. I know of an instance where a team started with the Scrum methodology and was failing. They very appropriately took a step back and switched to Kanban; with a bit of effort, the team turned things around.
Second, get help—and not just from consultants. Consultants can advise you in the moment, but your team probably needs some permanent help. My suggestion is to hire an experienced scrum master as soon as possible. That person will be able to set up and manage the right processes and act as an arbiter in times of misalignment. Someone with experience will be able to expertly balance the team’s capacity versus the work to be done, and that will help in the long run with team morale and burnout.
Third, there are no shortcuts. You have to crisply define the roles that people are responsible for carrying out. You need to expect that in the beginning things will slow down and maybe go badly before you get more nimble. And, most importantly, remember that Agile is not just for the team; it’s for the organization. Command and control leadership from the C-suite is the biggest threat to an Agile effort. I would highly recommend training at all levels and coaching for any executive who touches the product. For that, I suggest anything in the Pragmatic Engineering ecosystem.
All in all, I found Impact Engineering and the related survey to be thought-provoking, but I was hardly convinced by its attempt to indict Agile as a methodology.
NOTE: Special thanks to Ryan Daws for publishing the article that inspired this piece.
Read the full article here