RUP
Unified Process (UP, suom. yhtenäistetty prosessi, myös Unified Software Development Process, suom. yhtenäistetty ohjelmistokehitysprosessi) on iteratiivisen ja inkrementaalisen ohjelmistokehityksen prosessikehys. Sen tunnetuin ja perusteellisimmin dokumentoitu versio on IBM Rational Unified Process (RUP), jonka kehitti Rational Software Corporation (IBM:n osasto vuodesta 2003 lähtien).
Yleistä
muokkaaUnified Process ei ole itsenäinen prosessi vaan laajennettava kehys, joka tulee muokata vastaamaan organisaation tai projektin erityistarpeita. Rational:in yhtenäistetty prosessi eli RUP (Rational Unified Process, nimi juontuu prosessikuvauksen luoneen Rational Software Corporationin nimestä) on samalla tavoin muokattava kehys. Joskus muokatusta prosessikuvauksesta on vaikea sanoa onko se peräisin UP:stä vai RUP:sta, joten termejä käytetäänkin usein sekaisin.
Nimeä Unified Process käytetään usein korvaamaan nimeä Rational Unified Process, kun puhutaan yleisesti prosessista ja siihen tavallisimmin tehdyistä muokkauksista. Nimeä Unified Process käytetään usein myös siksi, että halutaan välttää mahdolliset tekijänoikeusloukkaukset, sillä Rational Unified Process ja RUP ovat IBM:n ja Intel:n tavaramerkkejä. Ensimmäinen prosessia kuvaileva kirja The Unified Software Development Process (ISBN 0-201-57169-2) julkaistiin vuonna 1999 (tekijöinä Ivar Jacobson, Grady Booch ja James Rumbaugh). Tämän jälkeen useat eri tekijät ovat julkaisseet kirjoja ja artikkeleita aiheesta käyttäen joko termiä Rational Unified Process (mikäli ovat liitoksissa IBM:n kanssa) tai Unified Process (mikäli eivät ole yhteydessä IBM:ään).
Neljä projektin elinkaaren vaihetta
muokkaaRup vaiheita ja järjestyksiä
muokkaaRup määrittelee projektin elinkaaren koostuvan neljästä vaiheesta. Nämä vaiheet sallivat, että prosessi voidaan esittää korkealla tasolla samanlailla kuin ’vesiputous’-mallin projekteissa voitaisiin esittää, vaikkakin perusolettamuksena avain prosessiin sijaitsee kaikkien eri vaiheiden kehityksen iteraatioissa. Myös, jokaisella vaiheella on tietty päämäärä lopussa, joka ilmaisee tavoitteen onnistuneen toteutuksen.
- Voimaantulovaihe
Päätavoitteena on tutkia järjestelmää, lähtökohtana tarkistaa alustava kustannusarvio ja budjetti. Tässä vaiheessa yrityskonteksti, menestystekijät ja taloudellinen ennuste vahvistetaan. Täydennetäkseen nämä vaiheet luodaan peruskäyttötapausmalli, projektisuunnitelma, alustava riskiarviointi ja projektikuvaus. Kun nämä on toteutettu projekti arvioidaan ja tarkistetaan sen kannattavuus.
- Kehittelyvaihe
Tämän vaiheen päätavoite on vähentää pahimpia havaittuja riskejä. Tässä vaiheessa projekti rupeaa ottamaan muotoa. Vaiheen aikana tehdään ongelma-alueiden analyysi, ja projektin arkkitehtuuri saa perusmuotonsa.
- Rakennusvaihe
Päätavoite on rakentaa ohjelmisto. Tässä vaiheessa keskitytään suunnitellun järjestelmän komponenttien ja muiden ominaisuuksien kehittämiseen. Tässä vaiheessa tapahtuu valtaosa ohjelmoinnista.
Tämä vaihe tuottaa ensimmäisen ulkoisen julkaisun ohjelmistosta.
- Muutosvaihe
Päätavoite on muuntaa järjestelmä kehitysasteelta tuotantoon ja tuoda se loppukäyttäjän saataville ja ymmärrettäväksi. Tämän vaihe sisältää loppukäyttäjän ja ylläpitäjien kouluttamisen ja järjestelmän testaamisen, jotta huomataan toteutuuko loppukäyttäjien odotukset.
Kuusi parasta tapaa
muokkaaRUPissa kuvattu Kuusi parasta tapaa on ohjelmistotuotannon malli, joka listaa kuusi ideaa joita tulisi seurata ohjelmistoprojektin suunnittelussa vikojen minimoimiseksi ja tuottavuuden parantamiseksi. Nämä tavat ovat:
- Kehitä iteratiivisesti
- On hyvä tietää kaikki vaatimukset etukäteen, mutta useimmiten tämä ei ole mahdollista. Useat ohjelmistotuotannon prosessit tähtäävät kustannusten minimointiin kehitysmallien avulla.
- Hallinnoi vaatimuksia
- Pidä aina käyttäjien asettamat vaatimukset mielessä.
- Käytä komponentteja
- Kehittyneen projektin ositus ei ole pelkästään suositeltavaa vaan itse asiassa välttämätöntä. Tämä mahdollistaa yksittäisten osioiden testaamisen ennen kuin ne liitetään suurempaan systeemiin. Koodin uudelleenkäyttö on myös suuri plussa ja on saavutettavissa helpommin olio-ohjelmoinnin avulla.
- Suunnittele visuaalisemmin
- Käytä kaavioita esittämään kaikkia tärkeitä komponentteja, käyttäjiä ja niiden vuorovaikutusta. "UML", eli Unified Modeling Language on työkalu, jonka avulla tästä tehtävästä saadaan helpompaa.
- Valvo laatua
- Tee testauksesta aina suuri osa projektia. Testauksesta tulee rankempaa projektin edetessä, mutta sen pitäisi silti olla tärkeä osa jokaisen ohjelmistotuotteen kehityksessä.
- Hallinnoi muutoksia
- Useat projektit luodaan usean tiimin avulla, tiimien sijainnin ja alustan vaihdellessa. Tämän takia on tärkeää pitää kirjaa systeemiin tehdyistä muutoksista. Versionhallinta on hyvä työkalu tässä.
Lähteet
muokkaa- Kroll, Per; Kruchten, Philippe (2003). The Rational Unified Process Made Easy: A Practitioner's Guide to the RUP. ISBN 0-321-16609-4.
- Kruchten, Philippe (2004). The Rational Unified Process: An Introduction (3rd Ed.). ISBN 0-321-19770-4.
- Larman, Craig (2004). Agile and Iterative Development: A Manager's Guide. ISBN 0-13-111155-8.
- Scott, Kendall (2002). The Unified Process Explained. ISBN 0-201-74204-7.
- Bergstrom, Stefan; Raberg, Lotta (2004). Adopting the Rational Unified Process: Success with the RUP. ISBN 0-321-20294-5.