The Agile with Scrum User’s Guide: A Compilation of Thoughts and Practices Compiled by Joel Adams, CSM [email protected] Edited by Jillian Neustel [email protected] © 2006 This book is an edited and organized compilation of over 100 postings to message boards and a few other texts. The primary source is ScrumDevelopment in Yahoo Groups. Although the term Agile can cover a wide range, I have always been most interested in people, team productivity, and project management. The subjects selected for this book and these particular answers and comments were useful to me in learning about Agile and teaching others about Agile. -- Editor ii THE HISTORY OF AGILE SOFTWARE DEVELOPMENT................................................1 1.1 ORIGINS OF SCRUM....................................................................................................................2 1.2 IMPLEMENTATION CHALLENGES................................................................................................4 1.3 AGILE VS. WATERFALL..............................................................................................................6 1.4 SCRUM VS. TRADITIONAL SPIRAL DEVELOPMENT......................................................................7 1.5 CMMI AND AGILE.....................................................................................................................9 1.6 AGILE AND PMBOK................................................................................................................10 1.7 SCRUM WITH RUP....................................................................................................................12 1.8 PERSONAL SCRUM....................................................................................................................14 TEAM SPACE AND ON-SITE VS. OFFSHORE...................................................................16 2.1 BULL PENS / CO-LOCATION / OPEN SPACE (QUIET WORKING CONDITIONS VS. COMMON ROOM) .......................................................................................................................................................17 2.2 DISPERSED (NON CO-LOCATED) TEAMS..................................................................................19 2.3 ON-SITE CUSTOMER................................................................................................................20 TEAMWORK AND HIERARCHY..........................................................................................22 3.1 APPLICATION ARCHITECTURE ACROSS TEAMS........................................................................23 3.2 SELF-ORGANIZING TEAMS.......................................................................................................25 3.3 SCRUMMASTER: ELECTED FROM TEAM...................................................................................26 3.4 SCRUMMASTER: TEAM MEMBER OR COACH...........................................................................27 3.5 SCRUMMASTER: COMMUNICATION..........................................................................................29 3.6 BUSINESS ANALYSTS AND SCRUM...........................................................................................30 3.7 IS THE PRODUCT OWNER A PIG OR A CHICKEN?.......................................................................33 3.8 INTERACTION DURING SPRINT.................................................................................................37 3.9 RETROSPECTIVES: WHO SHOULD FACILITATE.........................................................................39 3.10 SPRINT REVIEW: STAKEHOLDER’S ROLE................................................................................40 3.11 TEAM MEMBERS....................................................................................................................42 3.12 PERFORMANCE REVIEWS.......................................................................................................43 DEVELOPMENT PRACTICES...............................................................................................45 4.1 BEST PRACTICES......................................................................................................................46 4.2 IMPLEMENTING AGILE ON YOUR OWN.....................................................................................47 4.3 DAILY BUILDS.........................................................................................................................48 4.4 DAILY SCRUM MEETING..........................................................................................................50 4.5 SCRUM OF SCRUMS..................................................................................................................51 4.6 SPRINT GOAL...........................................................................................................................52 iii 4.7 TASK SIZE VS. EFFORT VS. DURATION.....................................................................................53 4.8 TASK SIZE (BREAKING DOWN TASKS).....................................................................................54 4.9 SPRINT CALENDAR...................................................................................................................55 4.10 ESTIMATES.............................................................................................................................56 4.11 ESTIMATING TESTING............................................................................................................57 4.12 PLANNING AND ESTIMATING TASKS......................................................................................58 4.13 TECHNICAL DEBT – BIG REFACTORINGS NOT YET DONE......................................................61 4.14 REQUIREMENTS READY FOR SPRINT......................................................................................62 4.15 TESTING.................................................................................................................................63 4.16 TEST DRIVEN DEVELOPMENT.................................................................................................64 4.17 UNIT TESTING........................................................................................................................66 4.18 BUGS – HOW TO HANDLE.......................................................................................................69 4.19 RETROSPECTIVES...................................................................................................................70 4.20 IMPLEMENTATION OR CUSTOMIZATION REQUIREMENTS........................................................71 4.21 REQUIREMENTS DEFINITION SPRINT......................................................................................72 4.22 VERY LARGE PROJECTS.........................................................................................................74 4.23 SPRINT BURNDOWN...............................................................................................................75 4.24 NEW TASKS ADDED TO LIST OF SPRINT TASKS......................................................................77 4.25 PRODUCT BACKLOG...............................................................................................................80 4.26 MOVING PRODUCT BACKLOG TO THE SPRINT........................................................................81 4.27 PRODUCT BACKLOG IS A NULL SET.......................................................................................83 4.28 DEFINITION OF DONE.............................................................................................................84 PRINCIPLES, MEASUREMENTS, AND TOOLS.................................................................86 5.1 SCRUM PERFORMANCE MEASUREMENTS.................................................................................87 5.2 SCRUM PRINCIPLES..................................................................................................................88 5.3 DECLARATION OF INTERDEPENDENCE......................................................................................89 5.4 SITUATIONAL OWNERSHIP: CODE STEWARDSHIP REVISITED...................................................90 5.5 THE TOP 10 KEY DIFFERENCES BETWEEN A TEAM OF INDIVIDUALS AND A GROUP OF INDIVIDUALS..................................................................................................................................92 5.6 BURNDOWN TRACKING............................................................................................................94 5.7 USER STORIES..........................................................................................................................95 5.8 AUTOMATED TRACKING TOOLS...............................................................................................96 5.9 REFACTORINGS........................................................................................................................97 5.10 SCRUM ON A PAGE.................................................................................................................99 iv Section One: The History of Agile Software Development 1 1.1 Origins of Scrum Of historical interest is that Scrum was incubated at Easel Corporation in 1993 where I had just joined them as VP of Object Technology after spending 4 years as President of Object Databases, a startup surrounded by the MIT campus in a building that housed some of the first successful AI companies. My mind was steeped in artificial intelligence, neural networks, and artificial life. If you read most of the resources on Luis Rocha's page on Evolutionary Systems and Artificial Life you can generate the same mind set: http://informatics.indiana.edu/rocha/alife.html I leased some of my space to a robotics professor at MIT, Rodney Brooks, for a company now known as IROBOT Corporation. Brooks was promoting his subsumption architecture where a bunch of independent dumb things were harnessed together so that feedback interactions made them smart, and sensors allowed them to use reality as an external database, rather than having an internal datastore. Prof. Brooks viewed the old AI model of trying to create an internal model of reality and computing off that simulation was a failed AI strategy that had never worked and would never work. You cannot make a plan of reality because there are too many datapoints, too many interactions, and too many unforeseen side effects. This is most obviously true when you launch an autonomous robot into an unknown environment. The woman I believe will one day be known as the primeval robot mother by future intelligent robots was also working in my offices giving these robots what looked like emotional behavior to an external observer. Conflicting lower level goals were harnessed to produce higher goal seeking behavior. These robots were running in and around my desk during my daily work. I asked IROBOT to bring a spider-like robot to an adult education course that I was running with my wife (the minister of a local Unitarian Church) where they laid the robot on the floor with eight or more dangling legs flopping loosely. Each leg segment had a microprocessor and there were multiple processors on its spine and so forth. They inserted a blank neural network chip into a side panel and turned it on. The robot began flailing like an infant, then started wobbling and rolling upright, staggered until it could move forward, and then walked drunkenly across the room like a toddler. It was so humanlike in its response that it evoked the "Oh, isn't it cute!" response in all the women in the room. We had just watched the first robot learn how to walk. That demo forever changed the way the people in that room thought about robots, people, and life even though most of them knew little about software or computers. (I believe the robot's name was Genghis Khan and he is now in the Smithsonian.) This concept of a harness to help coordinate via feedback loops, while having the feedback be reality based from real data coming from the environment is central to human groups achieving higher level behavior than any individual could achieve on their own. Maximizing communication of essential information between group members actually powers up this higher-level behavior. Around the same time, a seminal paper was published out of the Santa Fe Institute mathematically demonstrating that evolution proceeds most quickly, as a system is made flexible to the edge of chaos. This demonstrated that confusion and struggle was essential to emerging peak performance (of people or software architectures which are journeys though an evolutionary design space) as was seen in the robot demo. 2 On this fertile ground, the Japanese Scrum paper provided a name, a metaphor, and a proof point for product development, the Coplien paper on the Borland Quattro Product kicked the team into daily meetings, and daily meetings combined with time boxing and reality based input (real software that works) started the process working. The team kicked into a hyperproductive state (only after daily meeting started), and Scrum was born. Jeff Sutherland1 1 From: Jeff Sutherland [email protected]; Sent: Sunday, December 5, 2004 at 2:07 PM Subject: Wholeness 3 1.2 Implementation Challenges Hello PaulOldfield1, Thank you for writing. > On Thursday, August 3, 2006, at 4:48:34 AM, PaulOldfield1 wrote: > Yet I don't think this is the root cause, or solution, of the problem Ron was talking about. We've done fairly well at getting the “buzzword” of Agile across, but we don't seem to be doing too well at following up with the enlightenment about what the buzzword really means. IMHO. Yes, that's certainly what I've just been going on about. I'll give some examples. Scrum and Engineering Practices In the Scrum world, the CSM course and the books don't say much about engineering practices. I guess it's assumed that if the team sets itself to producing real releasable software every month, they'll figure out what the engineering practices are that will help them do that. I actually believe that to be true, though it's often terribly slow waiting around for someone on the team to invent testing. What happens, at least in part because Scrum says so little about engineering practices, is that teams do things that are far from ideal. A short list: * Start a Sprint with analysis, so that programmers have nothing to do for a week or so; * Throw the code to the testers at the end of the Sprint, so that they have little to do at the beginning and are overloaded at the end; * Solve that problem by having a development Sprint followed by a "QA" Sprint, resulting in mostly idle people half the time; * Solve that problem by having testing for Sprint N during Sprint N+1, reducing feedback and interrupting Sprint N+1 programmers, and deferring fixes to Sprint N+2, reducing learning profoundly; ...and so on. There are many aberrations. We should produce a list of them. Maybe with a list of things labeled "If you're doing these things, you're probably not doing it right yet," we could address this enlightenment question. Agile and Additional Practices We have a number of Agile brands and branches who are strong proponents of some additional practices. Modeling is a popular example. Scott Ambler has been visiting lately, and he has an entire "Agile method" which is (was?) called "Agile Modeling". There are other examples, adding in Use Cases, Modeling, a bit of Up Front Architecture or Design, and so on. What is unfortunate in my opinion is that most of these "defensive" additions to Agile are unnecessary, and have the result of appearing to say that if you are going to do Agile safely, you'd better do a bunch of requirements first, then some architecture, then some design, then finally code and test the application. Since people are used to doing things roughly that way, that's what they read. They discover that they're "already doing Agile", add a couple of meetings to their practice, and proceed business as usual. Agile Without Experience There are a lot of people pushing Agile today who have entered the market from some other realm. There are group dynamics people, PMI people, and so on. Some of these people – I want to say many – have little or no training from people in the Agile lineage, and have never been on an Agile project except for projects they have created and called Agile. Einstein said: "Example isn't another way to teach: it is the only way to teach.” In Agile, that's certainly true. The best way to learn how much to test is to test too much, not just too little. The best way to learn how much to rely on up front thinking and building and how much on refactoring is to try to build software without all that modeling and infrastructure. 4 People who create methods without ever having worked with or even examined a really well-operating Scrum or XP project can't possibly know what they would if they had. I think their conclusions and recommendations would be quite different. Agile Without Skills Software development is an intricate and difficult art. Yet as an industry we send people into the fray terribly poorly equipped. Even developers with degrees in the subject are not well prepared in terms of what is really needed today. More significant is the fact that many – again I'd say most – software developers have no significant training in the subject at all. They're self-taught refugees from some other realm, who have entered programming because it interested them, or because there were no jobs available for semanticists or whatever they studied in college. To do the necessary engineering practices mentioned above, Agile teams require an especially wide range of skills, and the team needs to be really good at them. I would include human relations skills, requirements skills, design skills, programming of course, how about real Object Oriented programming, almost no one knows how to do that, relational database skills, and more. Add in customer-facing testing, unit testing, test-driven development, and refactoring. Add in some skills in setting up builds, and doing code management. The list is endless, and if we're going to be Agile, we can't have some bottleneck person who is our only refactorer: we all need to be good enough at most of these things. But there's no focus on these kinds of skills. Scrum, to name names, scarcely even admits that these skills exist, much less matter. Now sometimes, Scrum proponents claim "all those things have always been part of Scrum". It's true that all those things have always been part of //successful Scrum projects//, because they have to be. Authors of other Agile methods say similar things: we don't mention all these foundational things, they are taken for granted. But so few people have them, how can we take them for granted? Technical skills are often not part of Agile culture ... and they need to be. Summary Ken and others like to say that Scrum is "common sense". In my experience, it isn't. Jeff likes to point to Scrum teams that are "hyper-productive". In my experience, most aren't. The reasons have to do with the passing on of knowledge, and in some cases, the active denial that knowledge is necessary, and the active addition of things that are only sometimes needed. The Agile marketplace is filling up with people, mostly of good will, trying to do a good job, who, nonetheless, have an n-th hand partial picture of what it's all about. Of course, in the end, all of us only have a partial picture of what it's all about, YT included. And yet, it seems to me that things are getting watered down. Maybe that's inevitable. Ron Jeffries2 2 From: Ron Jeffries [email protected]; Sent: Thursday, August 3, 2006 at 4:10 AM Re: Agile 2.0 (2nd Attempt) 5 1.3 Agile vs. Waterfall 1. The difference between Agile and Traditional Project Management is simple and distinct. a. Agile is function / goal based – that is to say focused on what the product owner and user feel is critical to their success b. Traditional is task / cost based – that is to say focused on the providing the customer proof that the resources invested are being consumed according to plan 2. Neither approach communicates needed information to all parties concerned. a. Agile speaks poorly to customers who want to know where the money went b. Traditional speaks poorly to the product owner and user as to the usefulness of the functionality being provided 3. The differences are profound but at the same time driven by the audience each approach talks to. a. Bottom up support from users, customers, and clients will push organizations to use Agile methodologies b. Top down pressure by stockowners, investors and will push organizations to remain with traditional methodologies 4. There needs to be some thought put into building an interface between the two methodologies so that our customers can better use our skills and we can be seen as useful.3 3 From: Mike Dwyer [email protected]; Sent: Thursday, January 13, 2005, at 10:35 PM Subject: Lessons Learned Forward 6
Description: