Naar inhoud springen

Agile-softwareontwikkeling

Uit Wikipedia, de vrije encyclopedie

Agile-softwareontwikkeling is een manier van softwareontwikkeling. Het Engelse woord agile betekent: behendig, lenig.

Hoewel de praktijken die onder de noemer agile vallen al gangbaar zijn sinds software ontwikkeld wordt, valt de geboorte van agile als term en concept, terug te brengen tot het Agile Manifesto.[1]

Iteratieve en incrementele softwareontwikkelingsmethoden gaan terug tot 1957[2], terwijl evolutionair projectbeheer[3][4] en adaptieve softwareontwikkeling[5] opkwamen in het begin van de jaren 1970.[6]

Agile Manifesto

[bewerken | brontekst bewerken]

Het Agile Manifesto[1] (Manifesto for Agile Software Development) werd opgesteld tijdens een informele bijeenkomst van zeventien softwareontwikkelaars. Deze bijeenkomst vond plaats van 11 tot en met 13 februari 2001 in "The Lodge" in Snowbird (Utah).

Dat waren: Kent Beck (Extreme Programming), Ward Cunningham (Extreme Programming), Dave Thomas (PragProg, Ruby), Jeff Sutherland (Scrum), Ken Schwaber (Scrum), Jim Highsmith (Adaptive Software Development), Alistair Cockburn (Crystal), Robert C. Martin (SOLID), Mike Beedle (Scrum), Arie van Bennekum, Martin Fowler (OOAD en UML), James Grenning, Andrew Hunt (PragProg, Ruby), Ron Jeffries (Extreme Programming), Jon Kern, Brian Marick (Ruby, TDD), en Steve Mellor (OOA). Samen publiceerden zij het manifest.

Het handvest en de principes vormden een uitwerking van ideeën die halfweg de jaren negentig waren ontstaan, als reactie op methoden die men traditioneel klasseert als waterval-ontwikkelmodellen. Die modellen werden ervaren als bureaucratisch, traag en bekrompen en zouden de creativiteit en effectiviteit van ontwikkelaars belemmeren. De zeventien mensen die het Agile Manifesto samen hebben opgesteld vertegenwoordigden de diverse Agilestromingen. Na de publicatie van het handvest, richtten enkele ondertekenaars de "Agile Alliance" op, om de principes verder om te zetten in methoden.

Agile-methoden

[bewerken | brontekst bewerken]

Enkele agile-ontwikkelmethoden en -frameworks zijn:

Gesteld kan worden dat agile en iteratieve ontwikkelmethoden terugkeren naar de ontwikkelpraktijk in de vroege historie van softwareontwikkeling.[8] Oorspronkelijk werden agile-methoden "lightweight methods" (lichtgewichtmethoden) genoemd, omdat ze zo weinig regels hadden.

Agile-methoden hebben veel gemeenschappelijk met de rapid application development- of RAD-technieken uit de jaren tachtig volgens James Martin et al. Daarna zijn de volgende methoden ontwikkeld die later Agile genoemd werden

Met extreme programming (afgekort als "XP") zijn agilemethoden populair geworden, hoewel het misschien niet de eerste agile-methode is. Extreme programming was het antwoord van Kent Beck in 1996 op de worsteling van het Chrysler Comprehensive Compensation-(C3)-project. De methode werd verfijnd door Ron Jeffries, via openbare discussie in Portland Pattern Repository van Ward Cunningham en verder werk van Beck, waaronder een boek in 1999. Er lijken elementen van extreme programming voor te komen die gebaseerd zijn op Scrum en "Episodes pattern language" van Ward Cunningham.

