Jokaisella meistä on mahdollisuus todistaa itsensä testaajina, ja testauksemme sisältää esimerkiksi hyötytuotteiden käyttöä. Kun olemme kytkeneet ne päälle ja varmistaneet, että ne suorittavat tehtävänsä ja vastaavat odotuksiamme, voimme päätellä, että laitteet toimivat oikein. Jos havaitsemme käyttöön liittyviä vikoja, palautamme ne valitusta varten. Ohjelmistotestaus perustuu samankaltaiseen periaatteeseen.
Mitkä ovat ohjelmistotestauksen perusteet? – sisällysluettelo:
- Mitä on ohjelmistotestaus?
- Ohjelmistotestauksen tavoitteet
- Millainen ohjelmistotestaajan työ on?
- Kuinka tulla testaajaksi?
Mitä on ohjelmistotestaus?
Ohjelmoijien kehittämä ohjelmisto altistuu testeille, jotka koostuvat sen oikean toiminnan ja vaatimustenmukaisuuden tarkistamisesta. Tätä kutsutaan ohjelmiston vahvistamiseksi.
Vaatimusmäärittely on asiakirja, joka sisältää kaikki tarvittavat tiedot ohjelmistosta, esim. sovelluksesta, ja se sisältää ensin kuvauksen toiminnoista, joita sen tulisi suorittaa. Tarkistamista, toimiiko ohjelmisto käyttäjien odotusten mukaan, kutsutaan validoinniksi.
Testaus parantaa ohjelmiston laatua, rajoittaa virheistä johtuvien vikojen esiintymistä, vähentää taloudellisia menetyksiä, lyhentää ohjelmistokehityksen aikaa ja vahvistaa yrityksen imagoa. Testausaktiviteetit on parasta suorittaa ohjelmiston toteutuksen varhaisimmissa vaiheissa. Mitä aikaisemmin virhe havaitaan, sitä alhaisemmat ovat sen korjauskustannukset. Jos testejä ei suoriteta ohjelmistokehityksen varhaisimmissa vaiheissa, voi syntyä komplikaatioita, kuten edistyneestä työstä projektissa, mikä voi vaikeuttaa virheen lähteen paikallistamista ja korjaamista.
Ohjelmistotestauksen tavoitteet
ISTQB:n (International Software Testing Qualifications Board) mukaan testauksen tavoitteet voidaan saavuttaa:
- Estämällä virheitä, jotka johtuvat virheistä, arvioimalla työtuotteita, kuten koodia,
- Vähentämällä ohjelmiston laadun heikkenemisen riskiä havaitsemalla vikoja, jotka johtuvat virheistä,
- Vahvistamalla, että ohjelmisto täyttää kaikki vaatimukset, jotka on sisällytetty sen dokumentaatioon, validointi, eli varmistaminen, että ohjelmisto vastaa käyttäjien odotuksia,
- Rakentamalla luottamusta testaukseen kaikilla tasoilla,
- Tarjoamalla tietoa, joka vaikuttaa sidosryhmiin tekemään tietoon perustuvia päätöksiä,
- Vaatimustenmukaisuus lakien, standardien, normien ja sopimusvaatimusten kanssa.
Millainen ohjelmistotestaajan työ on?
Testaajan työ on raportoida ohjelmiston käytön seurauksena löydetyt virheet. Jos hän löytää niitä, hän raportoi ne ohjelmoijalle, joka on vastuussa tietystä alueesta tai koko ohjelmistosta. Tällaisia raportointia varten on suunniteltu erityisiä ohjelmia. Testaaja kuvaa polun, jossa hän esittää vaihe vaiheelta tavan, jolla virhe havaittiin. Tämä mahdollistaa ohjelmoijan löytää virheen nopeasti ja korjata sen, ja sitten raportoida suoritetun tehtävän testaajalle uudelleentestattavaksi. Testaaja puolestaan seuraa polkua toistamalla saman vaihejärjestyksen. Jos virhe on korjattu, hän hyväksyy tehtävän, ja jos se toistuu, hän raportoi sen jälleen ohjelmoijalle.
Testaajat jaotellaan manuaalisiin ja automatisoituihin testaajiin. Manuaalisen testaajan työ on testata ohjelmistoa yksin arvioimalla jokainen testiskenaario, joka sisältää kaikki tapaukset, mikä on aikaa vievää. Automaattinen testaaja puolestaan käyttää työkaluja kirjoittaakseen skriptejä ja ohjelmia, jotka nopeuttavat prosessia ja lisäksi havaitsevat virheitä, jotka saattavat jäädä huomaamatta manuaaliselta testaajalta. Automaattinen testaus on siis tarkempaa, mutta työkalujen luominen vaatii tietämystä ohjelmointikielistä, kuten Java, SQL tai Python.
Kuinka tulla testaajaksi?
Jokaisen, joka aikoo tulla ohjelmistotestaajaksi, tulisi oppia testauksen teoria. Hankittua tietoa voidaan sitten vahvistaa suorittamalla ISTQB-tentti. Tämä on voittoa tavoittelematon organisaatio, joka on toiminut vuodesta 2002. Tentti on testimuotoinen, ja positiivisen tuloksen saatuasi tutkittava saa todistuksen, joka vahvistaa hänen pätevyytensä ja tietonsa testaajana. Tenttin etuna on, että sertifikaatilla ei ole voimassaoloaikaa ja se on tunnustettu maailmanlaajuisesti.
ISTQB-tentti voidaan suorittaa kolmella tasolla: Core, Agile ja Specialized. Core käsittelee ohjelmistotestauksen monipuolista aihetta. Agile viittaa ketteriin ohjelmistotestauskäytäntöihin, ja erikoismoduuli tarjoaa esimerkiksi tietoa, joka liittyy erityisiin testausaktiviteetteihin, kuten testiautomaation. On myös kolme tasoa tentin vaikeusasteesta: perus, edistynyt ja asiantuntija. Alla on kaavio mainituista moduuleista ja niiden tasoista.
Testaaja näyttelee tärkeää roolia ohjelmiston oikeassa toiminnassa, joten hänen tulisi omata ominaisuuksia, jotka helpottavat työtä. Tarkat, kärsivälliset, johdonmukaiset ja kommunikoivat henkilöt menestyvät parhaiten ohjelmistotestauksessa. Testaajan tulisi myös osoittaa analyyttisiä ajattelutaitoja testiskenaarioiden toteuttamisen vuoksi.
Yhteenveto
Ohjelmistotestaus on tapa havaita epäsäännöllisyyksiä ohjelmistossa ja parantaa sen laatua täyttämällä testauksen tavoitteet. Koko prosessia hoitavat ohjelmistotestaajat, joilla on erityinen tieto työnsä helpottamiseksi, ja he voivat vahvistaa sen esimerkiksi hankkimalla ISTQB-sertifikaatin.
Mitä on ohjelmistotestaus? Nyt tiedät vastauksen! Tutustu myös muihin sarjoihimme Pythonista ja Javascriptista!
Jos pidät sisällöstämme, liity vilkkaaseen mehiläisyhteisöömme Facebookissa, Twitterissä, LinkedInissä, Instagramissa, YouTubessa.
Robert Whitney
JavaScript-asiantuntija ja opettaja, joka valmentaa IT-osastoja. Hänen päämääränsä on nostaa tiimin tuottavuutta opettamalla muille, kuinka tehdä tehokasta yhteistyötä koodauksen aikana.