Martin Fowler Testing Methodologies

Download as pdf or txt
Download as pdf or txt
You are on page 1of 22
At a glance
Powered by AI
Some of the key principles of agile methods mentioned are their adaptive and people-first orientation as opposed to traditional predictive approaches.

The principles that unite agile methodologies contrast from established methodologies in that they are more adaptive to changes and put more emphasis on people and collaboration.

Some agile methodologies mentioned are eXtreme Programming (XP), Scrum, Crystal, Lean Development, and the Rational Unified Process.

MartinFowler

Inthepastfewyearsthere'sbeenablossomingofanewstyleofsoftwaremethodology referred to as agile methods. Alternatively characterized as an antidote to bureaucracy or a license to hack they've stirred up interest all over the software landscape.InthisessayIexplorethereasonsforagilemethods,focusingnotsomuch ontheirweightbutontheiradaptivenatureandtheirpeoplefirstorientation.

Lastsignificantupdate:13Dec05
|Russian|Chinese|Indonesian|Spanish|Italian|French|Portuguese| Contents

FromNothing,toMonumental,toAgile PredictiveversusAdaptive o SeparationofDesignandConstruction o TheUnpredictabilityofRequirements o IsPredictabilityImpossible? o ControllinganUnpredictableProcessIterations o TheAdaptiveCustomer PuttingPeopleFirst o PlugCompatibleProgrammingUnits o ProgrammersareResponsibleProfessionals o ManagingaPeopleOrientedProcess o TheDifficultyofMeasurement o TheRoleofBusinessLeadership TheSelfAdaptiveProcess FlavorsofAgileDevelopment o AgileManifesto o XP(ExtremeProgramming) o Scrum o Crystal o ContextDrivenTesting o LeanDevelopment o (Rational)UnifiedProcess Shouldyougoagile?

RelatedArticles

IsDesignDead? TheNewMethodology(Original)

Probably the most noticeable change to software process thinking in the last few years has been the appearance of the word 'agile'. We talk of agile software methods, of how to introduce agility into a development team, or of how to resist theimpendingstormofagilistsdeterminedtochangewellestablishedpractices. This new movement grew out of the efforts of various people who dealt with softwareprocessinthe1990s,foundthemwanting,andlookedforanewapproach tosoftwareprocess.Mostoftheideaswerenotnew,indeedmanypeoplebelieved thatmuch successfulsoftwarehadbeenbuiltthatwayforalongtime.Therewas, however, a view that these ideas had been stifled and not been treated seriously enough,particularlybypeopleinterestedinsoftwareprocess. This essay was originally part of this movement. I originally published it in July 2000.Iwroteit,likemostofmyessays,aspartoftryingtounderstandthetopic.At thattimeI'dusedExtremeProgrammingforseveralyearsafterIwasluckyenough to work with Kent Beck, Ron Jeffries, Don Wells, and above all the rest of the ChryslerC3teamin1996.Ihadsincehadconversationsandreadbooksfromother people who had similar ideas about software process, but had not necessarily wantedtotakethesamepathasExtremeProgramming.SointheessayIwantedto explorewhatwerethesimilaritiesanddifferencesbetweenthesemethodologies.
SeeRelatedArticle:TheNewMethodology(Original) Here is the text of my original version, for those interested in historic curiosities. Other than formatting changesthetextisunaltered.

Myconclusionthen,whichIstillbelievenow,isthatthereweresomefundamental principles that united these methodologies, and these principles were a notable contrastfromtheassumptionsoftheestablishedmethodologies. Thisessayhascontinuedtobeoneofthemostpopularessaysonmywebsite,which means I feel somewhat bidden to keep it up to date. In its original form the essay bothexploredthesedifferencesinprinciplesandprovidedasurveyofagilemethods asIthenunderstoodthem.Toomuchhashappenedwithagilemethodssinceforme tokeepupwiththesurveypart,althoughIdoprovidesomelinkstocontinueyour explorations.Thedifferencesinprinciplesstillremain,andthisdiscussionI'vekept.

FromNothing,toMonumental,toAgile
Mostsoftwaredevelopmentisachaoticactivity,oftencharacterizedbythephrase "codeandfix".Thesoftwareiswrittenwithoutmuchofanunderlyingplan,andthe design of the system is cobbled together from many short term decisions. This

actually works pretty well as the system is small, but as the system grows it becomesincreasinglydifficulttoaddnewfeaturestothesystem.Furthermorebugs becomeincreasinglyprevalentandincreasinglydifficulttofix.Atypicalsignofsuch asystemisalongtestphaseafterthesystemis"featurecomplete".Suchalongtest phase plays havoc with schedules as testing and debugging is impossible to schedule. Theoriginalmovementtotrytochangethisintroducedthenotionofmethodology. Thesemethodologiesimposeadisciplinedprocessuponsoftwaredevelopmentwith theaimofmakingsoftwaredevelopmentmorepredictableandmoreefficient.They do this by developing a detailed process with a strong emphasis on planning inspired by other engineering disciplines which is why I like to refer to them as engineering methodologies (another widely used term for them is plandriven methodologies). Engineering methodologies have been around for a long time. They've not been noticeableforbeingterriblysuccessful.Theyareevenlessnotedforbeingpopular. The most frequent criticism of these methodologies is that they are bureaucratic. There's so much stuff to do to follow the methodology that the whole pace of developmentslowsdown. Agile methodologies developed as a reaction to these methodologies. For many peopletheappealoftheseagilemethodologiesistheirreactiontothebureaucracy oftheengineeringmethodologies.Thesenewmethodsattemptausefulcompromise betweennoprocessandtoomuchprocess,providingjustenoughprocesstogaina reasonablepayoff. The result of all of this is that agile methods have some significant changes in emphasisfromengineeringmethods.Themostimmediatedifferenceisthattheyare less documentoriented, usually emphasizing a smaller amount of documentation foragiventask.Inmanywaystheyarerathercodeoriented:followingaroutethat saysthatthekeypartofdocumentationissourcecode. However I don't think this is the key point about agile methods. Lack of documentationisasymptomoftwomuchdeeperdifferences:

