Struktureret system udvikling Minimodul 2: Kravspecifikation og accepttest

Relaterede dokumenter
Struktureret system udvikling Minimodul 2: Kravspecifikation og accepttest

Struktureret system udvikling Minimodul 3: Kravspecifikation og accepttest

Struktureret system udvikling Minimodul 1: Introduktion, UML og use cases

Fag: Projekt E1PRJ1 Emne: Kravspecifikation Softdrink-Automat Gruppe: 6 Dato: 10. april 2003 Medlemmer: Benjamin Sørensen, Joanna Christensen, Jacob

Vejledning til udviklingsprocessen for projekt 2

Struktureret system udvikling Minimodul 3: SPU/UML modellen

Kravspecifikation For. Gruppen

Secure O matic. Gruppe 5 2. SEMESTERPROJEKT. Udgave. Accepttest-specifikation

Accepttest Specifikation For. Gruppen

Model og metode til programudvikling. Om undertegnede... Struktureret Systemudvikling. Dagens menu... Tankevækkende erfaringer med systemudvikling...

Struktureret system udvikling Minimodul 3: SPU/UML modellen

Automation Projektledelse Networking GAPP. GAPP kravspecifikation

Bias Reducing Operating System - BROS -

Program Dokumentation PC Software Skrevet af. Gruppen. Version 1.0

Hos Lasse Ahm Consult vurderer vi at følgende supplerende krav i de enkelte kravelementer er væsentlige at bemærke:

Struktureret system udvikling Minimodul 2: UML og use cases

Struktureret system udvikling Minimodul 1: Introduktion, projekt- og tidsplanlægning

Secure O matic. Gruppe 5 2. SEMESTERPROJEKT. Udgave. Projektstyring

Struktureret system udvikling Minimodul 4: Introduktion til systematisk design

MoneyBank. Datatekniker svendeprøve 2011

UC Effektiviseringsprogrammet. Projektgrundlag. Business Intelligence. version 1.2

Automatisk Vandingssystem

Automatisk Vandingssystem

Hvem er vi? Kursus Introduktion. Kursuslærerne. Agenda for i dag

Struktureret system udvikling Minimodul 4: Struktureret ProgramUdvikling (SPU) - I

Hos Lasse Ahm Consult vurderer vi at følgende krav i de enkelte kravelementer er væsentlige at bemærke:

Fra Computer til Virkelighed. TPE-kursus Elektroniske Systemer P1

Velkommen til. Kravspecifikation i Softwareudvikling Workshop hos Brüel & Kjær. 14. september 2012,

LEVERANCE 1.3. Model for kvalitetssikring

Vurdering af kvalitet en note af Tove Zöga Larsen

Underbilag 14 C: Afprøvningsforskrifter til prøver og tests

FRA USECASE TIL TESTCASE HP TEST BRUGERKONFERENCE, 10. APRIL 2014

ADK 1.0 KRAVSPECIFIKATION

SPU UML note. Systematisk Program- Udvikling med UML. Finn Overgaard Hansen

God programledelse. Netværk

Svendeprøve Projekt Tyveri alarm

Brugermanual Netværkoptager (NVR)

Samrådsspørgsmål. Akt 186

Jens Myrup Pedersen Adjunkt. Department of Control Engineering Center for Network Planning. SPU 1. kursusgang

Hos Lasse Ahm Consult vurderer vi at følgende krav i de enkelte kravelementer er væsentlige at bemærke:

Procedure for systemtest

Birksund kommune. Datatekniker svendeprøve 2011

Vejledning til gevinstdiagram og gevinstprofiler

BRUGERCENTRERET DESIGN.

kv AC Station. Kontrolanlæg Relæbeskyttelse. Dataudveksling med SIMEAS SAFIR. ETS Rev. 1

Digital positioner type RE 3446

ETC sæt strøm til projektstyringen

IKT TEKNISK KOMMUNIKATIONS- SPECIFIKATION

Hassansalem.dk/delpin User: admin Pass: admin BACKEND

Bring lys over driften af belysningen

MARSTRAND PLANNING INTELLIGENCE

