Top Banner
IBM Software Group ® RUP - Rational Unified Process Eva Hådding [email protected]
31

RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding [email protected]. 2 Projektkaos…. Chaos-rapporten 28% av

Jul 10, 2020

Download

Documents

dariahiddleston
Welcome message from author
This document is posted to help you gain knowledge. Please leave a comment to let me know what you think about it! Share it to your friends and learn new things together.
Transcript
Page 1: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

1

IBM Software Group

®

RUP - Rational Unified Process

Eva Hå[email protected]

Page 2: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

2

Projektkaos….

Chaos-rapporten

28% av projekten avslutades i tid ochenligt budget.49% av projekten drog över de ursprungliga estimaten.- Tid i genomsnitt 63%.- Kostnad i genomsnitt 45%.

23% av projekten lades ner.

Standish Group, ‘01 (www.standishgroup.com)

Page 3: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

3

PraxisPraxis

Hantera kravAnvänd komponentarkitekturer

Modellera visuellt (UML)Verifiera kvalitet kontinuerligt

Hantera ändringarUtveckla iterativt

Hantera kravAnvänd komponentarkitekturer

Modellera visuellt (UML)Verifiera kvalitet kontinuerligt

Hantera ändringarUtveckla iterativt

Page 4: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

4

Praxis 1: Hantera krav

PraxisPraxis

Hantera kravAnvänd komponentarkitekturer

Modellera visuellt (UML)Verifiera kvalitet kontinuerligt

Hantera ändringarUtveckla iterativt

Hantera kravAnvänd komponentarkitekturer

Modellera visuellt (UML)Verifiera kvalitet kontinuerligt

Hantera ändringarUtveckla iterativt

Page 5: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

5

Kravhantering

Se till att nilöser de verkliga problemenbygger det rätta systemet

mha ett systematiskt tillvägagångssätt förkravfångstorganisationdokumentationhantering

av de föränderliga kraven på en programvarutillämpning.

Page 6: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

6

Översikt över kravhantering

Problem

Behov

Egenskaper

Programvaru-krav

TestskriptDesign Anv.

dok.

ProduktProduktattatt

byggabygga

Spårbarhet

Problem-område

Lösnings-område

Page 7: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

7

Praxis 2: Använd komponentarkitekturer

PraxisPraxis

Hantera kravAnvänd

komponentarkitekturerModellera visuellt (UML)

Verifiera kvalitet kontinuerligtHantera ändringarUtveckla iterativt

Hantera kravAnvänd

komponentarkitekturerModellera visuellt (UML)

Verifiera kvalitet kontinuerligtHantera ändringarUtveckla iterativt

Page 8: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

8

Förändringståliga, komponentbaserade arkitekturer

FörändringståligUppfyller nuvarande och framtida kravUnderlättar utbyggnadMöjliggör återanvändningKapslar in systemberoenden

KomponentbaseradÅteranvänd eller anpassa komponenterVälj bland kommersiellt tillgängligakomponenterVidareutveckla existerande programvarainkrementellt

Page 9: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

9

Praxis 3: Modellera visuellt (UML)

Hantera kravAnvänd komponentarkitekturer

Modellera visuellt (UML)Verifiera kvalitet kontinuerligt

Hantera ändringarUtveckla iterativt

Hantera kravAnvänd komponentarkitekturer

Modellera visuellt (UML)Verifiera kvalitet kontinuerligt

Hantera ändringarUtveckla iterativt

PraxisPraxis

Page 10: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

10

Varför visuell modellering?Fånga struktur och beteendeVisa hur systemets delar passar ihopHålla designen och implementationenkonsistentaDölja eller visa detaljer efter behovFörenkla tydlig kommunikation

Statiskadiagram

Dynamiskadiagram

Aktivitets-diagram

Modeller

Sekvens-diagram

Samarbets-diagram

Tillstånds-diagram

Driftsättnings-diagram

Komponent-diagram

Objekt-diagram

Klass-diagramAnvändnings-

fallsdiagram

UML erbjuder ettspråk för allainblandade

Page 11: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

11

Praxis 4: Verifiera kvalitet kontinuerligt

Hantera kravAnvänd komponentarkitekturer

Modellera visuellt (UML)Verifiera kvalitet

kontinuerligtHantera ändringarUtveckla iterativt

Hantera kravAnvänd komponentarkitekturer

Modellera visuellt (UML)Verifiera kvalitet

kontinuerligtHantera ändringarUtveckla iterativt

PraxisPraxis

Page 12: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

12

Verifiera programvarans kvalitet kontinuerligtK

ostn

adK

ostn

ad

Kostnad för åtgärdande

Kostnad för uteblivna möjligheter

Kostnad för förlorade kunder

Kostnad för åtgärdande

Kostnad för uteblivna möjligheter

Kostnad för förlorade kunder

Programvaruproblem blir 100–1000 gångerdyrare att hitta och åtgärda efter driftsättning

Programvaruproblem blir 100–1000 gångerdyrare att hitta och åtgärda efter driftsättning

Förberedelse Etablering Konstruktion Överlämning

Page 13: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

13

Testa varje iteration

UML-modelloch

implementation

Tester

Iteration 1Iteration 1

TestsvitTestsvit 11

Iteration 2Iteration 2

TestsvitTestsvit 22

Iteration 3Iteration 3

TestsvitTestsvit 33

Iteration 4Iteration 4

TestsvitTestsvit 44

Page 14: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

14

Praxis 5: Hantera ändringar

Hantera kravAnvänd komponentarkitekturer

Modellera visuellt (UML)Verifiera kvalitet kontinuerligt

