Ang Pagkakaiba sa Pagitan ng Unit, Integration at Functional Testing

Isang Detalyadong Paghahambing ng Unit, Integration at Functional Testing:

Para sa anumang software application, parehong Unit testing, pati na Integration testing, ay napakahalaga dahil ang bawat isa sa kanila ay gumagamit ng isang natatanging proseso upang subukan ang isang software application.

Ngunit hindi mapapalitan ng sinuman o kahit na pareho ang Functional na pagsubok sa anumang punto.

Pagsusuri sa Unit Vs Pagsusuri sa Pagsasama Vs Pagsusuri sa Paggana

Pagsusuri sa unit ay nangangahulugan ng pagsubok sa mga indibidwal na module ng isang application nang nakahiwalay (nang walang anumang pakikipag-ugnayan sa mga dependency) sa kumpirmahin na tama ang ginagawa ng code.

Pagsubok sa integrasyon ay nangangahulugan ng pagsuri kung gumagana nang maayos ang iba't ibang mga module kapag pinagsama-sama bilang isang grupo.

Pagsusuri sa functional ay nangangahulugang pagsubok ng isang slice ng functionality sa system (maaaring makipag-ugnayan sa mga dependency) upang kumpirmahin na ang code ay gumagawa ng mga tamang bagay.

Ang mga functional na pagsubok ay nauugnay sa mga integration test, gayunpaman, sila ay nagpapahiwatig ng mga pagsubok na suriin ang buong functionality ng application kasama ang lahat ng code na tumatakbo nang magkasama, halos isang super integration test.

Isinasaalang-alang ng unit testing ang pagsuri sa isang bahagi ng system samantalang ang functionality testing ay isinasaalang-alang ang pagsuri sa paggana ng isang application laban sa nilalayon functionality na inilarawan sa detalye ng kinakailangan ng system. Sa kabilang banda, isinasaalang-alang ng integration testing ang pagsuripinagsamang mga module sa system.

At, higit sa lahat, para ma-optimize ang return on investment (ROI), ang iyong code base ay dapat magkaroon ng pinakamaraming unit test hangga't maaari, mas kaunting integration test at pinakamababang bilang ng functional tests.

Ito ay pinakamahusay na inilalarawan sa sumusunod na test pyramid:

Ang mga unit test ay mas madaling isulat at mas mabilis na isagawa. Ang oras at pagsisikap na ipatupad at mapanatili ang mga pagsubok ay tumataas mula sa unit testing hanggang sa functional na pagsubok tulad ng ipinapakita sa itaas na pyramid.

Halimbawa:

Ipaunawa natin ang tatlong uri ng pagsubok na ito gamit ang isang napakasimpleng halimbawa.

Hal . Para sa isang functional na mobile phone, ang mga pangunahing bahagi na kailangan ay "baterya" at "sim card".

Halimbawa ng pagsubok sa unit – Sinusuri ang baterya para sa buhay, kapasidad at iba pang mga parameter nito. Sinusuri ang sim card para sa pag-activate nito.

Halimbawa ng Pagsusuri sa Pagsasama – Ang baterya at sim card ay pinagsama-sama i.e. binuo upang simulan ang mobile phone.

Functional Halimbawa ng Pagsubok – Sinusuri ang functionality ng isang mobile phone sa mga tuntunin ng mga feature nito at paggamit ng baterya pati na rin ang mga pasilidad ng sim card.

Nakakita kami ng halimbawa sa mga tuntunin ng karaniwang tao.

Ngayon, kumuha tayo ngayon ng teknikal na halimbawa ng pahina sa pag-login:

Halos bawat web application ay nangangailangan nito user/customer para mag-log in. Para diyan, kailangang gawin ng bawat applicationmagkaroon ng page na “Login” na mayroong mga elementong ito:

  • Account/Username
  • Password
  • Buton na Mag-login/Mag-sign in

Para sa Unit Testing, ang mga sumusunod ay maaaring ang mga kaso ng pagsubok:

  • Haba ng field – mga field ng username at password.
  • Dapat wasto ang mga value ng field ng input.
  • Ang pindutan sa pag-login ay pinagana lamang pagkatapos na maipasok ang mga wastong halaga (Format at pahaba) sa parehong mga field.

Para sa Pagsusuri sa Pagsasama, ang mga sumusunod ay maaaring ang mga kaso ng pagsubok:

  • Nakikita ng user ang welcome message pagkatapos magpasok ng mga wastong value at itulak ang login button.
  • Dapat na ma-navigate ang user sa welcome page o home page pagkatapos ng wastong entry at pag-click ang button sa Pag-login.