Agilemethodsareadaptiveratherthanpredictive.Engineeringmethodstend totrytoplanoutalargepartofthesoftwareprocessingreatdetailforalong spanoftime,thisworkswelluntilthingschange.Sotheirnatureistoresist change. The agile methods, however, welcome change. They try to be processes that adapt and thrive on change, even to the point of changing themselves. Agile methods are peopleoriented rather than processoriented. The goal of engineering methods is to define a process that will work well whoever happenstobeusingit.Agilemethodsassertthatnoprocesswillevermake

uptheskillofthedevelopmentteam,sotheroleofaprocessistosupportthe developmentteamintheirwork. InthefollowingsectionsI'llexplorethesedifferencesinmoredetail,sothatyoucan understand what an adaptive and peoplecentered process is like, its benefits and drawbacks, and whether it's something you should use: either as a developer or customerofsoftware.

PredictiveversusAdaptive
SeparationofDesignandConstruction
The usual inspiration for methodologies is engineering disciplines such as civil or mechanical engineering. Such disciplines put a lot of emphasis on planning before youbuild.Suchengineerswillworkonaseriesofdrawingsthatpreciselyindicate whatneedstobebuiltandhowthesethingsneedtobeputtogether.Manydesign decisions,suchashowtodealwiththeloadonabridge,aremadeasthedrawings are produced. The drawings are then handed over to a different group, often a differentcompany,tobebuilt.It'sassumedthattheconstructionprocesswillfollow the drawings. In practice the constructors will run into some problems, but these areusuallysmall. Sincethedrawingsspecifythepiecesandhowtheyneedtobeputtogether,theyact as the foundation for a detailed construction plan. Such a plan can figure out the tasksthatneedtobedoneandwhatdependenciesexistbetween thesetasks.This allows for a reasonably predictable schedule and budget for construction. It also says in detail how the people doing the construction work should do their work. Thisallowstheconstructiontobelessskilledintellectually,althoughtheyareoften veryskilledmanually. So what we see here are two fundamentally different activities. Design which is difficult to predict and requires expensive and creative people, and construction which is easierto predict. Oncewe have the design, we can planthe construction. Oncewehavetheplanfortheconstruction,wecanthendealwithconstructionina muchmorepredictableway.Incivilengineeringconstructionismuchbiggerinboth costandtimethandesignandplanning. Sotheapproachforsoftwareengineeringmethodologieslookslikethis:wewanta predictable schedule that can use people with lower skills. To do this we must separatedesignfromconstruction.Thereforeweneedtofigure outhowtodothe

design for software so that the construction can be straightforward once the planningisdone. Sowhatformdoesthisplantake?Formany,thisistheroleofdesignnotationssuch astheUML.IfwecanmakeallthesignificantdecisionsusingtheUML,wecanbuild a construction plan and then hand these designs off to coders as a construction activity. Buthereliesthecrucialquestion.Canyougetadesignthatiscapableofturningthe coding into a predictable construction activity? And if so, is cost of doing this sufficientlysmalltomakethisapproachworthwhile? Allofthisbringsafewquestionstomind.Thefirstisthematterofhowdifficultitis togetaUMLlikedesignintoastatethatitcanbehandedovertoprogrammers.The problem with a UMLlike design is that it can look very good on paper, yet be seriouslyflawedwhenyouactuallyhavetoprogramthething.Themodelsthatcivil engineersusearebasedonmanyyearsofpracticethatareenshrinedinengineering codes. Furthermore the key issues, such as the way forces play in the design, are amenable to mathematical analysis. The only checking we can do of UMLlike diagramsispeerreview.Whilethisishelpfulitleadstoerrorsinthedesignthatare often only uncovered during coding and testing. Even skilled designers, such as I considermyselftobe,areoftensurprisedwhenweturnsuchadesignintosoftware. Anotherissueisthatofcomparativecost.Whenyoubuildabridge,thecostofthe designeffortisabout10%ofthejob,withtherestbeingconstruction.Insoftware theamountoftimespentincodingismuch,muchlessMcConnellsuggeststhatfora large project, only 15% of the project is code and unit test, an almost perfect reversal of the bridge building ratios. Even if you lump in all testing as part of construction,thendesignisstill50%ofthework.Thisraisesanimportantquestion about the nature of design in software compared to its role in other branches of engineering. ThesekindsofquestionsledJackReevestosuggestthatinfactthesourcecodeisa designdocumentandthattheconstructionphaseisactuallytheuseofthecompiler and linker. Indeed anything that you can treat as construction can and should be automated. Thisthinkingleadstosomeimportantconclusions:

Insoftware:constructionissocheapastobefree In software all the effort is design, and thus requires creative and talented people Creativeprocessesarenoteasilyplanned,andsopredictabilitymaywellbe animpossibletarget. Weshouldbeverywaryofthetraditionalengineeringmetaphorforbuilding software.It'sadifferentkindofactivityandrequiresadifferentprocess

TheUnpredictabilityofRequirements
There'sarefrainI'veheardoneveryproblemprojectI'verun into.Thedevelopers come to me and say "the problem with this project is that the requirements are always changing".The thing Ifind surprising about this situation is that anyone is surprised by it. In building business software requirements changesarethenorm, thequestioniswhatwedoaboutit. One route is to treat changing requirements as the result of poor requirements engineering.Theideabehindrequirementsengineeringistogetafullyunderstood pictureoftherequirementsbeforeyoubeginbuildingthesoftware,getacustomer signofftotheserequirements,andthensetupproceduresthatlimitrequirements changesafterthesignoff. Oneproblemwiththisisthatjusttryingtounderstandtheoptionsforrequirements is tough. It's even tougher because the development organization usually doesn't provide cost information on the requirements. You end up being in the situation whereyoumayhavesomedesireforasunroofonyourcar,butthesalesmancan't tell you if it adds $10 to the cost of the car, or $10,000. Without much idea of the cost,howcanyoufigureoutwhetheryouwanttopayforthatsunroof? Estimation is hard for many reasons. Part of it is that software development is a designactivity,andthushardtoplanandcost.Partofitis thatthebasicmaterials keepchangingrapidly.Partofitisthatsomuchdependsonwhichindividualpeople areinvolved,andindividualsarehardtopredictandquantify. Software's intangible nature also cuts in. It's very difficult to see what value a softwarefeaturehasuntilyouuseitforreal.Onlywhenyouuseanearlyversionof some software do you really begin to understand what features are valuable and whatpartsarenot. This leads to the ironic point that people expect that requirements should be changeable. After all software is supposed to be soft. So not just are requirements changeable,theyoughttobechangeable.Ittakesalotofenergytogetcustomersof software to fix requirements. It's even worse if they've ever dabbled in software developmentthemselves,becausethenthey"know"thatsoftwareiseasytochange. Butevenifyoucouldsettleallthatandreallycouldgetanaccurateandstablesetof requirements you're probably still doomed. In today's economy the fundamental businessforcesarechangingthevalueofsoftwarefeaturestoorapidly.Whatmight beagoodsetofrequirementsnow,isnotagoodsetinsixmonthstime.Evenifthe customers can fix their requirements, the business world isn't going to stop for them. And many changes in the business world are completely unpredictable: anyone who says otherwise is either lying, or has already made a billion on stock markettrading.

