Aina kun uusi ohjelmisto julkaistaan, tarve testata uusia toimintoja on ilmeinen. Yhtä tärkeää on kuitenkin suorittaa vanhat testit, jotka sovellus on aiemmin läpäissyt. Näin voimme olla varmoja siitä, että uusi ohjelmisto ei tuo vanhoja vikoja uudelleen tai luo uusia ohjelmistoon. Kutsumme tämän tyyppistä testausta nimellä regressiotestaus. Tässä artikkelissa tutkitaan regressiotestaustayksityiskohtaisesti. Jos olet uusi ohjelmistotestauksessa, lue myös .
Katsotaanpa tässä artikkelissa käsiteltyjä aiheita:
- Mikä on regressiotestaus?
- Regressiotestauksen edut?
- Milloin regressiotestausta käytetään?
- Mitkä ovat regressiotestauksen tyypit?
- Kuinka regressiotestaus toteutetaan?
- Regressiotestaustekniikat
- Regressiotestauksen haasteet
Mikä on regressiotestaus?
'Aikaisemmin testatun ohjelman testausta muokkauksen jälkeen sen varmistamiseksi, että vikoja ei ole havaittu tai paljastettu ohjelmiston muuttumattomilla alueilla tehtyjen muutosten seurauksena, kutsutaan regressiotestaukseksi.'
Regressiotesti on koko järjestelmän kattava testi, jonka päätarkoitus on varmistaa, että pieni muutos järjestelmän yhdessä osassa ei riko olemassa olevaa toiminnallisuutta muualla järjestelmässä. Jos pidät regressiota tahattomana muutoksena, tämän tyyppinen testaus on näiden muutosten metsästysprosessi. Yksinkertaisesti sanottuna on kyse siitä, ettei vanhoja vikoja tule takaisin ahdistamaan sinua. Katsotaanpakatsokaa fiktiivistä esimerkkiä, joka kuvaa käsitettä.
Kun lisäät uuden maksutyypin ostosivustolle, suorita vanhat testit uudelleen varmistaaksesi, että uusi koodi ei ole luonut uusia vikoja tai ottanut vanhoja uudelleen käyttöön.Regressiotestaus on tärkeää, koska ilman sitä on täysin mahdollista tuoda tarkoitetut korjaukset järjestelmään, joka aiheuttaa enemmän ongelmia kuin ne ratkaisevat.
Regressiotestauksen edut
Regressiotestien suorittaminenhyötyy yrityksille monin tavoin, kuten:
- Se lisää mahdollisuuksia havaita ohjelmistoon ja sovelluksiin tehtyjen muutosten aiheuttamat virheet
- Se voi auttaa vikojen havaitsemisessa jo varhaisessa vaiheessa ja siten vähentää niiden korjaamisesta aiheutuvia kustannuksia
- Auttaa tutkimaan ei-toivottuja sivuvaikutuksia, joita saattaa esiintyä uuden toimintaympäristön vuoksi
- Varmistaa suorituskykyisemmän ohjelmiston virheiden ja virheiden varhaisen tunnistamisen vuoksi
- Mikä tärkeintä, se varmistaa, että koodimuutokset eivät palauta vanhoja vikoja
Regressiotestaus varmistaa ohjelmiston oikeellisuuden siten, että tuotteen paras versio julkaistaan markkinoilla. Todellisessa maailmassa melkein loputtoman regressiotestisarjan suunnittelu ja ylläpito ei kuitenkaan ole mahdollista. Joten sinun pitäisi tietää, milloin regressiotestausta käytetään.
Milloin regressiotestausta käytetään?
On suositeltavaa suorittaa regressiotesti seuraavien tapahtumien esiintymiselle:
- Kun uusia toimintoja lisätään
- Muutosvaatimusten ollessa kyseessä
- Kun vikakorjaus on
- Kun esiintyy suorituskykyongelmia
- Ympäristön muutosten yhteydessä
- Kun korjaustiedosto on korjattu
Tämän artikkelin seuraava osa koskee erityyppisiä regressiotestejä.
paras ohjelmisto java-ohjelmointiin
Mitkä ovat regressiotestauksen tyypit?
Regressiotestaus tehdään useissa testausvaiheissa. Tästä syystä regressiotestejä on useita. Jotkut niistä ovat seuraavat:
Yksikön testaus: Yksikkötestauksessa, kun koodauksen muutoksia tehdään yhdelle yksikölle, testaaja, yleensä koodista vastaava kehittäjä, suorittaa kaikki aiemmin läpäistyt yksikötestit uudelleen. Sisään ympäristöissä automaattiset yksikötestit on rakennettu koodiin, mikä tekee yksikötestauksesta erittäin tehokasta verrattuna muihin testaustyyppeihin.
Progressiivinen testaus: Tämäntyyppinen testaus toimii tehokkaasti, kun ohjelmisto- / sovellusspesifikaatioihin tehdään muutoksia sekä uusia on suunniteltu.
Valikoiva testaus: Valikoivassa testauksessa testaajat käyttävät nykyisten testitapausten osajoukkoa vähentämään uudelleentestauksen kustannuksia ja vaivaa. Testiyksikkö on suoritettava uudelleen vain ja vain, jos jotakin sen kattamista ohjelma-entiteeteistä on muutettu.
Testaa kaikki uudelleen: Tämän tyyppinen testausstrategia sisältää tietyn sovelluksen kaikkien näkökohtien testaamisen sekä kaikkien testitapausten uudelleenkäytön, vaikka muutoksia ei olisi tehty. Se on aikaa vievää eikä siitä ole paljon hyötyä, kun sovellukseen tehdään pieniä muutoksia tai muutoksia.
Täydellinen testaus: Tämä testaus on erittäin hyödyllinen, kun olemassa olevaan koodiin on tehty useita muutoksia. Tämän testauksen suorittaminen on erittäin arvokasta odottamattomien virheiden tunnistamiseksi. Kun tämä testaus on suoritettu, lopullinen järjestelmä voidaan asettaa käyttäjän saataville.
On erittäin tärkeää tietää, minkä tyyppinen testaus sopii vaatimuksiisi. Seuraavaksi keskustelemme siitä, miten regressiotestaus toteutetaan.
Kuinka regressiotestaus toteutetaan?
Regressiotestauksen toteuttaminen on samanlainen kuin mitä käytät muussa testausprosessissa. Aina kun ohjelmistoon tehdään muutoksia ja uusi julkaisu tulee esiin, kehittäjä suorittaa nämä vaiheet osana testausprosessia:
- Ensinnäkin hän suorittaa yksikkötason regressiotestit vahvistamaan muokkaamansa koodin sekä kaikki uudet testit, jotka he ovat kirjoittaneet kattamaan uudet tai muuttuneet toiminnot
- Sitten muutettu koodi yhdistetään ja integroidaan luomaan testattavan sovelluksen uusi koontiversio (AUT)
- Seuraavaksi suoritetaan savutestit sen varmistamiseksi, että rakenne on hyvä, ennen kuin lisätestit suoritetaan
- Kun koontiversio on julistettu hyväksi, suoritetaan integraatiotestit, joilla varmistetaan sovelluksen yksiköiden välinen vuorovaikutus keskenään ja taustapalveluiden, kuten tietokantojen, kanssa
- Vapautetun koodin koosta ja laajuudesta riippuen joko osittainen tai täydellinen regressio ajoitetaan
- Vioista ilmoitetaan sitten kehitystiimille
- Tarvittaessa suoritetaan ylimääräisiä regressiokokeita
Näin regressiotestaus sisällytetään tyypilliseen ohjelmistojen testausprosessiin. Alla oleva kuva kuvaa selvästi, miten regressiotestaus suoritettiin.
Aina kun lähdekoodiin tehdään joitain muutoksia, ohjelman suorittaminen epäonnistuu ilmeisistä syistä. Vian jälkeen lähdekoodia viritetään virheen tunnistamiseksi ohjelman virheistä. Tarvittavat muutokset tehdään. Sitten sopivat testitapaukset valitaan jo olemassa olevasta testipaketista, joka kattaa kaikki lähdekoodin muokatut ja vaikuttavat osat. Uudet testitapaukset lisätään tarvittaessa. Loppujen lopuksi testaus suoritetaan valituilla testitapauksilla. Nyt saatat miettiä, mitkä testitapaukset valitaan.
Tehokkaat regressiotestit voidaan tehdä valitsemalla seuraavat testitapaukset:
- Testitapaukset, joissa on usein vikoja
- Monimutkaiset testitapaukset
- Integraatiotestitapaukset
- Testitapaukset, jotka kattavat tuotteen ydintoiminnot
- Usein käytetyt toiminnot
- Testaa maljakoita, jotka usein epäonnistuvat
- Raja-arvotestitapaukset
Kun regressiotestaus on poissa tieltä, katsotaanpa erilaisia tekniikoita.
Regressiotestaustekniikat
Regressiotestaus yksinkertaisesti vahvistaa, että muokattu ohjelmisto ei ole vahingossa muuttunut, ja se suoritetaan yleensä käyttämällä mitä tahansa seuraavien tekniikoiden yhdistelmää:
Testaa kaikki uudelleen: Tämä menetelmä yksinkertaisesti testaa koko ohjelmistopaketin uudelleen ylhäältä alas. Monissa tapauksissa suurin osa näistä testeistä suoritetaan automatisoiduilla työkaluilla. Tietyinä aikoina automaatio ei ole tarpeen. Tämä tekniikka on kallista, koska se vaatii enemmän aikaa ja resursseja muihin tekniikoihin verrattuna.
Testin valinta: Kaikkien testitapausten valitsemisen sijaan tämä menetelmä antaa tiimille mahdollisuuden valita joukko testejä, jotka arvioivat testipaketin täydellisen testauksen. Tämän käytännön ensisijainen etu on, että sen suorittaminen vaatii paljon vähemmän aikaa ja vaivaa. Yleensä kehittäjät, joilla on yleensä parempi käsitys testireunojen vivahteista ja odottamattomasta käyttäytymisestä.
Testitapausten priorisointi: Tämän tekniikan tavoitteena on asettaa etusijalle rajoitettu joukko testitapauksia ottamalla huomioon enemmän potentiaalisia testitapauksia ennen vähemmän tärkeitä. Valitaan testitapaukset, jotka voivat vaikuttaa sekä ohjelmiston nykyisiin että tuleviin rakenteisiin.
Nämä ovat kolme päätekniikkaa. Toisinaan testausvaatimusten perusteella nämä tekniikat yhdistetään.
käytä pythonia visuaalisessa studiossa
Niin hyödyllistä kuin regressiotestaus voi olla, se ei ole ilman negatiivisia pisteitä. Sinun on ymmärrettävä haasteet, joita saatat kohdata toteuttaessasi sitä.
Regressiotestauksen haasteet
- Aikaavievä: Uudelleentestauksen kaltaiset tekniikat vaativat paljon aikaa testitapausten koko sarjan testaamiseen
- Kallis: Kallis resurssien ja työvoiman takia, jotka sinun on testattava uudestaan ja uudestaan, mikä on jo kehitetty, testattu ja otettu käyttöön varhaisessa vaiheessa
- Monimutkainen: Tuotteen laajentuessa testaajat ovat usein masentuneita valtavasta määrästä testitapauksia ja joutuvat menetettyjen testitapausten uhriksi, unohtamatta tärkeitä testitapauksia
Näistä negatiivisista pisteistä huolimatta regressiotestaus on erittäin hyödyllistä ohjelmistojen testausprosessissa. Regressiotestauksen avulla yritykset voivat estää hankkeita menemästä yli budjetin, pitää tiiminsä oikealla tiellä ja mikä tärkeintä, estää odottamattomat virheet vahingoittamasta tuotteitaan. Tämän avulla olemme päässeet blogin loppuun. Toivottavasti täällä tänään oppimasi asiat auttavat sinua lähtiessäsi ohjelmistojen testausmatkalle.
Jos löysit tämän artikkeli asiaankuuluva, tutustu live-verkossa Edureka, luotettava verkko-oppimisyritys, jolla on yli 250 000 tyytyväisen oppijan verkosto, joka levisi ympäri maailmaa.
Onko sinulla kysymys meille? Mainitse se tämän kommentin osiossa. Mikä on regressiotestaus? Artikkeli ja palaamme sinuun.