Ngayon, pagkatapos magawa ang pagsubok sa unit at integration, tingnan natin ang karagdagang mga test case na isinasaalang-alang para sa functional na pagsubok:

  1. Ang inaasahang pag-uugali ay sinusuri, ibig sabihin, ang gumagamit ay makakapag-log in sa pamamagitan ng pag-click sa pindutan ng pag-login pagkatapos magpasok ng wastong username at mga halaga ng password.
  2. Mayroon bang welcome message na lalabas pagkatapos ng matagumpay na pag-login?
  3. Mayroon bang mensahe ng error na dapat lumabas sa isang di-wastong pag-login?
  4. Mayroon bang anumang naka-imbak na cookies ng site para sa mga field sa pag-login?
  5. Maaari bang mag-log in ang isang hindi aktibo na user?
  6. Mayroon bang anumang link na 'nakalimutan ang password' para sa mga user na nakalimutan ang kanilang mga password?

Marami pang mga ganitong kaso na dumating saang isip ng isang functional tester habang nagsasagawa ng functional testing. Ngunit hindi kayang sagutin ng developer ang lahat ng kaso habang gumagawa ng mga kaso ng pagsubok sa Unit at Integration.

Kaya, maraming mga sitwasyong susuriin pa kahit pagkatapos ng pagsubok sa unit at integration.

Panahon na para suriin ang Unit, Integration at Functional testing nang isa-isa.

Ano ang Unit Testing?

Tulad ng iminumungkahi ng pangalan, ang antas na ito ay nagsasangkot ng pagsubok sa isang 'Yunit'.

Dito ang unit ay maaaring ang pinakamaliit na bahagi ng isang application na nasusubok, ito man ang pinakamaliit na indibidwal na function, pamamaraan, atbp . Ang mga developer ng software ay ang nagsusulat ng mga kaso ng pagsubok sa unit. Ang layunin dito ay upang tumugma sa mga kinakailangan at inaasahang gawi ng unit.

Nasa ibaba ang ilang mahahalagang punto tungkol sa unit testing at mga benepisyo nito:

  • Unit testing ay ginagawa bago ang Integration testing ng mga developer ng software gamit ang white box testing techniques.
  • Ang unit testing ay hindi lamang nagsusuri sa positibong gawi ibig sabihin, ang tamang output kung sakaling may valid na input, kundi pati na rin ang mga pagkabigo na nangyayari sa invalid na input.
  • Ang paghahanap ng mga isyu/mga bug sa maagang yugto ay lubhang kapaki-pakinabang at binabawasan nito ang kabuuang gastos ng proyekto. Habang ginagawa ang pagsubok sa unit bago ang pagsasama-sama ng code, ang mga isyung makikita sa yugtong ito ay napakadaling mareresolba at ang epekto ng mga ito ay napakababa rin.
  • Ang isang unit test ay sumusubok sa maliliit na piraso ng code o indibidwalfunction upang ang mga isyu/error na makikita sa mga test case na ito ay independyente at hindi nakakaapekto sa iba pang mga test case.
  • Isa pang mahalagang bentahe ay ang mga unit test case ay nagpapasimple at nagpapadali sa pagsubok ng code. Kaya, nagiging mas madaling lutasin ang mga isyu sa mas huling yugto din dahil ang pinakabagong pagbabago lang sa code ang susuriin.
  • Ang pagsubok sa unit ay nakakatipid ng oras at gastos, at ito ay magagamit muli at madaling mapanatili.

JUnit (Java framework), PHPUnit (PHP framework), NUnit (.Net framework) atbp. ay mga sikat na unit testing tool na ginagamit para sa iba't ibang wika.

Ano ang Integration Testing ?

Ang integration testing ay sumusubok sa pagsasama ng iba't ibang bahagi ng system nang magkasama. Dalawang magkaibang bahagi o module ng system ang unang isinama at pagkatapos ay isasagawa ang integration testing.

Ang layunin ng integration testing ay suriin ang functionality, reliability, at performance ng system kapag isinama.

Isinasagawa ang integration testing sa mga module na unang nasubok sa unit at pagkatapos ay tinutukoy ng integration testing kung ang kumbinasyon ng mga module ay nagbibigay ng gustong output o hindi.

Ang integration testing ay maaaring alinman gagawin ng mga independiyenteng tester o ng mga developer din.

May 3 iba't ibang uri ng mga diskarte sa pagsubok ng Integration. Talakayin natin ang bawat isa sa kanila nang maikli:

a) Big Bang Integration Approach

Sa diskarteng ito, ang lahat ng mga module o unit ay pinagsama-sama at nasubok sa kabuuan sa isang pagkakataon. Ito ay kadalasang ginagawa kapag ang buong system ay handa na para sa integration testing sa isang punto ng oras.

Mangyaring huwag malito ang diskarteng ito ng integration testing sa system testing, tanging ang integration ng mga module o unit ang sinusuri at hindi ang buong system tulad ng ginagawa sa pagsubok ng system.

Ang pangunahing bentahe ng big bang approach ay ang lahat ng pinagsama-samang bagay ay nasubok sa isang pagkakataon.