Everything else in software development depends on the requirements. If you cannotgetstablerequirementsyoucannotgetapredictableplan.

IsPredictabilityImpossible?
In general, no. There are some software developments where predictability is possible. Organizations such as NASA's space shuttle software group are a prime example of where software development can be predictable. It requires a lot of ceremony,plentyoftime,alargeteam,andstablerequirements.Thereareprojects outtherethatarespaceshuttles.HoweverIdon'tthinkmuchbusinesssoftwarefits intothatcategory.Forthisyouneedadifferentkindofprocess. Oneofthebigdangersistopretendthatyoucanfollowapredictableprocesswhen you can't. People who work on methodology are not very good at identifying boundaryconditions:theplaceswherethemethodologypassesfromappropriatein inappropriate. Most methodologists want their methodologies to be usable by everyone, so they don't understand nor publicize their boundary conditions. This leads to people using a methodology in the wrong circumstances, such as using a predictablemethodologyinaunpredictablesituation. There's a strong temptation to do that. Predictability is a very desirable property. Howeverifyoubelieveyoucanbepredictablewhenyoucan't,itleadstosituations wherepeoplebuildaplanearlyon,thendon'tproperlyhandlethesituationwhere theplanfallsapart.Youseetheplanandrealityslowlydriftingapart.Foralongtime youcanpretendthattheplanisstillvalid.Butatsomepointthedriftbecomestoo muchandtheplanfallsapart.Usuallythefallispainful. So if you are in a situation that isn't predictable you can't use a predictive methodology.That'sahardblow.Itmeansthatmanyofthemodelsforcontrolling projects, many of the models for the whole customer relationship, just aren't true anymore.Thebenefitsofpredictabilityaresogreat,it'sdifficulttoletthemgo.Like somanyproblemsthehardestpartissimplyrealizingthattheproblemexists. However letting go of predictability doesn't mean you have to revert to uncontrollablechaos.Insteadyouneedaprocessthatcangive youcontroloveran unpredictability.That'swhatadaptivityisallabout.

ControllinganUnpredictableProcessIterations
So how do we control ourselves in an unpredictable world? The most important, and still difficult part is to know accurately where we are. We need an honest feedback mechanism which can accurately tellus whatthesituationisatfrequent intervals.

Thekeytothisfeedbackisiterativedevelopment.Thisis notanewidea.Iterative development has been around for a while under many names: incremental, evolutionary, staged, spiral... lots of names. The key to iterative development is to frequently produce working versions of the final system that have a subset of the required features. These working systems are short on functionality, but should otherwise be faithful to the demands of the final system. They should be fully integratedandascarefullytestedasafinaldelivery. Thepointofthisisthatthereisnothinglikeatested,integratedsystemforbringing a forceful dose of reality into any project. Documents can hide all sorts of flaws. Untested code can hide plenty of flaws. But when people actually sit in front of a systemandworkwithit,then flawsbecometrulyapparent:bothintermsofbugs andintermsofmisunderstoodrequirements. Iterative development makes sense in predictable processes as well. But it is essentialinadaptiveprocessesbecauseanadaptiveprocessneedstobeabletodeal withchangesinrequiredfeatures.Thisleadstoastyleofplanningwherelongterm plansareveryfluid,andtheonlystableplansareshorttermplansthataremadefor a single iteration. Iterative development gives you a firm foundation in each iterationthatyoucanbaseyourlaterplansaround. A key question for this is how long an iteration should be. Different people give different answers. XP suggests iterations of one or two weeks. SCRUM suggests a length of amonth. Crystal may stretch further. The tendency, however,is tomake each iteration as short as you can get away with. This provides more frequent feedback,soyouknowwhereyouaremoreoften.

TheAdaptiveCustomer
This kind of adaptive process requires a different kind of relationship with a customerthantheonesthatareoftenconsidered,particularlywhendevelopmentis donebyaseparatefirm.Whenyouhireaseparatefirmtodosoftwaredevelopment, mostcustomerswouldpreferafixedpricecontract.Tellthedeveloperswhatthey want, ask for bids, accept a bid, and then the onus is on the development organizationtobuildthesoftware. Afixedpricecontractrequiresstablerequirementsandhenceapredictiveprocess. Adaptive processes and unstable requirements imply you cannot work with the usualnotionoffixedprice.Tryingtofitafixedpricemodel toanadaptiveprocess ends up in a very painful explosion. The nasty part of this explosion is that the customergetshurteverybitasmuchasthesoftwaredevelopmentcompany.After allthecustomerwouldn'tbewantingsomesoftwareunlesstheirbusinessneededit. If they don't get it their business suffers. So even if they pay the development companynothing,theystilllose.Indeedtheylosemorethantheywouldpayforthe