Hantera ändringarUtveckla iterativt

Hantera kravAnvänd komponentarkitekturer

Modellera visuellt (UML)Verifiera kvalitet kontinuerligt

Hantera ändringarUtveckla iterativt

PraxisPraxis

Page 15: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

15

The Configuration and Change Management (CCM) Cube

Page 16: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

16

Praxis 6: Utveckla iterativt

PraxisPraxis

Hantera kravAnvänd komponentarkitekturer

Modellera visuellt (UML)Verifiera kvalitet kontinuerligt

Hantera ändringarUtveckla iterativt

Hantera kravAnvänd komponentarkitekturer

Modellera visuellt (UML)Verifiera kvalitet kontinuerligt

Hantera ändringarUtveckla iterativt

Page 17: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

17

Egenskaper hos vattenfallsutveckling

Försenar möjligheten attbekräfta kritiskariskåtgärderMäter framskridandegenom att utvärderaarbetsprodukter som ärdåliga på att visa mängden återståendearbeteFörsenar och försvårarintegration och testningFörhindrar tidigdriftsättningLeder ofta till stora, oplanerade iterationer

Vattenfallsprocess

Kodning och enhetstest

Systemtest

Delsystemintegration

Design

Kravanalys

Page 18: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

18

Iterativ utveckling producerar körbara utgåvor

Risk!Krav

Initialplanering

Planering

Analys & design

Implementation

Driftsättning

Utvärdering

Projektledning

Varje iteration resulterar i en körbar utgåva

Test

Page 19: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

19

Riskprofiler

RiskreduceringRiskreduceringRis

kR

isk

Vattenfallsrisk

Iterativ risk

TidTid

Page 20: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

20

RUP förverkligar dessa praxis

PraxisEn praktisk process

PraxisEn praktisk process

Hantera kravAnvänd komponentarkitekturer

Modellera visuellt(UML)Verifiera kvalitet kontinuerligt

Hantera ändringarUtveckla iterativt

Hantera kravAnvänd komponentarkitekturer

Modellera visuellt(UML)Verifiera kvalitet kontinuerligt

Hantera ändringarUtveckla iterativt

Page 21: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

21

Processtruktur - Livscykelfaser

FörberedelseFörberedelse EtableringEtablering KonstruktionKonstruktion ÖverlämningÖverlämning

tid

Rational Unified Process definierar fyra faser:Förberedelse (Inception) – Definierar projektetsomfattningEtablering (Elaboration) – Planera projektet, specificera egenskaper, ta fram grundversion avarkitekturenKonstruktion (Construction) – Bygg produktenÖverlämning (Transition) – Överlämna produkten till slutanvändarna

Page 22: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

22

Fasgränserna utgör större milstolpar

FörberedelseFörberedelse EtableringEtablering KonstruktionKonstruktion ÖverlämningÖverlämning

Milstolpe:Livscykelmål

Milstolpe:Livscykel-arkitektur

Milstolpe:Initialt

funktionsduglig

Produkt-utgåva

tid

Page 23: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

23

Iterationer och faser

IterationIterationF1F1

Iteration Iteration E1E1

IterationIterationE2E2

IterationIterationK1K1

IterationIterationK2K2

IterationIterationK3K3

IterationIterationÖ1Ö1

IterationIterationÖ2Ö2

FörberedFörbered.. EtableringEtablering KonstruktionKonstruktion ÖverlämningÖverlämning

Mindre milstolpar: Interna utgåvor

Page 24: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

24

Nio discipliner

Page 25: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

25

Tillsammans blir det: Ett iterativt tillvägagångssätt

Disciplinergrupperaraktiviteterlogiskt

I en iterationgår man igenom alladiscipliner

Page 26: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

26

RUP är en

användningsfallsdriven,arkitekturcentrisk,samt riskdriven process.

Page 27: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

27

Nyckelbegrepp i RUP: Roller, aktiviteter, artefakter

Aktivitet

Roll

Artefakt

Page 28: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

28

RUP är en omfattande process, ett ”processramverk”

RUP bör införas stegvis

RUP måste anpassastill organisationentill projektet

Page 29: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

Användarcentrering i RUPRequirements: Analysis & Design:

Deployment:

Conceptual Road Map:Usability Engineering

Use CasesGuidelines: Role playing, Interviews, Storyboarding, User Interface etc

Ux Plug-InConcepts:User-Centered Design,Usability Testing

Page 30: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

30

Användningsfall och användarcentrering...

+ Fokus på användarna och deras uppgifter!!

- Oftast bara beskrivning av nuläget ...- Användarna är inte utvecklare ...- Sekventiell struktur ...- Ett användningsfall blir ett fönster ...- Ingen entydig definition ...

Användarna ska delta!

Page 31: RUP - Rational Unified Process - Uppsala University · 2003-11-12 · RUP - Rational Unified Process Eva Hådding eva.hadding@se.ibm.com. 2 Projektkaos…. Chaos-rapporten 28% av

31

Användarcentrering i RUP

Detta kunde varit bättre... Detta är bra!Detta är bra!

Användbarhet är utspritt och otydligt →kan nedprioriteras –eller helt enkelt ”försvinna”

Användbarhet är utspritt och otydligt →kan nedprioriteras –eller helt enkelt ”försvinna”

Användningsfall →användarcentreringAnvändningsfall →användarcentrering

Fokus på kravFokus på krav

Iterativ utvecklingIterativ utvecklingIngen samordnande, ansvarig roll Ingen samordnande, ansvarig roll Tvärdisciplinärt samarbeteTvärdisciplinärt samarbete