I've been talking with a lot of folks lately that claim to have been working with Agile for a long time. When I talk with them, they boil agile down to a few things such as; delivering faster, iterations, and stand-ups.
Sunday, December 6, 2009
Agile - It's All About the Principles
Thursday, December 3, 2009
Just in Time or Just in Case?
A huge form of waste that many people don't talk about are those things that are built "just in case" we might need them some day.
There are some Scrum Masters (and Project Managers) that typically stay out of those kinds of details. Yes, the team is self-organizing. Yes, the team has to learn by making mistakes. However, the Scrum Master has to be involved enough to not allow the "just in case" methodology from taking hold. If it's allowed to go on too long, you will have found out that what you have delivered in the end is not what is valuable now.
Monday, November 16, 2009
Bringing Agile to the Organization
Almost all of the literature out there recommends the first step being finding a "pilot" project where you can use an agile methodology. The project can't be too complex, too simple, too large, too small, too critical, or too unimportant.
- The primary measure of progress is working software
- Business and IT working together daily
- Face to face communication
- Reducing waste
- Building quality in
- Delivering as fast as possible
- Delivering working software frequently
- Self-organizing teams
- Welcome change
- Sustainable development
- Technical excellence
- Keeping it simple
- Continuously improving the process
Monday, November 9, 2009
The Cross Functional Team vs. the Functional Community
An agile team consists of everyone it takes to deliver value to the customer. The typical team consists of analysts, developers, and testers. Of course the team is not limited to these roles. The team could also include technical documenters, DBAs, or whoever else has a hand in creating value.
In traditional organizations, "team" is defined as a functional group. The development "team", the "testing" team, the "analyst" team, etc. This makes sense in a traditional, waterfall-ish environment.
In an agile, cross-functional environment, it is not helpful to define "teams" around functions. Okay, "maybe" its okay in a production support capacity, but that's still pushing it as there will still need to be cross-functional work with production support.
Teams have a common, unified goal. Functional "teams" do not. For example, a functional "team" that consists of a dozen Java programmers, with each programmer on a different project, can hardly be called a "team". They have no common goal, other than to adhere to the (hopefully) high development standards that have been put in place.
I propose that instead of calling these functional groups "teams", we call them communities. Here's a simple definition of community that I found on dictionary.com: "A group of people having common interests". The Java "community" will work together to make sure that they have common standards of excellence, share knowledge and experiences, and provide each other guidance as needed. However, these people will have different goals, depending on the project on which they have been assigned.
Labels: community, cross functional, functional teams, teams
Sunday, November 8, 2009
Up Front & Iterative Planning
You know the question..."what kind of projects are best suited for agile?". To me, this is the same as asking "what kind of projects are best suited for empowered teams, technical excellence, servant leadership, reducing waste?". Would there ever be a time when you would not want these things? I know, that is a very smart-allec response, but I just can't help myself.
I then ask "what's the other option?". This surprisingly stumps people when I ask this. We all know there is no such thing as "true" waterfall in software. So, to help them along, I clarify what I "think" they are asking which is "what kinds of projects are best suited for big, upfront planning and design vs. iterative & incremental delivery?". People almost always agree with the restatement of the question.
I believe that everything can and must be done iteratively and incrementally in software. However, the level of "up front" may change with the type of project. Gutting out an old accounting system and replacing it with an Oracle or Great Plains solution will require more up-front planning and analysis than a green-field Web 2.0 social networking application.
So, fellow agilists, "up-front" is not a bad word, it has to be done. We know this already with release planning, and even sprint planning, we just don't call it "up-front". Just be careful...VERY careful. You run the risk digressing into waterfall. At times, there will need to be more "up-front" than other times. Always be asking yourself, "what is the soonest we can deliver value to customer?".
Labels: agile, analysis, big up front, planning, scrum, traditional, waterfall