software(whywouldtheypayforthesoftwareifthebusinessvalueofthatsoftware wereless?) So there's dangers for both sides in signing the traditional fixed price contract in conditionswhereapredictiveprocesscannotbeused.Thismeansthatthecustomer hastoworkdifferently. This doesn't mean that you can't fix a budget for software upfront. What it does meanisthatyoucannotfixtime,priceandscope.Theusualagileapproachistofix timeandprice,andtoallowthescopetovaryinacontrolledmanner. In an adaptive process the customer has much finergrained control over the software development process. At every iteration they get both to check progress and to alter the direction of the software development. This leads to much closer relationshipwiththesoftwaredevelopers,atruebusinesspartnership.Thislevelof engagement is not for every customer organization, nor for every software developer;butit'sessentialtomakeanadaptiveprocessworkproperly. Allthisyieldsanumberofadvantagesforthecustomer.Fora starttheygetmuch moreresponsivesoftwaredevelopment.Ausable,althoughminimal,systemcango intoproductionearlyon.Thecustomercanthenchangeitscapabilitiesaccordingto changes in the business, and also from learning from how the system is used in reality. Everybitasimportantasthisisgreatervisibilityintothetruestateoftheproject. The problem with predictive processes is that project quality is measured by conformancetoplan.Thismakesitdifficultforpeopletosignalwhenrealityandthe plandiverge.Thecommonresultisabigslipintheschedulelateintheproject.Inan agile project there is a constant reworking of the plan with every iteration. If bad news is lurking it tends to come earlier, when there is still time to do something aboutit.Indeedthisriskcontrolisakeyadvantageofiterativedevelopment. Agile methods take this further by keeping the iteration lengths small, but also by seeing these variations in a different way. Mary Poppendieck summed up this differenceinviewpointbestformewithherphrase"Alatechangeinrequirementsis acompetitiveadvantage".Ithinkmostpeoplehavenoticedthatit'sverydifficultfor business people to really understand what they need from software in the beginning. Often we see that people learn during the process what elements are valuable and which ones aren't. Often the most valuable features aren't at all obviousuntilcustomerhavehadachancetoplaywiththesoftware.Agilemethods seek to take advantage of this, encouraging business people to learn about their needsasthesystemgetsbuilt,andtobuildthesysteminsuchawaythatchanges canbeincorporatedquickly.
SeeRelatedArticle:IsDesignDead?

For my keynote at the first XP/Agile conference (XP 2000) I prepared this essay on the role of design in extremeprogramming.

Allthishasanimportantbearingwhatconstitutesasuccessfulproject.Apredictive projectisoftenmeasuredbyhowwellitmetitsplan.Aprojectthat'sontimeand oncost is considered to be a success. This measurement is nonsense to an agile environment. For agilists the question is business value did the customer get software that's more valuable to them than the cost put into it. A good predictive projectwillgoaccordingtoplan,agoodagileprojectwillbuildsomethingdifferent andbetterthantheoriginalplanforesaw.

PuttingPeopleFirst
Executinganadaptiveprocessisnoteasy.Inparticularitrequiresaveryeffective team of developers. The team needs to be effective both in the quality of the individuals, and in the way the team blends together. There's also an interesting synergy: not just does adaptivity require a strong team, most good developers preferanadaptiveprocess.

PlugCompatibleProgrammingUnits
One of the aims of traditional methodologies is to develop a process where the peopleinvolvedarereplaceableparts.Withsuchaprocessyou cantreatpeopleas resources who are available in various types. You have an analyst, some coders, some testers, a manager. The individuals aren't so important, only the roles are important.Thatwayifyouplanaprojectitdoesn'tmatterwhichanalystandwhich testers you get, just that you know how many you have so you know how the numberofresourcesaffectsyourplan. But this raises a key question: are the people involved in software development replaceable parts? One of the keyfeatures ofagile methods is that they reject this assumption. PerhapsthemostexplicitrejectionofpeopleasresourcesisAlistairCockburn.Inhis paper Characterizing People as NonLinear, FirstOrder Components in Software Development, he makes the point that predictable processes require components thatbehaveinapredictableway.Howeverpeoplearenotpredictablecomponents. Furthermore his studies of software projects have led him to conclude the people arethemostimportantfactorinsoftwaredevelopment. In the title, [of his article] I refer to people as "components". That is how people are treatedintheprocess/methodologydesignliterature.Themistakeinthisapproachis

that "people" are highly variable and nonlinear, with unique success and failure modes. Those factors are firstorder, not negligible factors. Failure of process and methodology designers to account for them contributes to the sorts of unplanned projecttrajectorieswesooftensee. [Cockburnnonlinear] One wonders if not the nature of software development works against us here. Whenwe'reprogrammingacomputer,wecontrolaninherentlypredictabledevice. Sincewe'reinthisbusinessbecausewearegoodatdoingthat,weareideallysuited tomessingupwhenfacedwithhumanbeings. Although Cockburn is the most explicit in his peoplecentric view of software development,thenotionofpeoplefirstisacommonthemewith manythinkersin software. The problem, too often, is that methodology has been opposed to the notionofpeopleasthefirstorderfactorinprojectsuccess. Thiscreatesastrongpositivefeedbackeffect.Ifyouexpectallyourdeveloperstobe plugcompatibleprogrammingunits,youdon'ttrytotreatthemasindividuals.This lowersmorale(andproductivity).Thegoodpeoplelookforabetterplacetobe,and youendupwithwhatyoudesire:plugcompatibleprogrammingunits. Deciding that people come first is a big decision, one that requires a lot of determination to push through. The notion of people as resources is deeply ingrained in business thinking, its roots going back to the impact of Frederick Taylor's Scientific Management approach. In running a factory, this Taylorist approachmaymakesense.Butforthehighlycreativeandprofessionalwork,which I believe software development to be, this does not hold. (And in fact modern manufacturingisalsomovingawayfromtheTayloristmodel.)

ProgrammersareResponsibleProfessionals
A key part of the Taylorist notion is that the people doing the work are not the peoplewhocanbestfigureouthowbesttodothatwork.Inafactorythismaybe trueforseveralreasons.Partofthisisthatmanyfactoryworkersarenotthemost intelligent or creative people, in part this is because there is a tension between management and workers in that management makes more money when the workersmakeless. Recenthistoryincreasinglyshowsushowuntruethisisforsoftwaredevelopment. Increasingly bright and capable people are attracted to software development, attractedbybothitsglitzandbypotentiallylargerewards.(Bothofwhichtempted meawayfromelectronicengineering.)Despitethedownturnoftheearly00's,there isstillagreatdealoftalentandcreativityinsoftwaredevelopment.