Procedurer for styring af softwarearkitektur og koordinering af udvikling

Koncept for systemforvaltning af den fælles open source kode, herunder procedure for opfølgning på software-versioner af OpenTele

Sporbarhed og Rapportering i Quality Center. Kim Stenbo Nielsen NNIT Application Management Services

MP3 player med DMX interface.

CCS Formål Produktblad December 2015

Bilag 9, Kvalitetssikring

XProtect-klienter Tilgå din overvågning

Dansk El-montage manual Portautomatik

Iterativ og Agil udvikling

Vejledning - Udarbejdelse af gevinstdiagram

Projektlederens roller og kompetencer. Cases til Projektlederens roller og kompetencer

Projekt: I4PRJ4 Dato: 18/ Titel: Kravspecifikation for Danish Rox

AGIDON Kursushæfte. Effek viser dine arbejdsgange! Kursushæfte

Enalyzer Survey Solution. Kursusbeskrivelser. Kursuskalender 2012, 2. halvår - København/Vejle. Nyt kursus. om mobile undersøgelser

2. Metode. 2.1 Interessentanalyse Interessenterne i projektet er vist i nedenstående figur: Aftalekalenderprojektet. Indledning

Vejledning - Udarbejdelse af gevinstdiagram

Introduktion Til Functional Safety

Indledning. MIO er optimeret til Internet Explorer. Læs endvidere under Ofte stillede spørgsmål.

ZitePanel Infoskærme. ZitePanel produkt ark Alt hvad du skal vide om Zitemedia s infoskærm system ZitePanel!

Synopsis. Hardi Bootlader m. Java ME

Noter til dm529. Jonas Nyrup. 11. november 2011

Mobilitet har fået nyt navn: CrossPad. Comwell Kolding den 9. april 2013

2x50 ETHERNET MODUL. RS485 slave med Ethernet-IP. Gælder for: Program nr.: AUXSLAVE v1 Dokument nr.: 0422md2x50-2v1 Dato:

Underbilag 14 B: Oversigt over prøve- og testtyper. Udbud om levering, installation, implementering, support, drift og vedligehold af BAS

Planlægning og styring i praksis hos

EG Data Inform. Byggebasen. WCF og webservices. Jens Karsø

DGI - GEVINSTREALISERING

GODE RÅD TIL MØDELEDER

Hurtigbrugsanvisning til Dynomet 6.31 for Windows 7

Lavet af Danni jensen og David Olsen

7. Referencer til andre værktøjer. 8. Sammenhæng med internationale standarder. 9. Referencer til Projektledelse Teori og praksis. 10.

Innovationens Syv Cirkler

BRUGERCENTRERET DESIGN.

Transkript:

Struktureret system udvikling Minimodul 2: Kravspecifikation og accepttest Rasmus L. Olsen, 18 februar 2009

Kursusoversigt og tidsplan Mm1: Introduktion til kursus, UML og use cases (11 Februar, 2008) Mm2: Kravspecifikation og accepttest (18/2) Mm3: SPU og UML (11/3) Mm4: Design af system (18/3) Mm5: Test design og planlægning (25/3??)

Dagens program Opsummering fra sidst Kravspecifikation Accepttest

SPU V model Kravspec. Programdesign Procesdesign Moduldesign Accepttest Procesintegration Modulintegration Modultest Implementation

Eksempel MP3 afspiller MP3 afspiller Lytteren Afspil mp3 fil Vis ID-tag info Forstærker anlæg Uploader PC Upload af mp3 filer

Relation mellem kravspecifikation og use cases

Nogen Spørgsmål?

Dagens program Opsummering fra sidst Kravspecifikation Accepttest

Målet er at. Målet er : IKKE en god kravspecifikation i sig selv MEN et godt produkt Hvorfor så ikke spare kravspecifikationen? Svarer til ønsket om blive millionær satse på at vinde i lotteriet eller arbejde hårdt/smart!

Hvorfor kravspecifikation? #1/2 Enig?!? Aftale mellem kunde og leverandør om hvad der skal udvikles (afstemme mål og forventninger)

