What single aspect of agile development should we implement first to improve our development process, and why?
I'm in a situation that's requiring me to "tweak" my process, rather than re-engineer it, and "agile" seems to be the mantra of the day. If we can make only one change that will improve something--quality, time to market, documentation, transparency, etc., what will have the most visible, positive impact?
If we choose correctly, we'll be able to make a second choice. :-)
Update: What is your current SDLC?
Environment: essentially "restartup."  A small handful of developers; legacy products with 10^5-10^6 LOC and tens of thousands deployed worldwide; products are strongly interdependent; significant features added over the years, including many one-offs, w/o refactoring; tight schedules; superficial QA; no post-mortems or "process guru."
Typical process:
Thanks for so many helpful suggestions and insights!
Iterative building
When we moved to having builds on a consistent basis (in our case weekly or twice per week) we saw the biggest improvement.
When every build was produced we sat down with the development team, the QA team and the product management team and created a list of the work that was included in the new build.
Everyone then helped answer the question of what should be included in the next build.
We have since added many other features of Agile development (including trying to implement a scrum to the letter), but nothing has given us as much "bang for the buck" as iterative building.
Iterative development. Work in small iterations (say 2 weeks), have 'ready' application by the end of each and single iteration, i.e. your testers should be happy to release the results to your customers.
This is the core. You could build on this.
I'm a big fan of mix-and-match, and an incremental change of the development process. I agree that iterative development should be your first goal, but I think you can approach it in even smaller steps.
From my experience, I would recommend the following order - pick the first you don't do already:
Fix Bugs First. I wish I wouldn't have to say that. This is the call of sanity, and also required to have shorter cycles.
Small steps. Train the habit of implementing the smallest change that is a visible step towards the next feature, then compile and test. Break down all your tasks into <1h units before starting to code. Aim for buildable, functional code at least every 15 minutes. This doesn't require much infrastructure change - except maybe fixing the incremental build and having fast machines.
Yes! Start with making sure developers have fast machines. How much better advise could get?!
Build Everything Daily. Set up a double-click full builds from Source Control to installation medium, ideally on a separate PC. This are the first step to the frequent builds, but they help a lot on their own already. For us, it was a crucial step in getting reliable, reproducable build results.
Start writing Unit Tests. Don't bother about coverage yet, don't enforce "write tests first", but put the framework in place. Write tests for new code and changes. Then run them with your daily builds.
Short Cycles. Now it's the time, you have all tools in place to make weekly or two-weekly in house releases: The codebase is in a deliverable state many times a day, making the build is a double-click away, and at least something is working.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With