(Theremaywellbeagenerationaleffecthere.Someanecdotalevidencemakesme wonderifmorebrighterpeoplehaveventuredintosoftwareengineeringinthelast fifteenyearsorso.Ifsothiswouldbeareasonforwhythereissuchacultofyouth inthecomputerbusiness,likemostcultsthereneedstobeagrainoftruthinit.) Whenyouwanttohireandretaingoodpeople,youhavetorecognizethattheyare competentprofessionals.Assuchtheyarethebestpeopletodecidehowtoconduct their technical work. The Taylorist notion of a separate planning department that decideshowtodothingsonlyworksiftheplannersunderstand howtodothejob betterthanthosedoingit.Ifyouhavebright,motivatedpeopledoingthejobthen thisdoesnothold.

ManagingaPeopleOrientedProcess
Peopleorientationmanifestsitselfinanumberofdifferentwaysinagileprocesses. Itleadstodifferenteffects,notallofthemareconsistent. Oneofthekeyelementsisthatofacceptingtheprocessratherthantheimposition ofaprocess.Oftensoftwareprocessesareimposedbymanagementfigures.Assuch they are often resisted, particularly when the management figures have had a significant amount of time away from active development. Accepting a process requirescommitment,andassuchneedstheactiveinvolvementofalltheteam. This ends up with the interesting result that only the developers themselves can choosetofollowanadaptiveprocess.ThisisparticularlytrueforXP,whichrequires alotofdisciplinetoexecute.Crystalconsidersitselfasalessdisciplinedapproach that'sappropriateforawideraudience. Anotherpointisthatthedevelopersmustbeabletomakealltechnicaldecisions.XP getstotheheartofthiswhereinitsplanningprocessitstatesthatonlydevelopers maymakeestimatesonhowmuchtimeitwilltaketodosomework. Such technical leadership is a big shift for many people in management positions. Such an approach requires a sharing of responsibility where developers and managementhaveanequalplaceintheleadershipoftheproject.NoticethatIsay equal.Managementstillplaysarole,butrecognizestheexpertiseofdevelopers. An important reason for this is the rate of change of technology in our industry. After afew yearstechnical knowledgebecomesobsolete.Thishalflifeoftechnical skills is without parallel in any other industry. Even technical people have to recognizethatenteringmanagementmeanstheirtechnicalskillswillwitherrapidly. Exdevelopers need to recognize that their technical skills will rapidly disappear andtheyneedtotrustandrelyoncurrentdevelopers.

TheDifficultyofMeasurement

If you have a process where the people who say how work should be done are different from the people who actually do it, the leaders need some way of measuringhoweffectivethedoersare.InScientificManagementtherewasastrong pushtodevelopobjectiveapproachestomeasuringtheoutputofpeople. This is particularly relevant to software because of the difficulty of applying measurement to software. Despite our best efforts we are unable to measure the mostsimplethingsaboutsoftware,suchasproductivity.Withoutgoodmeasuresfor thesethings,anykindofexternalcontrolisdoomed. Introducing measured management without good measures leads to its own problems. Robert Austin made an excellent discussion of this. He points out that when measuring performance you have to get all the important factors under measurement. Anything that's missing has the inevitable result that the doers will alter what they do to produce the best measures, even if that clearly reduces the true effectiveness of what they do. This measurement dysfunction is the Achilles heelofmeasurementbasedmanagement. Austin's conclusion is that you have to choose between measurementbase management and delegatory management (where the doers decide how to do the work). Measurementbased management is best suited to repetitive simple work, with low knowledge requirements and easily measured outputs exactly the oppositeofsoftwaredevelopment. Thepointofallthisisthattraditionalmethodshaveoperatedundertheassumption that measurementbased management is the most efficient way of managing. The agile community recognizes that the characteristics of software development are such that measurement based management leads to very high levels of measurement dysfunction. It's actually more efficient to use a delegatory style of management, which is the kind of approach that is at the center of the agilist viewpoint.

TheRoleofBusinessLeadership
But the technical people cannot do the whole process themselves. They need guidanceonthebusinessneeds.Thisleadstoanotherimportantaspectofadaptive processes:theyneedveryclosecontactwithbusinessexpertise. This goes beyond most projects involvement of the business role. Agile teams cannot exist with occasional communication . They need continuous access to business expertise. Furthermore this access is not something that is handled at a management level, it is something that is present for every developer. Since developersarecapableprofessionalsintheirowndiscipline,theyneedtobeableto workasequalswithotherprofessionalsinotherdisciplines.

Alargepartofthis,ofcourse,isduetothenatureofadaptivedevelopment.Sincethe whole premise of adaptive development is that things change quickly, you need constantcontacttoadviseeverybodyofthechanges. Thereisnothingmorefrustratingtoadeveloperthanseeingtheirhardworkgoto waste.Soit'simportanttoensurethatthereisgoodqualitybusinessexpertisethat isbothavailabletothedeveloperandisofsufficientqualitythatthedevelopercan trustthem.

TheSelfAdaptiveProcess
SofarI'vetalkedaboutadaptivityinthecontextofaprojectadaptingitssoftware frequently to meet the changing requirements of its customers. However there's another angle to adaptivity: that of the process changing over time. A project that begins using an adaptive process won't have the same process a year later. Over time,theteamwillfindwhatworksforthem,andaltertheprocesstofit. The first part of selfadaptivity is regular reviews of the process. Usually you do thesewitheveryiteration.Attheendofeachiteration,haveashortmeetingandask yourselfthefollowingquestions(culledfromNormKerth)

Whatdidwedowell? Whathavewelearned? Whatcanwedobetter? Whatpuzzlesus?

Thesequestionswillleadyoutoideastochangetheprocessforthenextiteration.In thiswayaprocessthatstartsoffwithproblemscanimproveastheprojectgoeson, adaptingbettertotheteamthatusesit. If selfadaptivity occurs within a project, it's even more marked across an organization. A consequence of selfadaptivity is that you should never expect to findasinglecorporatemethodology.Insteadeachteamshouldnotjustchoosetheir own process, but should also actively tune their process as they proceed with the project.Whilebothpublishedprocessesandtheexperienceofotherprojectscanact as an inspiration and a baseline, the developers professional responsibility is to adapttheprocesstothetaskathand.