De meeste agile-methoden proberen risico's te verminderen door software te ontwikkelen in korte overzichtelijke perioden (timeboxes), die 'iteraties' genoemd worden. Elke iteratie is als het ware een miniatuurproject op zichzelf, en omvat alle noodzakelijke taken: planning, analyse, ontwerp, testen en documentatie. Het is de bedoeling om na iedere iteratie iets bruikbaars op te leveren. Aan het eind van de iteratie wordt het product getoond, getest en het product en proces beoordeeld. Hierdoor wordt het risico beperkt en weet men snel of men op de goede weg zit. Doordat men het product ziet wordt het allemaal concreter en komen er nieuwe ideeën. Aansluitend wordt er dan naar de projectprioriteiten gekeken en bepaald wat er de volgende iteratie (release) gedaan wordt.

Bij agile-methoden ligt de nadruk op directe communicatie, bij voorkeur als persoonlijk contact, in plaats van geschreven verslaglegging. In agile-projecten wordt erg weinig geschreven documentatie geproduceerd, vergeleken met andere methoden. De meeste agile-teams zijn gehuisvest op één locatie, een zogenaamde "bullpen". Zo mogelijk zijn alle mensen die nodig zijn voor het project in zo'n team ondergebracht. Maar ten minste zijn dit de ontwikkelaars en diegenen die het product definiëren. Dat kunnen productmanagers zijn, business-analisten of zelfs klanten. In Scrum heeft het team ook geen projectmanagers, maar scrummasters die hiërarchisch niet boven het team staan, maar deze ondersteunen. Dat bevordert de open communicatie tussen de gelijkwaardige teamleden. Bij XP is er ook sprake van pair programming, waarbij twee ontwikkelaars direct samenwerken. Dit is een erg directe manier van communicatie.

Bij agile-methoden wordt de voortgang afgemeten aan de hand van werkende producten, features of prototypes. Aan het eind van elke iteratie of sprint wordt zowel het opgeleverde product beoordeeld als het ontwikkelproces. Het doel hiervan is om te leren en steeds beter te worden. Dit aspect, de continue verbetering, (Kaizen) is overgenomen uit de Lean-productiemethoden.

Werkende software

[bewerken | brontekst bewerken]

Er wordt de nadruk gelegd op werkende software. In elke iteratie moet er iets werkends worden opgeleverd. Iets dat ook direct geïntegreerd wordt in de bestaande software, waardoor duidelijk wordt of dit ook allemaal goed gaat. In veel[bron?] agile-projecten wordt nu[(sinds) wanneer?] gewerkt met continuous delivery, waarbij software na het controleren door een automatische test-suite onmiddellijk live gaat, en dat meermaals per dag. De combinatie van de testen en de korte tijdsframe tussen twee aanpassingen, maakt dat de mogelijke problemen zodanig klein zijn dat ze zeer snel kunnen opgelost worden, waardoor de algemene kwaliteit hoger ligt dan bij projecten waar slechts om de drie maand of langer software live gezet wordt.

Agile-methoden worden snel populair en steeds meer gebruikt, ook in grote projecten.[bron?] Bekende projecten en bedrijven waar het is toegepast zijn:

Vergelijking met andere methoden

[bewerken | brontekst bewerken]

Aanpassend versus voorschrijvend

[bewerken | brontekst bewerken]

Agile-methoden worden soms misleidend gekarakteriseerd als de tegenpool van 'geplande' en 'gedisciplineerde' methoden. Een nauwkeuriger omschrijving kan gemaakt worden door onderscheid te maken tussen 'aanpassende' en 'voorschrijvende' methoden.[11] Agile-methoden staan dan aan het aanpassende uiteinde van dit spectrum.

'Aanpassende' (agile)methoden zijn er op gericht om zich snel aan te passen aan de veranderende werkelijkheid. Een 'aanpassend' team past zich dus snel aan maar heeft er moeite mee om exact te beschrijven wat er in de toekomst gaat gebeuren en wat het daarmee gaat doen.

Daartegenover staan 'voorschrijvende' methoden. Deze zijn er op gericht om de toekomst tot in detail te plannen. Een team dat met zo'n methode werkt kan precies aangeven welke resultaten en taken gepland staan voor de gehele duur van de ontwikkeling, maar heeft het moeilijk om om te gaan met verandering.

Tegenover 'iteratieve ontwikkeling'

