6

My development team is in the process of 'going agile' and lot of people are looking at each other blankly, not really too sure what it means. All management are saying is 'start working agile' without suggesting any particular methodology so they're waiting to see if we can come up with something ourselves. Has anyone been in this situation before and how did you handle it? Any do's and don'ts? I'm one of the senior members of the team so there's an expectation to show some initiative. I know that what works for one won't necessarily work for another so I'm more interested in the approach not so much the end result because I think the result will come naturally with the right approach.

John Shaft
  • 2,527
  • 2
  • 21
  • 30
  • 1
    Also related http://programmers.stackexchange.com/questions/26151/how-would-you-introduce-kanban-scrum-other-agile-methodology-to-a-team-in-an-en – JoseK Apr 13 '11 at 08:26
  • 1
    I think you're doomed to failure if the management team are only saying "be agile" to the dev team without buying into it themselves. – user1666620 Sep 10 '15 at 11:58
  • I came across this useful article that specifies the key elements the senior management should consider during agile transformation. http://blog.comakeit.com/agile-transformation-thing-senior-leadership-should-know –  Sep 10 '15 at 09:00
  • or, apparently, understanding it. If they did, they would be explaining what they wanted. And, IMO, the OP should be asking them, not us. If they can't explain, then they are just chasing buzzwords, which rarely has a happy ending. Management-buzzword-smell is usually a timely reminder to make sure that your CV is up to date (and does not include that particular buzzword, as you are unlikely to be able to answer questions about it convincingly at subsequent interviews). – Mawg says reinstate Monica Sep 11 '15 at 14:07

6 Answers6