FlavorsofAgileDevelopment
The term 'agile' refers to a philosophy of software development. Under this broad umbrellasitsmanymorespecificapproachessuchasExtremeProgramming,Scrum, LeanDevelopment,etc.Eachofthesemoreparticularapproacheshasitsownideas, communities and leaders. Each community is a distinctgroup of its own but to be correctly called agile it should follow the same broad principles. Each community alsoborrowsfromideasandtechniquesfromeachother.Manypractitionersmove between different communities spreading different ideas around all in all it's a complicatedbutvibrantecosystem. SofarI'vegivenmytakeontheoverallpictureofmydefinitionofagile.NowIwant to introduce some of the different agile communities. I can only give a quick overviewhere,butIdoincludereferencessoyoucandigfurtherifyoulike. Since I'm about to start giving more references, this is a good point to point out somesourcesforgeneralinformationonagilemethods.ThewebcenteristheAgile Allianceanonprofitsetuptoencourageandresearchagilesoftwaredevelopment. For books I'd suggest overviews by Alistair Cockburn and Jim Highsmith. Craig Larman's book on agile development contains a very useful history of iterative development. For more of my views on agile methods look at the appropriate sectionsofmyarticlesandblog. The following list is by no means complete. It reflects a personal selection of the flavorsofagilethathavemostinterestedandinfluencedmeoverthelastdecadeor so.

AgileManifesto
Theterm'agile'gothijackedforthisactivityinearly2001whenabunchofpeople who had been heavily involved in this work got together to exchange ideas and cameupwiththeManifestoforAgileSoftwareDevelopment. Prior to this workshop a number of different groups had been developing similar ideasaboutsoftwaredevelopment.Most,butbynomeansall,ofthisworkhadcome out of the ObjectOriented software community that had long advocated iterative development approaches. This essay was originally written in 2000 to try to pull togetherthesevariousthreads.Atthattimetherewasnocommonnameforthese approaches,butthemoniker'lightweight'hadgrownuparoundthem.Manyofthe peopleinvolveddidn'tfeelthiswasagoodtermasitdidn'taccuratelyconveythe essenceofwhattheseapproacheswereabout. Therehadbeensometalkingaboutbroaderissuesintheseapproachesin2000ata workshophostedbyKentBeckinOregon.Althoughthisworkshop wasfocusedon Extreme Programming (the community that at that time had gained the most

attention) several non XPers had attended. One the discussions that came up was whetheritwasbetterforXPtobeabroadorconcretemovement.Kentpreferreda morefocusedcohesivecommunity. Theworkshopwasorganized,ifIremembercorrectly,primarily byJimHighsmith and Bob Martin. They contacted people who they felt were active in communities with these similar ideas and got seventeen of them together for the Snowbird workshop.Theinitialideawasjusttogettogetherandbuildbetterunderstandingof each others' approaches. Robert Martin was keen to get some statement, a manifestothatcouldbeusedtorallytheindustrybehindthesekindsoftechniques. We also decided we wanted to choose a name to act as an umbrella name for the variousapproaches. Duringthecourseoftheworkshopwedecidedtouse'agile'as theumbrellaname, andcameupwithvaluespartofthemanifesto.Theprinciplessectionwasstartedat theworkshopbutmostlydevelopedonawikiafterwards. Theeffortclearlystruckanerve,Ithinkwewereallverysurprisedatthedegreeof attention and appreciation the manifesto got. Although the manifesto is hardly a rigorous definition of agile, it does provide a focusing statement that helps concentratetheideas.Shortlyafterwefinishedthemanifesto JimHighsmithandI wroteanarticleforSDMagazinethatprovidedsomecommentarytothemanifesto. Laterthatyear, mostof the seventeen whowrotethemanifesto got back together again, with quite a few others, at OOPSLA 2001. There was a suggestion that the manifesto authors should begin some ongoing agile movement, but the authors agreedthattheywerejustthepeoplewhohappenedtoturnupforthatworkshop and produced that manifesto. There was no way that that group could claim leadershipofthewholeagilecommunity.Wehadhelpedlaunchtheshipandshould letitgoforwhoeverwhowantedtosailinhertodoso.Sothatwastheendofthe seventeenmanifestoauthorsasanorganizedbody. Onenextstepthatdidfollow,withtheactiveinvolvementofmanyoftheseauthors, wastheformationoftheagilealliance.Thisgroupisanonprofitgroupintendedto promote and research agile methods. Amongst other things it sponsors an annual conferenceintheUS.

XP(ExtremeProgramming)
During the early popularity of agile methods in the late 1990's, Extreme Programmingwastheonethatgotthelion'sshareofattention.Inmanywaysitstill does. The roots of XP lie in the Smalltalk community, and in particular the close collaborationofKentBeckandWardCunninghaminthelate1980's.Bothofthem

