„Agilis szoftverfejlesztés” változatai közötti eltérés

A Wikipédiából, a szabad enciklopédiából
[nem ellenőrzött változat][nem ellenőrzött változat]
Tartalom törölve Tartalom hozzáadva
36. sor: 36. sor:


====Agilis szoftverfejlesztés elvei====
====Agilis szoftverfejlesztés elvei====
A [[SOLID|S.O.L.I.D. alapelvek]] adják az agilis szoftverfejlesztés alapját.


Az Agilis Kiáltvány 12 alapelven nyugszik:<ref name="manifestoprinciples">{{cite web|url=http://www.agilemanifesto.org/principles.html
Az Agilis Kiáltvány 12 alapelven nyugszik:<ref name="manifestoprinciples">{{cite web|url=http://www.agilemanifesto.org/principles.html

A lap 2020. június 12., 00:07-kori változata

Az agilis szoftverfejlesztés a szoftverfejlesztési módszerek egy csoportja, ahol a szoftver követelmények és a megoldások együttműködésen keresztül együtt fejlődnek az önszerveződő és multifunkcionális csapatok között. Ez elősegíti az alkalmazkodó tervezést, az evolúciós fejlesztést, korai szállítást, folytonos továbbfejlesztést és bátorít a változásokra adható gyors és rugalmas válaszokra.[1]

Az Agilis Szoftverfejlesztési Kiáltvány,[2] (ismert még Agilis kiáltvány néven is), először 2001-ben vezette be az agilis kifejezést a szoftverfejlesztés keretében. Habár mindez ez a DuPont-nál a 80-as évek közepén fejlesztett technikákból fejlődött ki és később James Martin[3] és James Kerr et al.[4] definiálta.

Története

Elődök

A növekményes szoftverfejlesztési módszerek egészen 1957-ig vezethetők vissza.[5] 1974-ben E. A. Edmonds írt egy dolgozatot, amelyben bevezetett egy alkalmazkodó szoftverfejlesztési folyamatot.[6][7] Ezzel párhuzamosan, és teljesen függetlenül ugyanazt a módszert fejlesztette ki és alkalmazta a New York Telefon Társaság Rendszerfejlesztési Központja Dan Gielan igazgatása alatt. A korai 1970-es években Tom Gilb elkezdte publikálni az evolúciós projektmenedzsment (EVO) koncepcióját, amely a competitive engineering-é nőtte ki magát.[8] Az 1970-es évek közepétől a végéig Gielan alapos előadásokat tartott Amerika szerte erről a módszertanról és gyakorlatáról és előnyeiről.

A pehelysúlyú szoftverfejlesztési módszerek egy csoportja kezdett kifejlődni az 1990-es évek közepén válaszul a nehézsúlyú vízesés-orintált módszerekre, amely kritikákat nevezik nehezen szabályozhatónak, nagyszámúnak és mikromenedzseltnek; habár egyes hívei ezen pehelysúlyú módszereknek azt állították, hogy csak visszatértek a korai szoftverfejlesztési gyakorlathoz.[5] Ezek a pehelysúlyú módszerek a következők voltak: 1994-ből a Unified Process és a dinamikus rendszerfejlesztési módszer (angol rövidítéssel DSDM); 1995-ből a Scrum; 1996-ból a crystal clear és az extrém programozás (angol rövidítéssel XP) és 1997-ből a adaptív szoftverfejlesztés és feature-driven fejlesztés. Habár ezek az Agilis Kiáltvány 2001-es közzététele előttről származnak, mostanra együttesen hivatkoznak rájuk, mint agilis módszerekre;[9] és gyakran rövidítik egyszerűen Agilisnek, nagy kezdő A-val, bár ez fokozatosan válik elavulttá.[10]

Az Agilis Kiáltvány

2001 februárjában 17 szoftverfejlesztő (lásd alább) találkozott Snowbird Üdülőközpontban Utah-ban, hogy megbeszéljék a pehelysúlyú szoftverfejlesztési módszereket. Kiadták a Kiáltvány az Agilis szoftverfejlesztésért-et:[2]

„Azáltal tárjuk fel a szoftverfejlesztés jobb módjait, hogy műveljük és segítünk másoknak is művelni azt. E munka során megtanultuk értékelni:

  • Az egyéneket és interakciókat az eljárásokkal és eszközökkel szemben
  • A működő szoftvert az átfogó dokumentációval szemben
  • Az ügyféllel való együttműködést a szerződéses egyeztetéssel szemben
  • A változásokra való reagálást a terv követésével szemben

Noha a jobb oldali elemekben is van érték, mi többre értékeljük a bal oldali elemeket.

Kent Beck, James Grenning, Robert C. Martin, Mike Beedle, Jim Highsmith, Steve Mellor, Arie van Bennekum Andrew Hunt, Alistair Cockburn, Ron Jeffries, Jeff Sutherland, Ken Schwaber, Ward Cunningham, Jon Kern, Dave Thomas, Martin Fowler, Brian Marick

© 2001, a fenti szerzők. Ez a nyilatkozat szabadon másolható bármilyen formában, de csak teljes egészében ezen megjegyzéssel együtt.”

A kiáltvány bal oldali elemeinek jelentései:

  • Egyének és kölcsönhatások: önszerveződés és motiváció nagyon fontos: az olyan kölcsönhatások mint szoros egymás melletti elhelyezkedés és páros programozás.
  • Működő szoftver: működő szoftver sokkal hasznosabb és üdvözlendőbb, mint a dokumentációk bemutatása az ügyfélnek a megbeszéléseken
  • Ügyféllel való együttműködés: a követelményeket nem lehet teljesen összegyűjteni a szoftver fejlesztési ciklus elején, így a folyamatos ügyfél vagy érdekeltek bevonása nagyon fontos.
  • Változásokra adandó válasz: az agilis módszerek a változásokra adandó gyors válaszokra és a folyamatos fejlesztésre koncentrálnak.[11]

Néhány szerző megalakította az Agilis Szövetséget (angolul Agile Alliance), amely egy nonprofit szervezet, amely segíti a szoftverfejlesztést a kiáltvány értékei és alapelvei szerint.

Agilis szoftverfejlesztés elvei

A S.O.L.I.D. alapelvek adják az agilis szoftverfejlesztés alapját.

Az Agilis Kiáltvány 12 alapelven nyugszik:[12]

  1. Ügyfél elégedettség fenntartása a használható szoftver gyors szállításaival
  2. Változtatás kérések fogadása bármikor még a fejlesztés végén is
  3. Működő szoftver gyakori szállítása (hónaponként helyett hetenként)
  4. Szoros napi együttműködés az üzleti emberek és a fejlesztők között
  5. Projektek motivált, megbízható egyénekből épülnek fel
  6. Kommunikáció legjobb formája a szemtől-szembe való információcsere
  7. Működő szoftver a haladás legfőbb mérőfoka
  8. Fenntartható fejlesztés, állandó mértékben való fenntartás
  9. Folyamatos figyelem a technikai kiválóságok és jó tervezés felé
  10. Egyszerűség - az el nem végzett munka mennyiségének maximalizálása művészi fokon - elengedhetetlen
  11. Önszerveződő csapat
  12. Alkalmazkodás szabályos időközönként a változó körülményekhez

Áttekintés

Páros programozás, egy XP által használt agilis fejlesztési technika.

Számos konkrét agilis fejlesztési módszer létezik. Legtöbbjük elősegíti a fejlesztést, csoportmunkát, együttműködést és folyamat alkalmazkodását a projekt életciklusán keresztül.

Ismétlődő, növekményes és evolúciós

A legtöbb agilis módszer lebontja a feladatot kisebb feladatokra. Egy fejlesztési ciklus (azaz iteráció vagy sprint) maximum 4 hétig tart. Ezt az időtartamot idődoboznak hívjuk. Minden iterációban lévő feladat elkészítése egy keresztfunkcionális fejlesztői csoport feladata, amely a tervezéstől, elemzéstől a programozáson át a tesztelésig és átvételi tesztig mindent elvégez. Az iteráció végén bemutatják az elkészült feladatokat a megrendelőnek. Így minimalizálhatóak a hosszú fejlesztésből fakadó kockázatok, és a projekt gyorsan alkalmazkodhat a változásokhoz. Az inkrementum talán nem alkalmas az értékesítésre önmagában, azonban cél, hogy minden fejlesztési ciklus végén potenciálisan szállítható termék készüljön el. A módszer ismétlődésen alapul (minden iterációban azonos szakaszokon megy végig a fejlesztőcsoport), és növekményes, mert mindig a már elkészült inkrementumot egészítik ki.[13][14]

Eredményes és szemtől-szembe való kommunikáció

Az agilis módszerek nagyobb hangsúlyt fektetnek a közvetlen, mint az írásbeli kommunikációra. A csapatok mérete ezért 3-9 fő ideális esetben, ennél nagyobb csapatban nem alakul ki a csapatszellem, vagy több csapatot kell létrehozni, amelyek között kommunikációs problémák léphetnek fel. A csapattagok ideális esetben egy térben dolgoznak, és kereszt-funkcionálisak, ami azt jelenti, hogy a csapat rendelkezik azokkal a készségekkel, amelyek szükségesek a feladat, munka vagy projekt elvégzéséhez.

Minden csapatban van egy delegált a megrendelő részéről, a Scrum keretrendszerben ő a product owner. A fejlesztés egész ideje alatt rendelkezésre áll, hogy a felmerülő kérdéseket megválaszolja.[15] Az iterációs szakasz végén a fejlesztők és a megbízó delegáltja együtt kiértékelik az inkrementumot. A megbízótól érkező személy fontos feladata, hogy az elkészítendő funkciókat fontossági sorrendjét felállítsa üzleti szempontból (megtérülési mutató, azaz return of investment - ROI). A fejlesztői csapat a legmagasabb prioritású funkciókat veszi előre.[16]

Az agilis szoftverfejlesztésben általában elhelyeznek az iroda egyik feltűnő pontján egy általában nagyméretű információs táblát (information radiator). Ezen mindenki láthatja a szoftver vagy más termék projektje fejlesztésének naprakész állapotát.[17][18] A kifejezést Alistair Cockburn alkotta meg és írta le 2002-es könyvében, az Agilis szoftverfejlesztésben.[18] Egy úgynevezett build light indicator (a projekt elkészültségi fokára utaló fényjelző) szintén tájékoztathatja a csapat tagjait a feladat állásáról.

Nagyon rövid visszajelzési és alkalmazkodási ciklus

Összpontosítás a minőségre

Speciális eszközök és technikák, mint pl. a folyamatos integráció, automatikus egység tesztelés, páros programozás, teszt vezérelt fejlesztés, tervezési minták, domain vezérelt tervezés, kód refaktorálás és más technikákat gyakran használják a minőség javítására és a projekt agilitás fokozására.

Filozófia

A hagyományos szoftvertervezési filozófiákkal szemben az agilis szoftver fejlesztés a komplex rendszereket és projekteket dinamikus, nemdeterminisztikus és nemlineáris módon célozza, ahol a pontos becslés, a stabil terv és az előrejelzés korai stádiumban gyakran nehezen megvalósítható, ezért a nagyszabású előre elkészített tervek és lebontások valószínűleg hatalmas veszteséggel járnak abban az értelemben, hogy gazdaságilag (üzletileg) nem megalapozottak. Ezek az alapvető érvek, és a korábbi iparági tapasztalatok, éveken át tartó próbálkozások sikerei és kudarcai segítettek kidolgozni az agilis szoftverfejlesztésnek kedvező adaptív, iteratív és evoluciós fejlesztést.[19]

Iterációs kontra vízesés modell

Az agilis és a vízeséses módszertanok közötti egyik fő különbség az, hogy hogyan tekintenek a minőség és a tesztelés kérdéskörére. A vízeséses modell mindig külön-külön tesztelési és építési (build) szakaszt definiál; ezzel szemben az agilis szoftverfejlesztés során a tesztelés rendszerint a tényleges fejlesztési (programozási) munkával egyidejűleg, vagy legalábbis ugyanazon iterációban zajlik.

Mivel a tesztelés minden, a szoftver egy-egy kicsiny részét előállító iterációnak része, a felhasználóknak sűrűbben lesz lehetőségük az új részeket használatba venni, és megismerni azok működését.

Miután a felhasználók pontos képet kapnak a továbbfejlesztett szoftver működéséről, jobb döntéseket tudnak hozni a szoftver jövőjéről. Azzal, hogy minden iterációban visszatekintő (retrospektív) és tervezési megbeszéléseket tartunk —a scrum módszertan szerint például általában kéthetente—, segítjük a fejlesztőket abban, hogy a terveket a lehető legcélszerűbb, leghasznosabb módon valósíthassák meg.

Ez az iteratív gyakorlat a vízeséses modell projekt-alapú szemléletmódjával szemben a terméket helyezi előtérbe. A szoftverre, mintegy élő szervezetként tekint, amely a környezet változásaira maga is változásokkal reagál. A szoftver teljes életútján, különösen pedig versenyhelyzetekben jelentkeznek változási igények; az iteratív szoftverfejlesztés ezen változások megvalósításának a kulcsa.


Agilis szoftverfejlesztési módszerek

Software development life-cycle support[20]

Az agilis szoftverfejlesztési módszerek a szoftverfejlesztési életciklus széles körét támogatják. [20] Néhányuk a gyakorlatokra összpontosít (pl. XP, pragmatikus programozás, agilis modellezés), míg mások a munkafolyamat menedzsmentjére összpontosítanak (pl. Scrum, Kanban). Néhány támogató tevékenység a követelmények meghatározásához és fejlesztéséhez (például FDD), míg mások a teljes fejlesztési életciklus lefedésére törekszenek (például DSDM, RUP).

A főbb agilis szoftverfejlesztési keretrendszerek, módszerek az alábbiak:

Keretrendszer Fő közreműködő(k)
Adaptív szoftverfejlesztés (ASD) Jim Highsmith, Sam Bayer
Agilis modellezés Scott Ambler, Robert Cecil Martin
Agilis egységes folyamat (AUP) Scott Ambler
Fegyelmezett agilis szállítás Scott Ambler
Dinamikus rendszerfejlesztési módszer (DSDM)
Extrém programozás (XP) Kent Beck, Robert Cecil Martin
Funkcióközpontú fejlesztés (FDD) Jeff De Luca
Lean szoftverfejlesztés Mary Poppendieck, Tom Poppendieck
Lean startup Eric Ries
Kanban Taiichi Ohno
Gyors alkalmazásfejlesztés (RAD) James Martin
Scrum Ken Schwaber, Jeff Sutherland
Scrumban
Scaled Agile Framework - SAFe

Agilis szoftverfejlesztési gyakorlatok

Az agilis szoftverfejlesztést számos konkrét gyakorlat támogatja, amelyek olyan területeket ölelnek fel, mint a követelmények, a tervezés, modellezés, kódolás, tesztelés, tervezés, kockázatkezelés, folyamat, minőség stb. Néhány figyelemre méltó agilis szoftverfejlesztési gyakorlat a következőket foglalja magában: [21]

Gyakorlat Fő közreműködő(k)
Elfogadási teszt által vezérelt fejlesztés (ATDD)
Agilis modellezés
Agilis tesztelés
Termék teendőlista (Termék és Sprint) Ken Schwaber
Viselkedés-vezérelt fejlődés (BDD) Dan Észak, Liz Keogh
Folyamatos integráció (CI) Grady Booch
Többfunkciós csapat
Daily Stand-up / Daily Scrum | James O Coplien
Területvezérlet design Eric Evans
Iteratív és növekményes fejlesztés (IID)
Kevés kódírást igénylő fejlesztési platformok
Páros programozás Kent Beck
Tervezési póker James Grenning, Mike Cohn
Újraírás (refactoring) Martin Fowler
Retrospektív
Scrum események (sprint-tervezés, sprint-áttekintés és retrospektív)
Példaalapú specifikáció
Történetvezérelt modellezés Albert Zündorf
Tesztvezérelt fejlesztés (TDD) Kent Beck
Időkorlátozás (timeboxing)
Felhasználói történet (User story) Alistair Cockburn
Sebesség (Velocity)

Az agilis módszertan terjedése más területeken

Az agilis megközelítést már nem csak a szoftver-, de a szervezetfejlesztés is alkalmazza.[22] Terjedését az indokolja, hogy a módszertan jó választ ad a mai korra jellemző bizonytalanságra és komplexitásra.[23] A módszertan használatával ugyanis általánosságban is gyorsabb a termékfejlesztés, nem csak a szoftver esetében. Gyorsabban lehet választ találni a piaci változásokra és magasabb termelékenység érhető el, mint hagyományos módon.

Ezért a legkülönfélébb ágazatokban vannak már példák a szervezet agilissá való alakítására, vagyis agilis transzformációra. Ilyenkor az alapoktól átgondolják a folyamatokat és kultúraváltásra is szükség van. Nem véletlen, hogy elsősorban olyan szervezetek vállalkoznak erre, ahol már az IT fejlesztés is agilis módon történik.

Jegyzetek

  1. What is Agile Software Development?. Agile Alliance, 2013. június 8. (Hozzáférés: 2015. április 4.)
  2. a b Beck, Kent: Manifesto for Agile Software Development. Agile Alliance, 2001. (Hozzáférés: 2010. június 14.)
  3. Martin, James (1991). Rapid Application Development. Macmillan. ISBN 0-02-376775-8.
  4. Kerr, James M.; Hunter, Richard (1993). Inside RAD: How to Build a Fully Functional System in 90 Days or Less. McGraw-Hill. ISBN 0-07-034223-7 p.3
  5. a b Gerald M. Weinberg, as quoted in Larman, Craig (2003. június 1.). „Iterative and Incremental Development: A Brief History”. Computer 36 (6), 47–56. o. DOI:10.1109/MC.2003.1204375. ISSN 0018-9162. „We were doing incremental development as early as 1957, in Los Angeles, under the direction of Bernie Dimsdale at IBM's Service Bureau Corporation. He was a colleague of John von Neumann, so perhaps he learned it there, or assumed it as totally natural. I do remember Herb Jacobs (primarily, though we all participated) developing a large simulation for Motorola, where the technique used was, as far as I can tell ... All of us, as far as I can remember, thought waterfalling of a huge project was rather stupid, or at least ignorant of the realities. I think what the waterfall description did for us was make us realize that we were doing something else, something unnamed except for 'software development.'” 
  6. Edmonds, E. A. (1974). „A Process for the Development of Software for Nontechnical Users as an Adaptive System”. General Systems 19, 215–18. o.  
  7. Note by Edmonds: I presented these ideas in London in 1970 and first submitted the paper to the Journal Computer Aided Design. It was rejected with the comment "If you don't know what you are going to do before you start you shouldn't start"! Only then did I submit it to General Systems.
  8. Evolutionary Project Management. Gilb. [2012. április 14-i dátummal az eredetiből archiválva]. (Hozzáférés: 2012. április 14.)
  9. Larman, Craig. Agile and Iterative Development: A Manager's Guide. Addison-Wesley, 27. o. (2004). ISBN 978-0-13-111155-4 
  10. "a"-vs-agile-lowercase-"a" Agile With a Capital "A" Vs. agile With a Lowercase "a". Rally, 2010. (Hozzáférés: 2015. március 31.)
  11. Ambler, S.W. "Examining the Agile Manifesto". Hozzáférés ideje: 6 April 2011.
  12. Beck, Kent: Principles behind the Agile Manifesto. Agile Alliance, 2001. [2010. június 14-i dátummal az eredetiből archiválva]. (Hozzáférés: 2010. június 6.)
  13. Beck, Kent (1999). „Embracing Change with Extreme Programming”. Computer 32 (10), 70–77. o. DOI:10.1109/2.796139.  
  14. Jegyzet a projekt labor című tárgyhoz. Eger: Eszterházy Károly Főiskola, 46-18.. o. (2012. március 28.). Hozzáférés ideje: 2016. április 17. 
  15. Gauthier, Alexandre: What is scrum. Planbox, 2011. augusztus 17. [2012. március 25-i dátummal az eredetiből archiválva]. (Hozzáférés: 2011. augusztus 22.)
  16. Jegyzet a projekt labor című tárgyhoz. Eger: Eszterházy Károly Főiskola, 48.. o. (2012. március 28.). Hozzáférés ideje: 2016. április 17. 
  17. Cockburn, Alistair: Information radiator
  18. a b Ambler, Scott. Agile Modeling: Effective Practices for EXtreme Programming and the Unified Process. John Wiley & Sons, 12, 164, 363. o. (2002. április 12.). ISBN 978-0-471-20282-0 
  19. Larman, Craig (2004): Agile and Iterative Development: A Manager's Guide. Addison-Wesley, p.27.
  20. a b Sablon:Cite techreport
  21. Útmutató az agilis gyakorlatokhoz. [2016. március 15-i dátummal az [http: //guide.agilealliance.org/ eredetiből] archiválva]. (Hozzáférés: 2019. december 13.)
  22. https://hbr.org/2018/05/agile-at-scale
  23. https://www.horvath-partners.com/hu/media-center/cikkek/12-jo-tanacs-agilis-transzformaciohoz/

További olvasnivaló

További információk

Az angol Wikikönyvekben
további információk találhatók