Software Quality Assurance (SQA) er definert som en godt planlagt og systematisk tilnærming for å evaluere kvaliteten på programvaren. Den kontrollerer overholdelsen av programvarestandarder, prosesser og prosedyrer. SQA inkluderer den systematiske prosessen med å sikre at standarder og prosedyrer er etablert og følges gjennom programvarens utvikling og livssyklus.
Hovedfokuset for testing er å identifisere feilene i systemet så tidlig som mulig, fordi det er billigere å fikse feilene tidlig. I henhold til tallene i en undersøkelse, hvis feil blir funnet etter utgivelsen, blir de dyrere å fikse, og de påvirker også sluttbrukernes tillit til applikasjonen.
En IBM-studie viser at det er 100 ganger dyrere å fikse feil som blir funnet etter at applikasjonen er utgitt
- For å oppsummere er kvalitetssikring av programvare viktig fordi det gjør det mulig å:
- Sørg for at prosjektet oppfyller kravene
- Forhindre, oppdage og fikse feil tidlig
- Minimer prosjektrisikoen
- Øk produktets pålitelighet
- Forbedre sluttbrukeropplevelsen
- Testing og standardoverholdelse
- Slippadministrasjon og Slipp kontroll
- Reduserte utbyggingskostnader
- Reduserte vedlikeholdskostnader
Fordeler med testing
- Redusert tid til markedet
- Høy kvalitet
- Toppmoderne testressurser
- Fleksibel ressurs
- Fokuser på strategiske prioriteringer
SQA-aktiviteter finner sted på hvert trinn av utviklingslivssyklusen. Stadiene er kategorisert i områder med kravinnsamling, systemdesign og koding og testing og til slutt utgivelse.
- Verifisering - Prosessen med å evaluere et system eller en komponent for å bestemme om produktene fra en gitt utviklingsfase oppfyller betingelsene som ble pålagt ved starten av den fasen.
- Validering - Prosessen med å evaluere et system eller en komponent under eller på slutten av utviklingsprosessen for å avgjøre om den tilfredsstiller spesifikke krav
Under kravanalysen, design og koding av applikasjonsutvikling må utgangene fra hvert trinn måles, overvåkes og styres slik at hver utgang kan verifiseres mot de forhåndsdefinerte utgangskriteriene. Når den endelige søknaden har fullført kodings- og integreringsfasen, må den valideres mot de opprinnelige søknadskravene og signeres av toppledelsen som godkjent valideringstesting. På hvert trinn av denne applikasjonsutviklingen, må innsatsen under utviklingen forbedres der det er mulig for å forbedre kvaliteten og forbli konkurransedyktig.
Forskjellen mellom verifisering, validering og måling av programvarekvalitet
En effektiv verifiseringsinnsats må vise at alle krav er utført riktig, dette gjøres ved å teste kravene mot produktleveransen. Disse testene kan utføres på nytt for å oppnå de samme resultatene hvis systemet endres på et senere tidspunkt.
Bekreftelse viser at et produkt oppfyller sine spesifiserte krav ved forhåndsdefinerte milepæler i løpet av utviklingslivssyklusen. Validering kontrollerer at systemet oppfyller kundens krav når utviklingslivssyklusen er fullført.
Validering er prosessen med å evaluere det endelige produktet for å sjekke om applikasjonen oppfyller kundens forventninger og krav. Det er en dynamisk mekanisme for validering og testing av det faktiske produktet. Valideringstesten bruker metoder som svart boks (funksjonell) testing, grå boks testing og hvit boks (strukturell) testing, etc.
Kvaliteten på programvaren som produseres i hver prosess eller modell er beskrevet i forhold til antall feil som opprettes. Vanligvis er de vanligste beregningene for mangler:
- Totalt antall testsaker
- Antall prøvesaker bestått
- Antall testsaker mislyktes
- Antall testsaker blokkert
- Antall mangler funnet
- Antall mangler akseptert
- Antall avviste feil
- Antall utsatte mangler
- Antall kritiske feil
- Antall planlagte testtimer
- Antall faktiske testtimer
- Antall feil funnet etter levering
Ulike aktiviteter for kvalitetssikring er som følger:
- Opprettholde kvaliteten på prosjektet i henhold til spesifikasjonene og forretningskravene.
- Defektforebygging og formelle metoder for andre teknikker for forebygging av feil.
- Feilreduksjon.
- Inspeksjon, formell og uformell gjennomgang: Direkte feildeteksjon og fjerning uten å gjennomføre prosjektscenariet.
- Testing av prosjektet for feilobservasjon og fjerning av feil.
- Risikoidentifikasjon.
- Feilsporingsteknikker og -metoder.
- Feiltoleranse for programvare.
- Avsluttende bemerkninger og vedlikehold av rapporter.
Hvorfor kvalitetssikringen av programvaren er veldig viktig
- Brukerperspektiv : Kvalitetssikring av programvareapplikasjon er bra å se applikasjonen fra sluttbrukerperspektiv og lage et scenario avhengig av det samme.
- Defekt i testfasen : Det er bra å finne problemene på et tidlig stadium og fikse dem før for eksempel kundene finner dem i produksjonen.
- Prosjektrisiko : QA i begynnelsen av et prosjekt spiller en nøkkelrolle for å redusere risikoen som er identifisert i spesifikasjonsfasene.
- Pålitelighet : Øker sluttbrukernes tillit når de finner applikasjoner som fungerer i henhold til deres forventninger. Selv et negativt scenario med full feil øker tilliten til sluttbruker og gjør applikasjonen intelligent.
- Gjør sluttbrukeren enkel : Det hjelper sluttbrukeren å utføre forretningsoppgaver uten å ha teknisk kunnskap om applikasjonen. Lett forståelige applikasjoner har flere brukere enn tradisjonelle applikasjoner.
- Sikkerhetsbrudd : Det hjelper programvareutviklere å beskytte brukerdataene i produksjonsmiljøet og oppdage eventuelle datalekkasjer i testmiljøet.
- Lastforståelse : Det hjelper å forstå applikasjonen som fungerer under simulering og løse problemene etter å ha forstått den virkelige belastningen på systemet i produksjonsmiljøet.
- Automatisering : Testing av programvaren med det formål å redusere testinnsatsen, levere kapasitet raskere og på en rimeligere måte. Det hjelper med å bygge programvare av bedre kvalitet med mindre innsats.