refinedtheirpracticesonnumerousprojectsduringtheearly90's,extendingtheir ideas of a software development approach that was both adaptive and people oriented. Kent continued to develop his ideas during consulting engagements, in particular the Chrysler C3 project, which has since become known as the creation project of extreme programming. He started using the term 'extreme programming' around 1997. (C3 also marked my initial contact with Extreme Programming and the beginningofmyfriendshipwithKent.) During the late 1990's word of Extreme Programming spread, initially through descriptions on newsgroups and Ward Cunningham's wiki, where Kent and Ron Jeffries (a colleague at C3) spent a lot of time explaining and debating the various ideas. Finally a number of books were published towards the end of the 90's and start of 00's that went into some detail explaining the various aspects of the approach. Most of these books took Kent Beck's white book as their foundation. Kentproducedasecondeditionofthewhitebookin2004whichwasasignificant rearticulationoftheapproach. XP begins with five values (Communication, Feedback, Simplicity, Courage, and Respect). It then elaborates these into fourteen principles and again into twenty fourpractices.Theideaisthatpracticesareconcretethingsthatateamcandoday today, while values are the fundamental knowledge and understanding that underpins the approach. Values without practices are hard to apply and can be applied in so many ways that it's hard to know where to start. Practices without valuesareroteactivitieswithoutapurpose.Bothvaluesandpracticesareneeded, but there's a big gap between them the principles help bridge that gap. Many of XP's practices are old, tried and tested techniques, yet often forgotten by many, including most planned processes. As well as resurrecting these techniques, XP weaves them into a synergistic whole where each one is reinforced by the others andgivenpurposebythevalues. Oneofthemoststriking,aswellasinitiallyappealingtome,isitsstrongemphasis on testing. While all processes mention testing, most do so with a pretty low emphasis. However XP puts testing at the foundation of development, with every programmer writing tests as they write their production code. The tests are integrated into a continuous integration and build process which yields a highly stableplatformforfuturedevelopment.XP'sapproachhere,oftendescribedunder theheadingofTestDrivenDevelopment(TDD)hasbeeninfluentialeveninplaces thathaven'tadoptedmuchelseofXP. There's a great deal of publications about extreme programming. One area of confusion, however, is the shift between the first and second edition of the white book. I said above that the second edition is a 'rearticulation' of extreme programming,inthattheapproachisstillthesamebutitisdescribedinadifferent style. The first edition (with four values, twelve practices and some importantbut

mostlyignoredprinciples)hadahugeinfluenceonthesoftwareindustryandmost descriptions of extreme programming were written based on the first edition's description. Keep that in mind as you read material on XP, particularly if it was prepared prior to 2005. Indeed most of the common web descriptions of XP are basedonthefirstedition. Thenaturalstartingplacetodiscovermoreisthesecondeditionofthewhitebook. This book explains the background and practices of XP in a short (160 page) package.KentBeckeditedamulticoloredseriesofbooksonextremeprogramming aroundtheturnofthecentury,ifforcedtopickonetosuggestI'dgoforthepurple one,rememberthatlikemostmaterialit'sbasedonthefirstedition. There's a lot of material on the web about XP but most of it is based on the first edition. One of the few descriptions I know of that takes account of the second edition is a paper on The New XP (PDF) by Michele Marchesi who hosted the original XP conferences in Sardinia. For discussion on XP there is a yahoo mailing list. My involvement in the early days and friendships within the XP community mean thatIhaveadistinctfamiliarity,fondnessandbiastowardsXP.Ithinkit'sinfluence owestomarryingtheprinciplesofagiledevelopmentwithasolidsetoftechniques for actually carrying them out. Much of the early writings on agile neglected the latter, raising questions about whether the agile ideas were really possible. XP providedthetoolsbywhichthehopesofagilitycouldberealized.

Scrum
Scrumalsodevelopedinthe80'sand90'sprimarilywithOOdevelopmentcirclesas ahighlyiterativedevelopmentmethodology.It'smostwellknowndeveloperswere KenSchwaber,JeffSutherland,andMikeBeedle. Scrumconcentratesonthemanagementaspectsofsoftwaredevelopment,dividing development into thirty day iterations (called 'sprints') and applying closer monitoringandcontrolwithdailyscrummeetings.Itplacesmuchlessemphasison engineeringpracticesandmanypeoplecombineitsprojectmanagementapproach with extreme programming's engineering practices. (XP's management practices aren'treallyverydifferent.) KenSchwaberisoneofthemostactiveproponentsofScrum,hiswebsiteisagood place to start looking for more information and his book is probably the best first reference.

Crystal