[bewerken | brontekst bewerken]

De meeste agile-methoden delen de nadruk van "iteratieve ontwikkeling", op het tot stand brengen van vrij te geven producten in korte perioden. Agile-methoden onderscheiden zich daarvan omdat de tijdsspanne nog korter is (weken in plaats van maanden) en vanwege de nadruk op intensieve samenwerking. Daarbij komt dat agile-methoden hun "timebox" letterlijk nemen; er wordt niet overgewerkt en aan het eind van de timebox wordt alleen opgeleverd wat ook echt klaar is (done).

Tegenover de watervalmethode

[bewerken | brontekst bewerken]

De watervalmethode wordt nog volop toegepast.[12] Het is het meest voorschrijvende van alle modellen met uitgebreide voorschriften voor processtappen, in een strikt geplande volgorde. Voortgang wordt ermee gemeten aan de hand van allerlei documenten op basis waarvan management voortgangsbeslissingen neemt.

Het onbuigzame karakter van het watervalmodel, met de opdeling van projecten in afzonderlijke fasen en voortijdige commitments maken dat er moeilijk gereageerd kan worden op veranderingen. Het is daarom feitelijk onbruikbaar als projectdoelstellingen en producteisen vooraf nog niet gedetailleerd zijn of mogelijk onderhevig aan verandering gedurende het project.[13]

Daartegenover leveren agile-methoden elke zoveel weken uitontwikkelde en geteste onderdelen, al zijn dit telkens kleine delen van het geheel. De nadruk ligt er op om zo snel mogelijk de kleinst mogelijke functionele onderdelen te leveren, en die voortdurend te verbeteren en uit te breiden. Sommige agile-teams passen de watervalmethode toe op een kleine schaal tijdens elke iteratie. Andere, vooral XP-teams laten de waterval geheel los en werken simultaan aan uiteenlopende taken.

Tegenover "cowboy coding"

[bewerken | brontekst bewerken]

Bij cowboy coding is geen sprake van een uitgesproken methode. Teamleden doen wat hen goed dunkt. Agile-teams wekken soms de indruk aan cowboy-coding te doen. Geregelde herziening van plannen en nadruk op persoonlijk contact in plaats van gedocumenteerde communicatie kan ongestructureerd overkomen. Maar agile-teams coördineren hun activiteiten voortdurend en volgen wel degelijk gedefinieerde en gedisciplineerde processen.

Zoals met alle methoden hangt het succes ervan af van de vaardigheden van de gebruiker. Op vaststaande en systematische vereisten kunnen beoefenaars makkelijker afgerekend worden. Het vervallen van zulke vereisten kan leiden tot activiteiten die met cowboy-coding aangeduid zouden kunnen worden.

Geschiktheid van agile-methoden

[bewerken | brontekst bewerken]

Of agile-methoden algemeen geschikt zijn is afhankelijk van het gekozen gezichtspunt. Agile-methoden zijn geschikter naarmate eisen nog vaag en veranderlijk zijn. Vanuit organisatorisch gezichtspunt kan de geschiktheid worden afgemeten aan drie dimensies: cultuur, mensen en communicatie. In dit verband is een aantal succesfactoren aangegeven (Cohen et al., 2004):[14]

  • De cultuur van de organisatie moet openstaan voor discussie en onderhandeling.
  • Organisaties moeten mensen (fulltime) vrijmaken om besluiten te nemen over wat de organisatie wil en om te testen of het opgeleverde ook daaraan voldoet.
  • Mensen moeten vertrouwd worden.
  • Organisaties moeten de beslissingen accepteren die hun afgevaardigden / producteigenaars / product-managers nemen.
  • Organisaties moeten een omgeving hebben waarin snelle communicatie tussen teamleden mogelijk is.
  • Mensen moeten kunnen samenwerken.

De DSDM-methode is voorzien van een ‘geschiktheidsfilter’. Ook de Crystal-familie van methoden voorziet in criteria waarmee een methode geselecteerd kan worden voor een zeker project. De selectie wordt daarbij gebaseerd op projectomvang, -belang en -prioriteit. Andere agile-methoden voorzien echter niet in zulke expliciete instrumenten om hun geschiktheid te bepalen.

