- Единица за тестирање против интеграција Тестирање наспроти функционално тестирање
- Што е тестирање на единици?
- Што е тестирање за интеграција ?
- Единица за тестирање наспроти интеграциско тестирање
- Функционално тестирање
- Заклучок
- Препорачана литература
Детална споредба на единица, интеграција и функционално тестирање:
За која било софтверска апликација, и тестирањето на единицата, како и тестирањето за интеграција, се многу важни бидејќи секоја од нив користи уникатен процес за тестирање софтверска апликација.
Но, кој било или дури и двете не можат да го заменат функционалното тестирање во ниту еден момент.
Единица за тестирање против интеграција Тестирање наспроти функционално тестирање
Тестирање на единица значи тестирање на поединечни модули на апликација во изолација (без каква било интеракција со зависности) до потврдете дека кодот ги прави работите правилно.
Интеграциското тестирање значи проверка дали различните модули работат добро кога се комбинираат заедно како група.
Функционално тестирање значи тестирање на дел од функционалноста во системот (може да има интеракција со зависности) за да се потврди дека кодот ги прави вистинските работи.
Функционалните тестови се поврзани со тестовите за интеграција, меѓутоа, тие означуваат на тестовите кои проверете ја целата функционалност на апликацијата со целиот код што работи заедно, речиси тест за супер интеграција.
Тестирањето на единицата предвидува проверка на една компонента на системот додека тестирањето на функционалноста ја разгледува проверката на работата на апликацијата во однос на планираното функционалност опишана во спецификацијата за системско барање. Од друга страна, тестирањето за интеграција ја разгледува проверкатаинтегрирани модули во системот.
И, што е најважно, за да се оптимизира повратот на инвестицијата (ROI), вашата база на код треба да има што е можно повеќе единечни тестови, помалку тестови за интеграција и најмалку функционални тестови.
Ова најдобро е илустрирано во следната тест пирамида:
Единиците на тестовите се полесни за пишување и побрзи за извршување. Времето и напорот за спроведување и одржување на тестовите се зголемуваат од тестирање на единицата до функционално тестирање како што е прикажано во горната пирамида.
Пример:
Дозволете ни да ги разбереме овие три типа на тестирање со премногу поедноставен пример.
На пр. . За функционален мобилен телефон, потребните главни делови се „батерија“ и „сим-картичка“.
Пример за тестирање на единицата – Батеријата се проверува за нејзиниот век на траење, капацитет и други параметри. СИМ-картичката се проверува дали е активирана.
Пример за тестирање за интеграција – Батеријата и сим-картичката се интегрирани, т.е. собрани за да го стартуваат мобилниот телефон.
Функционално Пример за тестирање – Функционалноста на мобилниот телефон се проверува во однос на неговите карактеристики и користење на батеријата, како и можностите за сим-картичка.
Видовме пример во лаички услови.
Сега, да земеме технички пример за страница за најавување:
Речиси секоја веб-апликација бара нејзина корисници/клиенти да се логираат. За тоа, секоја апликација мораимајте страница „Најава“ која ги има овие елементи:
- Сметка/Корисничко име
- Лозинка
- Копче за најава/најава
За тестирање единица, следново може да бидат тест случаи:
- Должина на полето – полиња за корисничко име и лозинка.
- Вредностите на полето за внес треба да бидат валидни.
- Копчето за најава е овозможено само откако ќе се внесат валидни вредности (Формат и по должина) во двете полиња.
За тестирање за интеграција, следниве може да бидат случаите за тестирање:
- Корисникот ја гледа пораката за добредојде откако ќе внесе валидни вредности и ќе го притисне копчето за најавување.
- Корисникот треба да се движи до страницата за добредојде или почетната страница по валиден влез и кликнување копчето за најавување.
Сега, откако ќе се направат тестирањата на единицата и интеграцијата, да ги видиме дополнителните тест случаи што се разгледуваат за функционално тестирање:
- Очекуваното однесување е проверено, односно дали корисникот може да се најави со кликнување на копчето за најавување откако ќе внесе важечки вредности на корисничко име и лозинка.
- Дали има порака за добредојде што треба да се појави по успешното најавување?
- Дали има порака за грешка што треба да се појави на неважечко најавување?
- Дали има складирани колачиња на страницата за полиња за најавување?
- Дали може да се најави инактивиран корисник?
- Дали има врска „заборавена лозинка“ за корисниците кои ги заборавиле своите лозинки?
Има многу повеќе такви случаи кои доаѓаат доумот на функционален тестер додека врши функционално тестирање. Но, развивачот не може да ги преземе сите случаи додека ги гради случаите за тестови за единица и интеграција.
Така, има многу сценарија што допрва треба да се тестираат дури и по тестирањето на единицата и интеграцијата.
Сега е време да се испитаат единечните, интегративните и функционалните тестирања еден по еден.
Што е тестирање на единици?
Како што сугерира името, ова ниво вклучува тестирање на „Единица“.
Овде единицата може да биде најмалиот дел од апликацијата што може да се тестира, било да е тоа најмалата индивидуална функција, метод итн. Развивачите на софтвер се тие кои ги пишуваат случаите за тестирање на единицата. Целта овде е да се усогласат барањата и очекуваното однесување на единицата.
Подолу се дадени неколку важни точки за тестирањето на единицата и неговите придобивки:
- Тестирање на единицата се прави пред интеграциското тестирање од развивачите на софтвер користејќи техники за тестирање во белата кутија.
- Тестирањето на единицата не само што го проверува позитивното однесување, односно правилниот излез во случај на валиден влез, туку и неуспесите што се случуваат со неважечки влез.
- Наоѓањето проблеми/бубачки во рана фаза е многу корисно и ги намалува вкупните трошоци на проектот. Бидејќи тестирањето на единицата се прави пред интеграцијата на кодот, проблемите пронајдени во оваа фаза може да се решат многу лесно, а нивното влијание е исто така многу помало.
- Единскиот тест тестира мали парчиња код или индивидуалнифункционира така што проблемите/грешките пронајдени во овие тест случаи се независни и не влијаат на другите тест случаи.
- Друга важна предност е што единиците за тест случаи го поедноставуваат и го олеснуваат тестирањето на кодот. Така, станува полесно да се решат проблемите и во подоцнежна фаза бидејќи треба да се тестира само најновата промена во кодот.
- Тестот на единицата заштедува време и трошоци, а може повторно да се употребува и лесно се одржува.
JUnit (Java frame), PHPUnit (PHP frame), NUnit (.Net Framework) итн. се популарни алатки за тестирање единици што се користат за различни јазици.
Што е тестирање за интеграција ?
Интеграциското тестирање е тестирање на интеграцијата на различни делови од системот заедно. Два различни делови или модули на системот прво се интегрираат, а потоа се врши интеграциско тестирање.
Целта на интеграциското тестирање е да се провери функционалноста, доверливоста и перформансите на систем кога е интегриран.
Тестирањето на интеграцијата се врши на модулите кои прво се тестираат единица, а потоа интеграциското тестирање дефинира дали комбинацијата на модулите го дава саканиот излез или не.
Тестирањето на интеграцијата може или може да се направи од независни тестери или од програмери.
Постојат 3 различни типови на пристапи за тестирање на интеграцијата. Дозволете ни да разговараме за секој од нив накратко:
а) Пристап за интеграција на Биг Бенг
Во овој пристап, сите модули или единици се интегрирани и тестирани како целина во исто време. Ова обично се прави кога целиот систем е подготвен за интеграциско тестирање во еден момент.
Ве молиме не го мешајте овој пристап на интеграциско тестирање со системско тестирање, само интеграцијата на модулите или единиците се тестира и не целиот систем како што се прави при тестирањето на системот.
Главната предност на пристапот на големата експлозија е што сè што е интегрирано се тестира одеднаш.
Еден главен недостаток е тоа што станува тешко да се идентификуваат неуспесите.
Пример: На сликата подолу, единицата 1 до единицата 6 се интегрирани и тестирани со помош на пристапот на Big Bang.
б) Пристап одозгора надолу
Интеграцијата на единиците/модулите се тестира од горните до долните нивоа чекор по чекор.
првата единица се тестира поединечно со пишување тест STUBS. После ова, пониските нивоа се интегрираат едно по едно додека последното ниво не се состави и тестира.
Пристапот од горе надолу е многу органски начин на интегрирање бидејќи е конзистентен со тоа како работите се случуваат во реалноста околина.
Единствената загриженост со овој пристап е што главната функционалност се тестира на крајот.
в) Долно- Пристап нагоре
Единиците/модулите се тестираат од дното до горното ниво, чекор по чекор, додека не се интегрираат сите нивоа на единици/модулии тестиран како една единица. Во овој пристап се користат програми за стимулатори наречени DRIVERS . Полесно е да се откријат проблеми или грешки на пониските нивоа.
Главната недостаток на овој пристап е што проблемите на повисоко ниво може да се идентификуваат само на крајот кога сите единици имаат е интегрирано.
Единица за тестирање наспроти интеграциско тестирање
Имајќи доволно дискусија за тестирање на единицата и тестирање за интеграција, ајде брзо да ги разгледаме разликите помеѓу двете во следната табела:
Единица за тестирање | Интеграционо тестирање |
---|---|
Ја тестира една компонента на целиот систем т.е. тестира единица во изолација. | Ги тестира компонентите на системот кои работат заедно, односно ја тестира соработката на повеќе единици. |
Побрзо за извршување | Може да работи бавно |
Без надворешна зависност. Секоја надворешна зависност е исмејувана или отфрлена. | Потребна е интеракција со надворешни зависности (на пр. База на податоци, хардвер, итн.) |
Едноставно | Комплекс |
Спроведено од развивач | Спроведено од тестер |
Тоа е тип на тестирање на белата кутија | Тоа е тип на тестирање на црна кутија |
Извршено во почетната фаза на тестирањето, а потоа може да се изврши во секое време | Мора да се изврши по тестирањето на единицата и пред тестирањето на системот |
Ефтиноодржување | Скапо одржување |
Почнува од спецификацијата на модулот | Почнува од спецификацијата на интерфејсот |
Единица тестирањето има тесен опсег бидејќи само проверува дали секое мало парче код го прави она што е наменето да го направи. | Има поширок опсег бидејќи ја опфаќа целата апликација |
Исходот од тестирањето на единицата е детална видливост на кодот | Исходот од интеграцијата тестирањето е детална видливост на структурата за интеграција |
Откријте ги проблемите во рамките на функционалноста само на поединечни модули. Не открива грешки при интеграција или проблеми низ целиот систем. | Откријте ги грешките што се појавуваат кога различни модули комуницираат едни со други за да го формираат целокупниот систем |
Функционално тестирање
Техниката за тестирање на црната кутија, каде што функционалноста на апликацијата се тестира за да се генерира саканиот излез при обезбедување на одреден влез се нарекува „Функционално тестирање“.
Во нашите процеси на тестирање на софтверот, ние направете го тоа со пишување тест случаи според барањата и сценаријата. За која било функционалност, бројот на напишани тест случаи може да варира од еден до многу.
Заклучок
Сите овие три типа на тестирање се во корелација.
За да се постигне целосна покриеност, потребно е да има единечни тестови за патеките/линиите на кодот, функционалните и тестовите за интеграција за да се увери дека „единиците“работат заедно кохезивно.
Се надевам дека оваа статија ќе ви даде јасна идеја за Единица, интеграција и функционално тестирање заедно со нивните разлики, иако има многу повеќе во овие форми на тестирање!!