Are you ready... here it is... to be agile you must... break dependencies at all costs!
Dependencies are created when any two discrete elements within your organization require each other to do all or part of their job. At the enterprise level, dependencies are everywhere. They are created by the very way we have decided to structure our businesses and how we setup and execute our project work. This makes them very hard to identify and even harder to remove.
I believe that breaking our dependency on dependencies is the core challenge associated with orchestrating any sustainable enterprise agile transition.
Agile transitions don't fail because Scrum is insufficient. They don't fail because people have not sufficiently applied the right XP engineering practices. Our problem is not a fundamental misunderstanding of the Agile Manifesto nor an unwillingness to become the right kind of agile leaders.
While any given organization may have some or all of these problems, they are not our primary concern.
The underlying issue is that agile project management principles, agile engineering practices, and agile leadership philosophies assume you have already eliminated your dependencies! Most teams are trying to become agile without validating that core underlying assumption, no one has even told them they should try!
Think about how we describe our ideal agile implementation...
First, we start with a small team of cross functional individuals with sufficient skills such that anyone can work on any part of the system. Next we allow this team to only work only on a single project during any given sprint.
We then grant this team a dedicated product owner empowered to make decisions on behalf of the business. We allow them to work on small independent functional requirements which can be reprioritized at any time.
We give this team an empowering individual tasked with removing any organizational challenges the team might encounter. We remove any process constraints and allow them to do the work any way they want as long as they deliver working software.
Lastly, we assume they have an object oriented architecture that lends itself to test driven design, continuous integration, and constant refactoring.
This scenario perfectly describes a team with no dependencies. They have 100% of everything they need to get the job done.
Let's look at what many teams deal with trying to adopt agile...
People are typically part of a team of specialists that are matrixed into a cross functional project team. Because these people are specialists, their services are not needed 100% of the time. To maximize the utilization of the individual, they are assigned to multiple projects and any number of teams.
Product owners are doing market research, meeting with customers, and attending trade shows. The team is left with a less than empowered business analyst to make the decisions for the business. In reality, the product owner was just a proxy for a large group of uninvolved stakeholders anyway. No one gets access to real customers or real market data.
Many teams are trying to sprint through product development using a traditional MRD or PRD. They are not using requirements written as functional threads of system behavior that can fully tested at the end of the sprint. These requirements are not able to be reprioritized as we learn more about the evolving system.
Many teams are working with traditional project managers who are doing their best to be agile, but have been trained to manage dependencies and tell people what to do. Even if they want to be agile, they are not usually empowered to do anything about the real impediments the project teams are working through.
Teams are trying to be agile with tightly coupled software architectures, insufficient test coverage, legacy code bases, and unable to do a daily build.
This perfectly describes a team operating under the crushing weight of dependencies created by flawed organizational assumptions.
Let's look at some of our common assumptions that lead to unnecessary dependencies….
We assume that we must optimize for individual performance and therefore we matrix team members across projects. This creates dependencies between projects that did not have to exist. We find ourselves managing who is on what project and when they will be available for other projects. We create a network of dependencies [between projects] that restricts our ability to change course. Any change has a series of painful cascading impacts on our portfolio.
We assume parts of our solution are just too complicated and must be handled by specialists. We choose to assign certain people to specific components. By default, we create dependencies between products that share the same components. We also create dependencies between requirements that impact the same component. We create project dependencies between teams (and between team members) when we have these specialists assigned to a team of specialists.
We assume that our product owners are too busy for the team so we assign someone else to proxy for the business. We create a dependency between the team and the business that results in a tendency to over-document and manage the relationship between contracts. When contracts are used we create dependencies between the team and the business that must be maintained, enforced, and put under change management.
We assume the market is demanding all the features at one time so we do not focus on small functional slices across the entire systems architecture. Why bother, it all has to be done anyway? This thinking leads us to consider everything before we can consider building anything. When the requirements are all dependent on each other, there is no need to prioritize, no ability to change our minds, and no ability to learn from the emerging system. That big up front design document starts to look pretty reasonable.
We assume that architectures cannot be decoupled or that test coverage is too expensive. This causes us to think about making every change when we are making any change. Batched changes are made outside the context of working software. They are integrated and tested all at once... probably near the end fo the project. By creating dependencies between code changes, we loose the ability to learn from our mistakes, refactor, and hold teams accountable for outcomes.
Dependencies force us to measure hours worked, or modules delivered, or lines of code, when what we really want to measure is working software.
Why does all this matter?
Some of these dependencies are real. Many could take years to overcome. Just realize that every dependency you accept, every one you choose to leave in place, is going to fundamentally limit your ability to adopt agile methods.
Every single one will require a trade-off that will reduce your effectiveness and ability to respond to change.
By focusing on project management technique, engineering practices, or even leadership philosophy first… we miss the mark. We are inclined to pick from a smorgasbord of tactics and choose what can work for our particular organization. We are not forced to deal with the foundational problem, and therefore pick and choose our way into a meaningless agile implementation, one that will not deliver the essential value the organization is trying to deliver.
By focusing on the relentless pursuit and elimination of dependencies, we position our organization to potentially adopt ALL of the agile best practices. We can then pick and choose based on our values and principles, not on the constraints of our tangled up dependency based organizations!
Reduce dependencies at all costs. This is going to become my mantra for 2009. Expect to hear more on this topic as the year unfolds!
Subscribe to this blog
Subscribe to Leading Agile
Need training, coaching, or help leading an agile transformation?
email: mike@cottmeyer.com or call: 404.312.1471
Monday, December 8, 2008
The Secret to Organizational Agility
Labels:
Agile,
Dependencies
Subscribe to:
Post Comments (Atom)
Dependencies kill an organization, and I have been evangelizing this point of view. Thanks for this post, it is a great explanation of the problem. My compressed version: We need dedicated, cross-functional teams that are wholly responsible for delivery.
ReplyDeleteI agree with your compressed version 100% but when you lead with that argument, it does not resonate. They are tracking all other kinds of dependencies: resource specialization, inter-project relationships, software architecture, dependencies with the business, between release cycles, etc.
ReplyDeleteBrutal focus on all dependencies, before you even start talking about agile, will force people to break up the organizational constructs that are holding them back!
Nice in theory, but...
ReplyDeleteWe develop both hardware and the software to configure/program that hardware. I don't see how we can avoid a dependency from the software team to the hardware team. We could spend additional time creating a mock version of the hardware, but that should be done by the hardware guys, ergo still a dependency. Alternately the software guys could create it and we would also have to take on the rework once the hardware is real as it will note work like the mock. I don't see a way around it.
We also have the standard problems of shared resources (our QA team, our release engineer, our use of a common framework, etc). I suspose we could reorganize to remove these shared resources, but the result would be either more people (also know as more cost), or lower quality. I guess I don't like those choices.
Pat O
Mike,
ReplyDeleteThis doesn't work.
First, there are very healthy and necessary interactions in the process. Those dependencies must remain and must be optimized.
Second, it would be organizationally destructive to just "break all dependencies". How would you govern, how would you interact.
The point is to identify the few constraints that are keeping the organization (team) from delivering value today. Eliminate those constraints and find the next ones.
So creating dedicated, cross-functional teams is a great idea if the is a way to eliminated your current constraint on delivery.
The point is to increase the rate at which value is delivered to your customer.
Mike,
ReplyDeleteThe approach seems pretty extreme. I second Dennis' questions about governance and structure.
Do you have any real-life examples of breaking dependencies that you can share
Bob Williams