In the Beginning, There Was Chaos
I've always wanted to be someone who mentored and taught others how to live up to their potential. Naturally, I wanted to become a consultant. The path that lead me to where I am will have to be the subject of another post. For now, I'll just summarize.
After college, I went in to retail. What else could you do with a Psychology degree? After about four years in retail management, I went back to college to get a Computer Science degree. I had various jobs where I performed the functions of systems engineer, software engineer, DBA, SEO, etc. Then, I graduated to development management where I managed a couple of teams at a large software company. Surprisingly, managing a software development team isn't that much different that managing a retail team.
While managing these teams, it was hard to ignore the fact that they were in total chaos. My company was pushing a home-grown agile software development methodology. It sounded good because there was more focus on the customer, but it just didn't work. So, I went on the journey of finding what agile development meant. Certainly it didn't mean "no documentation" and "no design", right? Well, it didn't, but that's how we were acting. The teams were working super long hours. The engineers had no idea how to estimate. The team really didn't know what was supposed to be delivered.
Let There Be Scrum!
Then, slowly through several "iterations", we implemented scrum. I played the Scrum Master role. The path we took could be mapped by books that were used. The books that paved the road for us were "Agile Estimating and Planning", by Mike Cohn, then "User Stories Applied", by Mike Cohn, and then finally "Agile Software Development with Scrum", by Ken Schwaber. As we went through each book, we implemented these new things we learned incrementally.
So, we did it. We successfully implemented scrum. It was awesome. Why was it awesome? Here are some of the key reasons why:
- Freedom - The team was free to do whatever it took to make software. The management team didn't care if we used Scrum, XP, or Waterfall, they just wanted software. We were continually getting beat up for the crap we turned out. We finally got tired of it, and management let us do whatever it took.
- Engaged Teams - I was blessed with a wonderful team. Was every single person on the team engaged and wonderful? NO. But, these things have a way of working themselves out. The team, with a little guidance, quickly became a high performing, self-organizing team.
- Awesome Product Owner - Our product owner on our team was amazing. She was strong, had technical sense, and strived to play by the Scrum rules. She mastered the product backlog. Sure, maybe at times she was a bit "too" engaged throughout the sprint, which caused minor distractions at times, but that was to be expected and easily corrected.
- Individuals and Interactions Over Processes and Tools - You probably recognize that this is part of the agile manifesto. I listed this explicitly because this was a big deal. Originally, we were trying to use all kinds of tools; QuickBase, TeamTrack, TestDirector, Excel, etc. It was becoming a mess. We were spending so much time making sure everything was up to date. In addition, we were spending time generating reports that no one was reading. In the end, we used the tool with the lowest possible impact to the team; the white board. The teams sprint backlog was documented on the white board, where we tracked the daily status.
Okay, to be honest, we didn't "just" use the white board. We also used a tool called "ExtremePlanner" to hold the entire product backlog, and help with sprint and release planning. This was basically the playground for the product owner, so there was no overhead experienced by the team.
Enter the Agile Consultant
I really wanted to use my experiences over the last couple of years, both good and bad, to help others make the transition to common sense, i.e. Scrum. I know that most software development shops really didn't know how to make software that the customer wants without smashing the deadline, scope, or quality. That's exactly where we were.
Our company closed our office in Omaha, and I didn't want to move to the home base in San Diego, CA. This was the perfect opportunity to step into an "agile" consultant role. By certain divine intervention, a local company was looking for a consultant who was an expert in agile software methodologies. That was my calling.
My first job as a consultant is working with a company that was (and still is) in trouble. Some promises were made by executives that are now long gone, and the current team has to make good on those promises. Below is a sample of some of the core problems at this division:
- Legacy software - Most companies who have been around for 5+ years have to deal with legacy software that is fragile and extremely time consuming to make any changes. This is just about the worst case that I've seen or even read about. The code is so poorly architected it is a significant challenge to make even the smallest of changes.
- Turnover - Approximately 95% of the original team left. Most of the people who left held knowledge that was not documented nor was it shared. Just about everyone working on this project is new (within 6 months).
- Poor development infrastructure - The team is using VSS, which performs file-locks when code is checked out. This is a serious bottle-neck. Due to the poor design of the code, there are only a few files that most programmers have to touch. In addition, there is no consistent build or test environments or process.
- Lack of core experience - There are some key personnel, such as BA, QA, Management, that have no experience in those disciplines. Not only do they have to learn the product, they have to learn how to do their job.
- Micro-Management - There is a desire to manage every last task the team has to do. This has had a very damaging effect on the team. Most of the team is paralyzed when they have to make any decision for themselves. In addition, the management style is militant and somewhat cold.
- Implement Scrum on a small project and use the success to convince others to adopt. We would play roles on the Scrum team, product owner and Scrum Master.
- Educate everyone on Scrum, then let them try it themselves on any product they decided, with us helping and coaching only. We wouldn't play any roles on the scrum teams.
- Implement Scrum on the flag-ship product, and then let the other smaller projects fall in line. We would stay very close and coach the new Scrum Master, product owner, and team.
We went through quite a few struggles that we weren't expecting.
- We assumed that everyone would welcome us with open arms and that there would be a high level of trust. Boy, was I wrong. Most people were quite resistant. Many have come around after seeing some of the small successes, but there are some that I see that will always be resistant.
- We underestimated the learning curve of Scrum. Yes, Scrum is simple. But, as Ken Schwaber (one of the original creators of Scrum) frequently states, "Its incredibly difficult to implement". For example, creating a list of prioritized work has proven to be incredibly difficult. The product owner believed (for a while) that everything had the same priority ... HIGH! We are planning on conducting additional training sessions to accommodate.
- We didn't know how much trouble the project was really in. As we all know, not all projects can be saved. It doesn't matter what process you use. Again, as I've heard Ken Schwaber say, with Scrum, you'll know how screwed you are after 30 days. This couldn't be more true.
- There is no trust amongst the team. QA doesn't trust development, development doesn't trust QA, BA doesn't trust anyone, etc. What has been incredibly helpful here is our daily scrums. Just some time for the entire team to get together every day has helped the team members come closer to a trust relationship.
- People don't understand what self-organizing and cross-functional mean. The concept that you would have people from different disciplines on the same team is crazy! What's more crazy is that you would allow the team to work on what they want to. When we introduced this concept, it was like we just told them they should believe in elves. I was shocked. To me, these concepts are common sense for any good manager. As Scrum is working, and we are coaching everyone along the way, these concepts aren't approached with dismay and confusion anymore. It will be a slow process, but I think that the team will come around.
Improving Scrum Roll-Out
I know that there can't be a fine-grained plan to implement agile development on every team. Every team will have unique needs that will have to be addressed. However, our overall approach will be different.
- We will spend a significant amount of time with the management team, getting to know their problems, their personalities, and where they want to be. Each one of them will have different perspectives that will eventually have to be addressed. We need to set expectations better than we have in the past.
- We will work at building trust and teaching Scrum and agile development from the top-down AND bottom-up. With our current client, we used a bottom-up approach, and it just didn't work. However, if we would have only pushed it from the top, the team members would have totally rebelled. We will have to carefully map out our approach at our next engagement.
- We will spend significant time educating the team on agile development and Scrum. This will have to be continual. We did a "light" introduction, and then dove right in. The team really needed more than this.
- We will make sure to not get sucked into putting out fires, which is what happened at our current client. Now, this is a tricky one. Most likely there will be fires that they will need help with. If so, we will have to introduce a separate "fire-fighting" team. While the process improvement team continues with improving the process and coaching the members of the Scrum team.
- We will need to know exactly what level of empowerment we have and/or need. While management may say that we can do whatever it takes, we will have to make sure that everything is communicated clearly and frequently. And, we will get push-back, as we've learned at this current client. We will now be more prepared.
I will add posts as this project progresses, and as I learn new things about Scrum. I apologize for the length of this post. I promise future posts won't be like this. I do hope that this has helped someone out there who is starting their career as an agile consultant.
No comments:
Post a Comment