AlistairCockburnhaslongbeenoneoftheprincipalvoicesintheagilecommunity. He developed the Crystal family of software development methods as a group of approaches tailored to different size teams. Crystal is seen as a family because Alistairbelievesthatdifferentapproachesarerequiredasteamsvaryinsizeandthe criticalityoferrorschanges. Despite their variations all crystal approaches share common features. All crystal methods have three priorities: safety (in project outcome, efficiency, habitability (developerscanlivewithcrystal).Theyalsosharecommonproperties,ofwhichthe most important three are: Frequent Delivery, Reflective Improvement, and Close Communication. Thehabitabilitypriorityisanimportantpartofthecrystalmindset.Alistair'squest (asIseeit)islookingforwhatistheleastamountofprocessyou candoandstill succeed with an underlying assumption of lowdiscipline that is inevitable with humans. As a result Alistair sees Crystal as requiring less discipline that extreme programming, trading off less efficiency for a greater habitability and reduced chancesoffailure. Despite Crystal's outline, there isn't a comprehensive description of all it's manifestations.ThemostwelldescribedisCrystalClear,whichhasamodernbook description.ThereisalsoawikiforfurthermaterialanddiscussionofCrystal.

ContextDrivenTesting
Fromthebeginningit'sbeensoftwaredeveloperswhohavebeen drivingtheagile community.Howevermanyotherpeopleareinvolvedinsoftwaredevelopmentand are affected by this new movement. One obvious such group is testers, who often liveinaworldverymuchcontainedbywaterfallthinking.Withcommonguidelines thatstatethattheroleoftestingistoensureconformanceof software to upfront writtenspecifications,theroleoftestersinanagileworldisfarfromclear. Asitturnsout,severalpeopleinthetestingcommunityhavebeenquestioningmuch ofmainstreamtestingthinkingforquiteawhile.Thishasled toagroupknownas contextdriventesting.Thebestdescriptionofthisisthebook Lessons Learned in SoftwareTesting.Thiscommunityisalsoveryactiveontheweb,takealookatsites hostedbyBrianMarick(oneoftheauthorsoftheagilemanifesto),BrettPettichord, JamesBach,andCemKaner.

LeanDevelopment
I remember a few years ago giving a talk about agile methods at the Software Development conference and talking to an eager woman about parallels between the agile ideas and lean movement in manufacturing. Mary Poppendieck (and husband Tom) have gone on to be active supporters of the agile community, in

particular looking at the overlaps and inspirations between lean production and softwaredevelopment. TheleanmovementinmanufacturingwaspioneeredbyTaiichiOhnoatToyotaand is often known as the Toyota Production System. Lean production was an inspiration to many of the early agilists the Poppendiecks are most notable to describing how these ideas interact. In general I'm very wary of these kinds of reasoning by analogy, indeed the engineering separation between design and constructiongotusintothismessinthefirstplace.However analogiescanleadto goodideasandIthinktheleanideashaveintroducedmanyusefulideasandtools intotheagilemovement. The Poppendiecks' book and website are the obvious starting points for more information.

(Rational)UnifiedProcess
Anotherwellknownprocesstohavecomeoutoftheobjectorientedcommunityis theRationalUnifiedProcess(sometimesjustreferredtoastheUnifiedProcess).The originalideawasthatliketheUMLunifiedmodelinglanguages theUPcouldunify softwareprocesses.SinceRUPappearedaboutthesametimeastheagilemethods, there'salotofdiscussionaboutwhetherthetwoarecompatible. RUPisaverylargecollectionofpracticesandisreallyaprocessframeworkrather thanaprocess.Ratherthangiveasingleprocessforsoftwaredevelopmentitseeks to provide a common set of practices for teams to choose from for an individual project.Asaresultateam'sfirststepusingRUPshouldbetodefinetheirindividual process,orasRUPcallsit,adevelopmentcase. ThekeycommonaspectsofRUPisthatitisUseCaseDriven(developmentisdriven throughuservisiblefeatures),iterative,andarchitecturecentric(there'sapriority tobuildingaarchitectureearlyonthatwilllasttheprojectthrough). My experience with RUP is that it's problem is its infinite variability. I've seen descriptionsofRUPusagethatrangefromrigidwaterfallwith 'analysisiterations' topictureperfectagile.It'sstruckmethatthedesireofpeopletomarkettheRUPas thesingleprocessledtoaresultwherepeoplecandojustaboutanythingandcallit RUPresultinginRUPbeingameaninglessphrase. Despite all this there are some very strong people in the RUP community that are verymuchalignedwithagilethinking.I'vebeenimpressedinallmymeetingwith Phillippe Kruchten and his book is best starting point for RUP. Craig Larman has also developed descriptions of working with RUP in an agile style in his popular introductorybookonOOdesign.

Shouldyougoagile?
Using a agile method is not for everyone. There are a number of things to bear in mind if you decide to follow this path. However I certainly believe that these methodologies are widely applicable and should be used by more people than currentlyconsiderthem. In today's environment, the most common methodology is code and fix. Applying moredisciplinethanchaoswillalmostcertainlyhelp,andtheagileapproachhasthe advantagethatitismuchlessofastepthanusingaheavyweightmethod.Herethe lightweightofagilemethodsisanadvantage.Simplerprocessesaremorelikelyto befollowedwhenyouareusedtonoprocessatall. Forsomeonenewtoagilemethods,thequestioniswheretostart.Aswithanynew technologyorprocess,youneedtomakeyourownevaluationofit.Thisallowsyou toseehowitfitsintoyourenvironment.Asaresultmuchofmyadviceherefollows that I've given for other new approaches, bringing back memories of when I was firsttalkingaboutObjectOrientedtechniques. The first step is to find suitable projects to try agile methods out with. Since agile methods are so fundamentally peopleoriented, it's essential that you start with a teamthatwantstotryandworkinanagileway.Notjustisa reluctantteammore difficulttoworkwith,imposingagilemethodsonreluctantpeopleisfundamentally atoddswiththewholenotionofagiledevelopment. It's valuable to also have customers (those who need the software) who want to work in this kind of collaborative way. If customers don't collaborate, then you won'tseethefulladvantagesofanadaptiveprocess.Havingsaidthatwe'vefound on several occasions that we've worked with customers who didn't want to collaborate, but changed their mind over the first few months as they begun to understandtheagileapproach. A lot of people claim that agile methods can't be used on large projects. We (ThoughtWorks)havehadgoodsuccesswithagileprojectswitharound100people andmultiplecontinents.DespitethisIwouldsuggestpickingsomethingsmallerto startwith.Largeprojectsareinherentlymoredifficultanyway,soit'sbettertostart learningonaprojectofamoremanageablesize. Somepeopleadvisepickingaprojectwithlittlebusinessimpacttostartwith,that way if anything goes wrong then there's less damage. However an unimportant project often makes a poor test since nobody cares much about the outcome. I prefertoadvisepeopletotakeaprojectthat'salittlebitmorecriticalthanyouare comfortablewith.

Perhapsthemostimportantthingyoucandoisfindsomeonemoreexperiencedin agile methods to help you learn. Whenever anyone does anything new they inevitablymakemistakes.Findsomeonewhohasalreadymadelotsofmistakesso you can avoid making those yourself. Again this is something true for any new technologyortechnique,agoodmentorisworthherweightingold.Ofcoursethis adviceisselfservingsinceThoughtWorksandmanyofmyfriendsintheindustrydo mentoringonagilemethods.Thatdoesn'talterthefactthatIstronglybelieveinthe importanceoffindingagoodmentor. Andonceyou'vefoundagoodmentor,followtheiradvice.It'sveryeasytosecond guess much of this and I've learned from experience that many techniques can't reallybeunderstooduntilyou'vemadeareasonableattempttotrythemout.Oneof the best examples I heard was a client of ours who decided to trial extreme programmingforacoupleofmonths.Duringthatperiodtheymadeitclearthatthey woulddowhateverthementorsaideveniftheythoughtitwasabadidea.Atthe endofthattrialperiodtheywouldstopanddecideiftheywantedtocarryonwith any of the ideas or revert to the previous way of working. (In case you were wonderingtheydecidedtocarryonwithXP.) Oneoftheopenquestionsaboutagilemethodsiswheretheboundaryconditionslie. One of the problems with any new technique is that you aren't really aware of wheretheboundaryconditionsuntilyoucrossoverthemandfail.Agilemethodsare stilltooyoungtoseeenoughactiontogetasenseofwheretheboundariesare.This is further compounded by the fact that it's so hard to decide what success and failuremeaninsoftwaredevelopment,aswellastoomanyvaryingfactorstoeasily pindownthesourceofproblems. So where should you not use an agile method? I think it primarilycomes down to the people. If the people involved aren't interested in the kind of intense collaborationthatagileworkingrequires,thenit'sgoingtobeabigstruggletoget themtoworkwithit.InparticularIthinkthatthismeansyoushouldnevertryto imposeagileworkingonateamthatdoesn'twanttotryit. There's been lots of experience with agile methods over the last ten years. At ThoughtWorks we always use an agile approach if our clients are willing, which mostofthetimetheyare.I(andwe)continuetobebigfansofthiswayofworking.

You might also like