Isang major disadvantage ay nagiging mahirap tukuyin ang mga pagkabigo.

Halimbawa: Sa figure sa ibaba, ang Unit 1 hanggang Unit 6 ay isinama at sinusubok gamit ang Big bang approach.

b) Top-Down Approach

Ang pagsasama-sama ng mga unit/modules ay sinusuri mula sa itaas hanggang sa ibabang antas nang sunud-sunod.

Ang ang unang unit ay sinubok nang paisa-isa sa pamamagitan ng pagsusulat ng test STUBS. Pagkatapos nito, isa-isang isinasama ang mga mas mababang antas hanggang sa pagsama-samahin at masuri ang huling antas.

Ang top-down na diskarte ay isang napaka-organikong paraan ng pagsasama dahil naaayon ito sa kung paano nangyayari ang mga bagay sa totoong buhay. kapaligiran.

Ang tanging pag-aalala sa diskarteng ito ay ang pangunahing pagpapagana ay nasubok sa dulo.

c) Ibaba- Up Approach

Sinusubukan ang mga unit/modules mula sa ibaba hanggang sa itaas na antas, hakbang-hakbang, hanggang sa maisama ang lahat ng antas ng unit/modulesat sinubukan bilang isang yunit. Ang mga stimulator program na tinatawag na DRIVERS ay ginagamit sa diskarteng ito. Mas madaling tuklasin ang mga isyu o error sa mas mababang antas.

Ang pangunahing kapinsalaan ng diskarteng ito ay ang mas mataas na antas na mga isyu ay matutukoy lamang sa dulo kapag ang lahat ng unit ay may isinama.

Unit Testing vs Integration Testing

Pagkaroon ng sapat na talakayan tungkol sa unit testing at integration testing, mabilis nating suriin ang mga pagkakaiba sa pagitan ng dalawa sa sumusunod na talahanayan:

Pagsubok sa Unit Pagsubok sa Pagsasama
Sinusubukan ang iisang bahagi ng buong system ibig sabihin, sumusubok sa isang unit nang nakahiwalay. Sinusubukan ang mga bahagi ng system na nagtutulungan i.e. subukan ang pakikipagtulungan ng maraming unit.
Mas mabilis na i-execute Maaaring tumakbo mabagal
Walang external na dependency. Ang anumang panlabas na dependency ay kinukutya o pinipigilan. Nangangailangan ng pakikipag-ugnayan sa mga panlabas na dependency (hal. Database, hardware, atbp.)
Simple Kumplikado
Isinasagawa ng developer Isinasagawa ng tester
Ito ay isang uri ng white box testing Ito ay isang uri ng black box testing
Isinasagawa sa paunang yugto ng pagsubok at pagkatapos ay maaaring isagawa anumang oras Dapat isagawa pagkatapos ng unit testing at bago ang system testing
Murangmaintenance Mamahaling maintenance
Nagsisimula sa detalye ng module Nagsisimula sa detalye ng interface
Unit Ang pagsubok ay may makitid na saklaw dahil sinusuri lamang nito kung ginagawa ng bawat maliit na piraso ng code ang nilalayon nitong gawin. Ito ay may mas malawak na saklaw dahil sinasaklaw nito ang buong application
Ang resulta ng unit testing ay detalyadong visibility ng code Ang kinalabasan ng integration ang pagsubok ay ang detalyadong visibility ng istraktura ng integration
Alamin ang mga isyu sa loob ng functionality ng mga indibidwal na module lamang. Hindi inilalantad ang mga error sa pagsasama o mga isyu sa buong system. Alamin ang mga bug na lumitaw kapag ang iba't ibang mga module ay nakikipag-ugnayan sa isa't isa upang mabuo ang pangkalahatang system

Functional Testing

Ang isang black box testing technique, kung saan ang functionality ng application ay sinusubok upang makabuo ng ninanais na output sa pagbibigay ng isang partikular na input ay tinatawag na 'Functional testing'.

Sa aming software testing process, we gawin ito sa pamamagitan ng pagsulat ng mga test case ayon sa mga kinakailangan at sitwasyon. Para sa anumang functionality, ang bilang ng mga test case na nakasulat ay maaaring mag-iba mula sa isa hanggang sa marami.

Konklusyon

Lahat ng tatlong uri ng pagsubok na ito ay magkakaugnay.

Upang makuha ang buong saklaw, ito ay kinakailangang magkaroon ng mga unit test para sa mga path/linya ng code, functional at Integration test para sa katiyakan na ang 'units'nagtutulungan nang sama-sama.

Sana ang artikulong ito ay nagbigay sa iyo ng malinaw na ideya tungkol sa Unit, Integration at Functional na pagsubok kasama ng kanilang mga pagkakaiba, kahit na marami pang iba sa mga uri ng pagsubok na ito!!

Inirerekomendang Pagbasa

    Mag-scroll pataas