Van sommige methoden, zoals DSDM en Feature Driven Development (FDD), wordt beweerd dat ze geschikt zijn voor elk ontwikkelingsproject, onafhankelijk van omgevingsfactoren (Abrahamsonn et al., 2003),[15] althans op het gebied van software.

Grote projecten

[bewerken | brontekst bewerken]

Grote projecten zijn altijd moeilijk vanwege de benodigde hoeveelheid communicatie, maar dat is juist een sterk punt van de agilemethoden. Agile-ontwikkeling is uitgebreid gedocumenteerd om goed te werken in kleine (minder dan tien ontwikkelaars) co-located teams.

Voor grootschalige ontwikkelingen (meer dan twintig ontwikkelaars) zijn er voorstellen gedaan.[16] Ook wordt er met agile gewerkt in non-co-located teams die over de hele wereld verspreid kunnen zijn. Er zijn voorstellen gedaan in Bridging the Distance[17] en in Using an Agile Software Process with Offshore Development.[18]

Bestaansgrond

[bewerken | brontekst bewerken]

Agile-bestaansgrond:

  • Als nog onduidelijk is wat men precies wil.
  • Als snel eerste resultaten gewenst zijn.
  • Als de eisen steeds wijzigen
  • Continue beschikbaarheid van klant / gebruikers noodzakelijk om te bepalen wat men wil en de opgeleverde resultaten te testen.
  • Kan goed overweg met veranderingen, ook laat in het project.
  • Er wordt geclaimd dat Agile 2 à 10 maal zo snel / goed is als een traditioneel traject.
  • Als men snel kennis wil delen, o.a. als junior-softwaredevelopers moeten ingewerkt worden in een project.[bron?]

Bestaansgrond van traditionele voorschrijvende methoden:

  • Als men niet wil veranderen / ontwikkelaars wil omscholen.
  • Vaststaande projecteisen / scherpe specificaties (als vooraf goed duidelijk is wat men wil).
  • Als de omgeving slechts langzaam verandert / zoals de (semi)overheid (belastingdienst, UWV, ziekenhuizen, GBA etc.)
  • Cultuur die orde vereist, geen veranderingen in requirements tussen de afronding van de analysefase en de implementatie.

Agile-methoden en maatwerkmethode

[bewerken | brontekst bewerken]

Verschillende termen worden gebruikt om methodeaanpassing (‘method adaptation’) aan te duiden, zoals ‘method tailoring’, ‘method fragment adaptation’ en ‘situational method engineering’. Maatwerkmethode (‘method tailoring’) wordt gedefinieerd als:

een proces of vaardigheid waarbij menselijke factoren de behandelwijze voor de ontwikkeling van een systeem voor een specifieke project situatie bepalen door afgestemde veranderingen in, en dynamische wisselwerkingen tussen contexten, intenties, en fragmenten van methoden.[19]

Bijna alle agile-methoden komen in potentie in aanmerking voor maatwerk. Zelfs de DSDM-methode wordt voor dit doel gebruikt en is succesvol op maat gemaakt in een CMM-context.[15] Als kenmerk waarmee onderscheid gemaakt kan worden tussen agile-methoden en traditionele ontwikkelmethoden, waarbij de laatste inflexibel en voorschrijvend zijn, wordt situationele aanpassing beschouwd. Praktisch gevolg hiervan is dat de agile-methoden projectteams in staat stelt om praktijken aan te passen aan de individuele projectbehoeften. Praktijken zijn concrete activiteiten en producten die deel uitmaken van een methodisch raamwerk. Op een extremer niveau kan de filosofie achter de methode, bestaande uit een aantal ‘’’principes’’’ worden aangepast (Aydin, 2004).[20]