5
  1. (if you haven't done so yet) Start by browsing through some well known Agile processes such as Scrum and XP to get an idea of their philosophy, ways of approach, tools and methods.

  2. Discuss these with team members and management, and decide which practices are (not) suitable for you.
    E.g. it might be that management is opposing pair programming (for real or imaginary reasons), or that end users can't physically participate in the teamwork and planning sessions; there is no point endlessly arguing over it, it may be better to just leave it out from the initial process.
    (You seem to have management support which is indeed an absolutely necessary, Very Good Thing - but you must ensure this support stays with you even in the face of difficulties. For this you should ensure that management actually understands what Agile roughly means, and what (not) to expect from it.)

  3. Start doing it, with a simple initial set of rules which is acceptable to everyone. No problem if the edges are rough, just define an initial process and start practicing it as soon as possible. Since you need time to get used to any new process and way of thinking, expect an initial period of confusion, chaos and subsequently lower productivity; you must survive these weeks and months in order for your efforts to start bearing fruits.
    One thing you should absolutely include in the process is retrospectives: regular meetings at the end of each iteration/sprint to discuss

    • what went well (to be continued),
    • what went badly (to be stopped or replaced by something better),
    • what could be done better and how.
  4. This should result in some action points to successively fine-tune and improve your process.

The result* may be a "strange" mix of ideas and practices from different methodologies, but it will be your own personal process, tailored for your own team and project.

*In fact there is no "end result", just as there is no end result in the process of evolution. Process improvement never ends. Circumstances change, projects change, team members change, and a good Agile process is kept adapted to all these changes.

Péter Török
  • 46,427
  • 16
  • 160
  • 185
5

I have experienced such situation in a company attempting to make the agile move.

The agile way is fairly simple and straight forward and actually removed (or should have) a lot process heaviness. But it was difficult and to my knowledge they are still struggling with it.

The biggest hurdle was that people lacked understanding of what going agile means. I think the change is similar when going from a procedural language to object oriented programming. Writing classes and doing inheritance does not mean you are doing OOP, in much the same way doing daily stand-up meeting and shortening the iterations does not mean you are agile.

Agile is about getting feedback on your work as soon as possible such that this feed back can be integrated back in the product AS IT IS BEING CREATED.

Waterfall is about attempting to get everything down before starting and not look back until it is done. Only a finished product warrants review and starts a new iteration.

I guess you could say in some ways the difference between agile and waterfall is akin to the difference between guided missiles and ballistic missiles. One fires right away and continuously adjust the trajectory in-flight while the other aims very carefully before firing a dead weight.

What ended up being done as "agile" was that they split the waterfall process in smaller iterations. But they still worked all before it started. Though this enabled some parallelism the work was still divided in the basic waterfall view, first get requirements, then design, then code, then test and ship, each part by a different team each team working independently. They applied the agile in apparence but their hearts and minds remained firmly in the waterfall way. When told it was not agile enough they just dropped the design part and created a mess !

It may take some time for your team to truly grok what agile is all about. Not all believe in the agile way and it is very hard to get a non believer to abide to it. Perhaps some external fresh set of eyes and ears can get your team off the ground faster and more efficiently.


EDIT

I should point out that the process in place at the company, modelled after waterfall, was broken before they decided to move to a more Agile way. They thought that this new thing called agile would solve their problems but they never really analysed what their problem was to begin with. Thus they went from bad to worst.

Also, judging from the comment threads I guess my over simplification of both description deserves some clearing up.

In their own ideals both process would attempt to seek feedback from customers, ideally from the actual users of the system being created. For Waterfall this means that each successive stage should have an open dialogue with the stage before to understand and perhaps fix problems before it reaches them. However the cost of finding a problem increases dramatically as the product nears completion especially so if the problem comes from a few stages back. This implies rigorous checking akin to what a carpenter mean by saying "measure 5 times, cut only once". Waterfall is not inherently broken and has worked very well and continues so in cases where the product, once delivered, is not meant to be changed easily. Getting feedback from customer from a large document describing the engineer's understanding of their need is not easy, yet many company will ask customer to commit to a set of highly technical documents they are often not equipped to understand.

Agile embraces the dynamic nature of human nature and how easily Software can follow. The goal of Agile is to translate the requirements in a form the customer will more easily relate to and as such gain more reliable feedback, I believe this was the essence of the Agile Manifesto. It was not meant as a proletarian revolution of software engineers over the establishment, though it is sometimes, unfortunately so, wielded as a hammer meant to destroy all that do not agree. Most agile techniques will hinge on the fact that software should be easily modifiable given a competent team to do so, that the most difficult part is to make sure the project is on track to satisfy an actual existing need as opposed to the perception of this need by an analyst. This requires a deep change in philosophy and does not integrate well with the present corporate structure. Projects must gain financing, for this financing projects must be evaluated very precisely before it ever gets started. This structure tends to favour a waterfall mindset, where once a contract signed it is often worded in a way where the team is bound to the approved documents and must follow a pre-set plan rather than pursue the need that originated the project. A software company will truly embrace Agile when all it's structure will embrace the agile mindset starting with how the work is billed to customers, how the projects are framed legally and contractually etc. At this point my experience is skim and going further would be purely speculative for me but it is certainly something I would be very interested in learning more about.

Newtopian
  • 7,201
  • 3
  • 35
  • 52
  • This is a highly inaccurate description of waterfall, [as even Wikipedia can tell you](http://en.wikipedia.org/wiki/Waterfall_model). The model can and does involve regression to previous design stages based on feedback from the implementation and testing stages. The main difference with agile is not in its iterative nature but in *how much* design work is done before implementation. – Aaronaught Jun 01 '11 at 16:05
  • I see not where it is *highly* inaccurate, perhaps I should have used more precise vocabulary. If you actually read up on the reference material you kindly submitted you will see that Waterfall is not so much about how much design goes in first, namely, all of it. It is about breaking the work into successive steps at the end of the last only is a finished product. Waterfall in it's purest sense does not iterate, but reality tells us that version 1.0 is rarely done right and needs some refinement. Thus starts the new waterfall iteration. – Newtopian Jun 02 '11 at 13:32
  • ...One of the main difference between agile and waterfall is indeed the iterative nature, waterfall has none, normally a software shipped with waterfall enters maintenance mode, evolution of the same code with new features would warrant a new iteration of waterfall but this iterative process lies *outside* the process. The main difference is, as you partly pointed out, that agile does not try to get everything right on the first pass but through successive adjustments. Agile also fuses the different waterfall steps in a unified team working simultaneously rather than successively. – Newtopian Jun 02 '11 at 13:38
  • that said, if you still feel I am wrong here I would really like to hear more and if indeed I am wrong I will definitively change the answer to make it more accurate. – Newtopian Jun 02 '11 at 13:41
  • 1
    I suppose I should have been more clear as well. The term "Waterfall" is essentially a straw-man, an entirely fictitious methodology, a derogatory term used by the Church of Agile to describe anything that isn't Agile. The *actual* model that Royce *actually* proposed [allowed for backtracking](http://en.wikipedia.org/wiki/Modified_waterfall_models), and this is how the "Waterfall" actually works in practice 95% of the time. Anybody can screw it up by refusing to iterate, just as anybody can screw up an agile project by refusing to do any kind of design. – Aaronaught Jun 02 '11 at 14:04
  • Thanks for the link, indeed, waterfall *should* include some sort of feedback, it's just common sense. I will adjust the text in accordance, though the waterfall I have experienced and the one I refer to in the answer only allowed for feedback from customer's complaints. Essentially each successive stages worked as all saying god to the next stage, the premise was that documents describing requirements, designs, code.. were perfect and could not be questioned by the underlings of the stage past. Though this is the reality I was confronted to I do agree it is **not** the essence of waterfall – Newtopian Jun 02 '11 at 16:18
  • 1
    "Agile is about getting feedback on your work as soon as possible such that this feed back can be integrated back in the product AS IT IS BEING CREATED.", "Waterfall is about attempting to get everything down before starting and not look back until it is done. Only a finished product warrants review and starts a new iteration.": IMO the best solution is to find a good compromise between these two extremes. Waiting until the end of the project to get feedback means finding problems when it's too late. Getting feedback too often gets in the way of actually getting things done (properly). – Giorgio Sep 10 '15 at 12:17
  • agreed... With experience I find that they both have their use, some use cases will naturally lean towards the waterfall end of the spectrum. Say implementing an interface between two system for which the specification is stable and well defined. I find that the more unknown, holes and uncertainties there are the better suited agile is. – Newtopian Sep 10 '15 at 20:32
2

A few things we did that helped us with our transition.

  1. Agile coach: The one thing that made the biggest positive for our transition (which so far is pretty successful) is getting someone in from outside to help us. We were lucky enough that a smart and respected fellow that used to work for us had gone on to work at a few different agile shops, seeing some successes and some failures. We snared him for a while to help us pitch, plan, and ultimately execute, a switch to agile. Coming in, he had a good grasp of our business and the things that make us special/different/difficult/whatever, and a good grasp on agile. He took a fair amount of time to talk to people, consider end-state models, consider a transition plan, and make sure we understood the costs and benefits.

  2. Transition team - Once we knew this was for us, we formed a small team under the guidance of the agile coach, with experienced people from most of the functional areas of our department. This team works as an agile team, with a backlog that models the things we need to plan or execute for the transition. Membership has been reasonably static; team members have their "day jobs" as well as their transition team duties. Collectively, the team know pretty much everyone, understand what makes people tick, know the processes we use in every corner of the company, and what's going to break as we start changing things.

  3. Executive support - I'm amazed at what a difference this makes. For us, the desire to go agile came from the top, based on the perceived benefits both to the organisation and to the individuals in the organisation. When we interview folks, it sounds like most places looking to go agile have a grassroots agile movement that tries to get going in spite of a lack of management support, or lip service. The way you commit to work changes dramatically; without support from the top, I can't imagine how a transition would be successful. You're getting pushed in this direction from management; I assume they want more than "just be agile please", they want something in particular out of it.

The transition itself is a tricky beast. All of those practices we value under agile (stories, teams do estimation, set iterations, access to stakeholders, focus on testing and continuous integration, etc) are hugely important, but properly managing the transition to using those is difficult. It's a project in itself. We're a mid-sized place with a bunch of average-sized scrum teams, so your actual mileage may vary, but I'm sure the concepts would still apply.

Kris
  • 573
  • 4
  • 8
1

My development team is in the process of 'going agile'

Playing Devil's Advocate for a minute: Why?

What's wrong with what you're doing already?

Is moving to an Agile (or any other) way of working going to allow you to do your jobs any better than you're currently doing them?
If you cannot qualify the benefits you hope to gain from this piece of work (and changing between any Methodologies is a lot of work!) then why are you wasting your time?

Without a clear idea of what you hope to achieve, you're going to have a really hard time making it happen. And you Management, who clearly expect you, as an "Agile" team, to self-organise yourselves, will be "less than impressed" when you take [far] longer to produce [far] less, perhaps, then you currently do.

Agile is not a Magic Bullet. Yes; it's good (great, even) for some types of Development (mostly the "shiny", front-end stuff that Users like to look at and have a hand in driving), but quite dreadful for many other kinds (the back-end "plumbing" that every system needs, but that nobody wants to get stuck with).

Phill W.
  • 11,891
  • 4
  • 21
  • 36
1

Agile is all about short iterations and react to changes and have runnable version all the time. The rest are more or less details you could read up and do one after the other. I would suggest to read the following:

Tim Büthe
  • 416
  • 2
  • 7
1

Don't drop the current methodology all of a sudden. Instead adapt it to be more agile one step at a time. The current methodology can be the outer framework that gives structure to a more agile inner one.

  1. Find ways in which to simplify administrative and operational documentation. Drop some documents from the process.
  2. Shorten the release-to-deployment cycles. Change projects of more than six months of schedule into several versions released each three months, and revise the plan and features for the next version before starting to work on it.
  3. Use stories, scenarios, or use cases as the feature units, have developers estimate them, and base the project plans on those estimations.
  4. Plan to deliver working use cases in iterations of two to four weeks.
  5. Measure planned versus working features (ideal versus actual plus the velocity) and modify the general plan and the following iterations accordingly.
  6. Invest in the automation of functional tests, and make executing those tests part of the daily routine.
  7. Introduce unit tests and a personal code integration process that uses them. Don't let developers break the code in shared repositories.
  8. Tell management that frequent and expedite access to those who represent the client or the users is indispensable when going agile. Answers to questions are required when the features are being built, not after they've been released.
  9. If you can't or won't do pair programming, at least have developers work on different parts of the system on different iterations. That will make the code be reviewed by everyone, and will increase the knowledge everyone has about system components and technologies, thus reducing the risks of component/module ownership.
  10. Start with a pilot, low-risk project.

I've consulted in introducing agility to software teams and companies, and what has worked is to gradually introduce agile ways at the core of what they already do. The keywords are simplify and iterate (something that also applies to the process of introducing agile).

Apalala
  • 2,283
  • 13
  • 19