Hvorfor kravspecifikation? #2/2 Basis for projektplanlægning Basis for at estimere udviklingsomkostninger Reducere samlede udviklingsomkostninger Prioritering af projekt elementer Grundlag for accepttestspecifikation Har vi nået vores mål? Grundlag for fremtidige ændringer Forbedret portabilitet (til andre afdelinger/ platforme / etc.)

Hvordan laves en GOD kravspecifikation?

IEEE standarder/anbefalinger Paradoks Masser af information/vejledninger om udarbejdelse af kravspecifikation er tilgængelig MEN de bruges IKKE (altid)!!!! m.fl.

Hvad er en GOD kravspecifikation? IEEE std 830-1998 anbefaler følgende Korrekthed Utvetydig Komplet Konsistent Organiseret efter prioritet/vigtighed Verificerbar Modificerbar Sporbar

Korrekthed En kravspecifikation er korrekt, hvis og kun hvis ethvert krav i specifikationen er noget produktet skal overholde Mangler der nogen krav? Er der unødvendige krav i specifikationen? Er det reelt de krav, som kunden egentlig ønsker skal opfyldes? Glemte krav vdr. resonans On November 7, 1940, at approximately 11:00 AM, the first Tacoma Narrows suspension bridge collapsed due to wind-induced vibrations. Situated on the Tacoma Narrows in Puget Sound, near the city of Tacoma, Washington, the bridge had only been open for traffic a few months. (from http://www.enm.bris.ac.uk/research/nonlinear/tacoma/tacoma.html)

Utvetydig En kravspecifikation er utvetydig, hvis og kun hvis hvert krav har en mening Undgå udefinerede ord: Eksempel: genstartstid på motoren skal være min. 10 min. Hvad er genstartstid? Inkluderer det motoren først stopper, eller er det fra når motoren starter igen? Undgå ord som: tilstræbe, hurtigt, rimelig, så vidt muligt, eventuelt, Problemer kan være/opstå pga. Sprogbarrierer Er et skib er det en lystyacht, en stor færge eller noget andet Forskellige opfattelser af krav pga. folks forskellig baggrund For flyingeniøren er 800-1000 km/h en realistisk hastighed, mens raketingeniøren er det nærmere 11 km/s!! Krav repræsentationer/formuleringer SCMF skal automatisk vælge en CA der skal fungere som CMN i et PN cluster

Komplet En kravspecifikation er komplet hvis og kun hvis den inkluderer flg. elementer Indeholder alle betydende krav, hvad enten de hentyder til funktionalitet, ydelse, design begrænsninger, eller eksterne grænseflader. Specifikation af både gyldig og ugyldig input og output Referencer og figurtekst til samtlige figur, tabeller og diagrammer samt definitioner af samtlige termer og måleenheder TBD: To Be Determined Er ok så længe der itereres i udviklingsfasen Det er en god ide at beskrive hvorfor et krav er TBD og hvad der skal til for at ændre TBD til noget konkret Er IKKE ok når produktet afleveres

Konsistent En kravspecifikation er konsistent, hvis og kun hvis ingen underliggende krav er i konflikt med hinanden eller overordnede krav To type inkonsistens Forskellige navne (stophane vs. Lukkeventil) Direkte konflikt (blinkende rød lampe vs. konstant lysende rød lampe) Brug præcist og ikke varierende sprog Hmmm.. ~10 mio kr ~nm nøjagtig?? Den skal kunne en masse, være af god kvalitet og være billig

Organiseret efter prioritet/vigtighed En kravspecifikation er prioriteret hvis hvert krav har et nummer tilknyttet, der indikerer vigtigheden af kravet Kræver enighed mellem kunde og leverandør Kunden skal nøjere overveje sine enkelte krav Udviklere skal identificere tidskrav til enkelte opgaver Det er vigtigt at bussen er gul Det er vigtigt hjulene og styring kan klare terræn kørsel

Verificerbar En kravspecifikation er verificerbar hvis og kun hvis hvert krav opstillet kan verificeres Eksempler Ikke målbar: Resultatet af målingen skal være klar uden nævneværdig forsinkelse Programmet må ikke crashe! Intuitiv brugergrænseflade Målbar Resultatet skal i 70% af tilfældene foreligge inden 3 sek. og i 100% af tilfældene efter 7 sek. Programmet skal køre som forventet (overholde funktions bestemte krav) i mindst 99% af anvendelsesperioden Højst 5% af en given test gruppe må finde brugerfladen uoverskuelig

Modificerbar En kravspecifikation er modificerbar, hvis og kun hvis, dens struktur og stil er lavet således at ændringer, tilføjelser og fjernelse af krav ikke leder til inkonsistens eller redundans. Der VIL ske ændringer i krav under projektforløbet! Anvend struktur såsom Indholdsfortegnelse/indeks og logisk numerering Undgå redundans eller afhængige krav Separer krav i stedet for at blande krav sammen

Sporbar Et krav er sporbar hvis det er muligt at spore tilbage hvorfra kravet stammer Baglæns sporbarhed: Hvis krav kan henføres til tidligere specifikationer Forlæns Mulighed for at referere til krav fra fremtidige dokument (entydig identifikation af krav)

Kravspecifikation er en iterativ proces!! - og det er IKKE nemt

SPU check liste (jvf SPU bog side 82)

Bemærkninger Kravspecifikation skal beskrive hvad systemet skal gøre, og ikke hvordan det skal implementeres. Derfor, undgå Designkrav Projektkrav Det er OK at vende tilbage til krav og justere Man bliver klogere under projektforløbet Nogle krav giver pludselig ingen mening Nogle krav viser sig at være urealistiske

Indholdsfortegnelse af krav specifikation Indholdsfortegnelse er kun vejledende - Skal tilpasses de enkelte tilfælde (jeres projekter) Indledning Generel beskrivelse Specifikke krav Ekstern grænseflade Krav til ydelse Kvalitetskrav Design krav Andre krav Del-levering Se SPU-UML note eller IEEE Std. 830-1998

Indhold af kravspecifikation - Indledning Produktets navn Målet for udvikling Identifikation af leverandør og kunde Regler for indføring af ændringer Liste med reference dokumenter Læsevejledning Indledning Generel beskrivelse Specifikke krav Eksterne grænseflade Krav til ydelse Kvalitetskrav Design krav Andre krav Del-levering

Indhold af kravspecifikation Generel beskrivelse Beskrivelse af det totale system Hovedfunktioner vha. Use Cases Begrænsninger Fremtid Brugerprofiler Krav til udviklingsforløb Kundeleverance Forudsætninger (HW, SW, kunderepræsentant) Indledning Generel beskrivelse Specifikke krav Eksterne grænseflade Krav til ydelse Kvalitetskrav Design krav Andre krav Del-levering MP3 afspiller Afspil mp3 fil Lytteren Vis ID-tag info Forstærker anlæg Upload af mp3 filer Uploader PC

Indhold af kravspecifikation Specifikke krav Definitioner Detailkrav identificerbar reference/begrundelse prioritering levetid Indledning Generel beskrivelse Specifikke krav Eksterne grænseflade Krav til ydelse Kvalitetskrav Design krav Andre krav Del-levering

Indhold af kravspecifikation Eksterne grænseflader Bruger-grænseflade Hardware-grænseflade Kommunikations-grænseflade Software-grænseflade Indledning Generel beskrivelse Specifikke krav Eksterne grænseflade Krav til ydelse Kvalitetskrav Design krav Andre krav Del-levering

Indhold af kravspecifikation Krav til ydelse Tidskrav Programstørrelse Indledning Generel beskrivelse Specifikke krav Eksterne grænseflade Krav til ydelse Kvalitetskrav Design krav Andre krav Del-levering

Indhold af kravspecifikation Kvalitetskrav Pålidelighed Vedligeholdelses-venlighed Udvidelsesvenlighed Brugervenlighed Genbrugbarhed Integritet Effektivitet Indledning Generel beskrivelse Specifikke krav Eksterne grænseflade Krav til ydelse Kvalitetskrav Design krav Andre krav Del-levering

Indhold af kravspecifikation Design krav Hver kvalitetsfaktors vigtighed vurderes f.eks. skala 1.. 5 1: ukritisk, 2: ikke særlig vigtig, 3: vigtig, 4: meget vigtig, 5: særdeles vigtig eller MoSCoW skala: Must Should Could Won t Indledning Generel beskrivelse Specifikke krav Eksterne grænseflade Krav til ydelse Kvalitetskrav Design krav Andre krav Del-levering

Indhold af kravspecifikation Design krav Hvad der ikke falder under de andre kategorier Indledning Generel beskrivelse Specifikke krav Eksterne grænseflade Krav til ydelse Kvalitetskrav Design krav Andre krav Del-levering

Indhold af kravspecifikation Design krav Hvis projektet er opsplittet i del-leveringer definition af de enkelte leverancer hvilke specifikke krav der skal være opfyldt af den enkelte leverance X tid E E L Leverancetid Y tid L Z tid E E E Indledning Generel beskrivelse Specifikke krav Eksterne grænseflade Krav til ydelse Kvalitetskrav Design krav Andre krav Del-levering

If It s not tested, it doesn t work!!!

Accepttest Formål : Demonstrere overfor kunden, at produktet er som specificeret i kravspecifikationen. Udførelse : Planlægges, specificeres, designes og udføres af en uafhængig tester eller eventuelt af kunden selv. Generelt: des mere automatiserede en test er, jo bedre test gennemførelse Godkendelse : Godkendt accepttest er ofte betingelse for betaling af de sidste rater.

Indholdsfortegnelse af accepttest Accepttestspecifikationen består af: Indledning Formål Referencer Testens omfang og begrænsninger Godkendelse Testemner Testdesign/test metode

Eksempler på forskellige typer test Stress-test Volumen-test Bruger-test Sikkerhedstest Test på ydeevne Lagertest Konfigurationstest Kompatibilitetstest Pålidelighedstest Fejlbehandlingstest Mere om test og design af test i mm5

Men husk: planlæg jeres test ordentligt! Chernobyl, 26. April, 1986 : - En beslutning var taget om at teste værkets evne til at producere elektricitet nok til at drive værkets sikkerhedssystem i det tilfælde den eksterne el forsyning forsvandt. - En lang række af omstændigheder ikke taget i betragtning under testen, ledte til nedsmeltningen af reaktor 4 på kraftværket - Konsekvenserne ses stadig i dag og er meget virkelige på mange mennesker. En del er også døde som direkte og indirekte følgevirkning

Opsummering En god kravspecifikation har følgende karakteristika Korrekthed Utvetydig Komplet Konsistent Organiseret efter prioritet/vigtighed Verificerbar Modificerbar Sporbar Kravspecifikation leder op til accepttest Det er IKKE let at lave en god kravspecifikation, og kræver iterationer

Opgaver Opstilling af krav til jeres projekt baseret på use case fra sidste gang Fortsættelse af analysedokument Forbered jer på review... Hver gruppe skal/bør foretage to reviews af andre gruppers dokumenter Sørg for at være konstruktive og ikke destruktive i jeres kritik Det er meningen i skal hjælpe hinanden! Reviews vil indgå som en del af opgaveregning Skabelon til udfyldning af review vil blive tilgængelig på kursets hjemmeside snart

Et ord om review process og andre informationer Foreslået delegering af review: Gruppe 410 og 411 reviewer Gruppe 412 Gruppe 411 og 412 reviewer Gruppe 413 Gruppe 412 og 413 reviewer Gruppe 414 Gruppe 413 og 414 reviewer Gruppe 415 Gruppe 414 og 415 reviewer Gruppe 416 Gruppe 415 og 416 reviewer Gruppe 417 Gruppe 416 og 417 reviewer Gruppe 418 Gruppe 417 og 418 reviewer Gruppe 419 Gruppe 418 og 402 reviewer Gruppe 401 Gruppe 419 og 401 reviewer Gruppe 402 Gruppe 401 og 419 reviewer Gruppe 410 Gruppe 402 og 410 reviewer Gruppe 411