In het geval van XP is de noodzaak voor methodeaanpassing expliciet gemaakt. Een van de basisaannames van XP is dat er geen proces bestaat dat op elk project van toepassing is, maar dat praktijken aan de individuele projectbehoeften moeten worden aangepast. Er zijn ook geen ervaringsrapportages waarin XP-praktijken zijn opgenomen. Daar staat tegenover dat er meermalen verslag van gedeeltelijke toepassing van XP-praktijken is gedaan.[21]

Er kan onderscheid gemaakt worden tussen statische en dynamische methodeaanpassing.[22] De basisaanname achter statische methodeaanpassing is dat de projectcontext gegeven is bij aanvang en gelijk blijft gedurende het project. Met als gevolg een statische definitie van de projectcontext. Met zo'n definitie kan een keuze gemaakt worden uit fragmenten van gestructureerde methoden. Daartegenover wordt bij dynamische methodeaanpassing aangenomen dat ook de projectcontext in ontwikkeling is. Dit betekent dat het project in hoge mate onvoorspelbaar is en aan verandering onderhevig. Vooraf kan dus niet bepaald worden welke fragmenten van methoden toepasbaar zullen zijn. Projectmanagers zullen er dus, gedurende de uitvoering van projecten, toe moeten overgaan om methodefragmenten zelf aan hun behoefte aan te passen of zelfs nieuwe uit te vinden. (Aydin et al, 2005).[22]

Agile-methoden en projectmanagement

[bewerken | brontekst bewerken]

Agile-methoden verschillen in hoge mate in hoeverre zij met project-management overlappen. Sommige methoden worden aangevuld met richtlijnen voor project-management.[23]

Agility meten

[bewerken | brontekst bewerken]

Hoewel agility (behendigheid) wordt gezien als een middel om een doel te bereiken zijn er meerdere voorstellen gedaan om het te kwantificeren. Agility Index Measurements (AIM) meet projecten af met een aantal agility-factoren. De bijna-naamgenoot Agility Measurement Index, zet ontwikkelingen af tegen vijf dimensies van een project (duur, risico, nieuwheid, inspanning, interactie). Andere technieken zijn gebaseerd op meetbare doelen. In een onderzoek waarin gebruikmaakt van fuzzy wiskunde[24] wordt voorgesteld om projectsnelheid te gebruiken als een maat voor agility.

Agile-ontwikkelen is het onderwerp van meerdere conferenties. Sommige daarvan hebben een wetenschappelijke achtergrond met peer-reviewed artikelen en gevalsstudies. In gevalsstudies worden ervaringen gedeeld die in de praktijk met agile ontwikkelen zijn opgedaan.

Enkele conferenties waarin ervaringen gepubliceerd werden

  • XP (2000, 2001, 2002, 2003, 2004, 2005, 2006)
  • XP Universe (2001)
  • XP/Agile Universe (2002, 2003, 2004)
  • XP Days Benelux (2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012)[25]

Opleidingen en certificering

[bewerken | brontekst bewerken]

Met het groeiende gebruik is er ook een markt ontstaan voor het geven van agile/scrum-opleidingen die dan ook met een certificering afgesloten kunnen worden.

Agile-ontwikkelen wordt soms bekritiseerd als 'cowboy coding'. XP baarde met zijn controversiële leerstellingen zoals "pair programming" en "continuous design" aanvankelijk veel ophef en lokte kritiek uit als van McBreen[26] en Boehm en Turner en in Extreme Programming Refactored van Matt Stephens.[27] Veel van de kritiek werd door agile-praktijkmensen als onbegrip afgedaan.[28]

Kritiek behelst:

  • gebrek aan structuur, discipline en documentatie;
  • omvat onvoldoende softwareontwerp;
  • werkt alleen met ervaren ontwikkelaars;
  • vereist te veel culturele verandering;
  • men weet vooraf niet wat men wil en krijgt. Dit kan daardoor leiden tot moeilijkere contractonderhandelingen bij fixed price-projecten. Deze zijn daarmee bijna onmogelijk, men kan eigenlijk alleen een vast uurtarief afspreken.