Sunday, October 4, 2015

Agile Program Management: The Simplest Lesson

Program Managing a Large-Scale Distributed Agile Program involves several challenges such as team structuring, team induction, training, delivering in short-iterations, team retention and attrition management, system architecture, dependency management, risk management, software testing and automation and so on.  I am writing this post based on a large-scale distributed Agile program we undertook with more than 300 team members across two time zones with involving multiple business critical projects.   The objective of this post is to share experiential knowledge on managing large-scale distributed agile programs and present one of the simplest lessons. This is not it. I will be sharing many more lessons in my subsequent posts.
Program Management involves a higher degree of challenge and complexity as compared to Project Management.  This is because you need to cover multiple projects involving different lifecycles, pricing models, stakeholders, integration requirements, and dependencies. Of course, there are numerous other elements that add to this list.  When we move up from the role of a Project Manager or Scrum Master (in Agile world) to play the role of a Program Manager, we see program management as a role that involves managing more than one project and we stop there. We ignore the need to understand the possibilities of different technologies, stakeholders, regulatory needs, integration challenges and so on.  With over simplification we tend to ignore all the important aspects and eventually it hurts.
So, what is the simplest lesson that we need to know? Here it goes.
“Not all projects are the same. What worked in one project need not apply or work in another project.”
Obviously! We all know that.  However, how many times have we seen program managers as well as experienced project managers establishing a set of rigid rules or expectations on projects or labeling projects based on technology or lifecycle or something else? Here is an example.  Once, a program manager started opining that all agile projects must start doing Test Driven Development from the beginning.  Later, she mandated it.  It did not work because in some projects teams were getting ready to do automated unit tests right before jumping in to TDD. In some other projects teams were finding it tough to implement TDD because those projects involved data migration and the development activities were not mature enough to bring in TDD.
 
Let me present you with another example. Years ago, I came across a program manager who was very fond of three metrics - Schedule Variance, Effort Variance and Defect Density.  She ran program management meetings by looking at these three metrics. She wanted these three for projects of all sorts. It did not work because there were projects following iterative cycle. There were projects following Scrum and there were maintenance projects running in Kanban mode.
 
Well, is this simple lesson specific to Agile Program Management? No. It can be applied in Program Management in general.  Let me give you another example.  I had a Program Manager who used to manage multiple projects and most of them were following Scrum. Some of them were large-scale projects.  She recommended the same style, intensity and schedule of coaching – I mean Agile Coaching, for all Agile projects that would get added under her program no matter what.  She was ignoring the need to understand the needs of the project well and custom fit a coaching solution.  When an Agile Coach suggested this to her, she did not take it on the face of it. It took us some time to sell the idea.
 
“It worked in my previous project. It must work here as well.”  This is a typical Project Management mind block.  Many rookie project manager jump on to their second project with this belief. They bang their heads before they learn the hard lesson. And that is of course the simplest lesson.
 
Be open minded, listen to ideas, think logically and collaborate with your project managers. That is one way to keep remembering this simplest lesson and avoid fundamental mistakes.
 
Do you relate this simplest lesson to your experience or an incident happened at work? Please feel free to discuss. In my next post, I will continue with the next lesson.