테스트 레벨) 컴포넌트 테스팅, 통합 테스팅

2021. 1. 26. 14:14IT관련

728x90
반응형

 

2.2.1 컴포넌트 테스팅

단위 테스팅이라고도 불리는 컴포넌트 테스팅은

테스트가 가능한 단위로 나누어진 소프트웨어 내에서 결함을 찾고

그 기능을 검증하는 것이다.

컴포넌트 테스팅은 개발 수명주기의 정황과 시스템에 의존적이면서도

시스템의 다른 부분에서 격리하여 독립적으로 수행해야 한다.

이 때 스텁과 드라이버, 시뮬레이터 등이 필요할 수 있다.

*스텁 :

골격만 있는 또는 특별한 목적의 소프트웨어 컴포넌트를 구현한 것.

스텁을 호출하거나 또는 스텁에 의존적인 컴포넌트를 개발하거나 테스트할 때 사용

스텁은 호출된 컴포넌트를 대체 한다. [IEEE 610 준수]

*드라이버 :

컴포넌트나 시스템을 제어하거나 호출하는 (실제) 상위 컴포넌트를 대체하는

테스트용의 소프트웨어 컴포넌트 또는 툴 [TMap 준수]

컴포넌트 테스팅은 구조적인 테스팅은 물론

기능성 테스트와 리소스 관련 테스팅 또는 강건성 테스팅과 같은 특정 비기능 테스팅을 포함한다.

테스트 케이스는 컴포넌트 명세서, 소프트웨어 상세 설계 또는 데이터 모델과 같은

개발 산출물에서 도출한다.

일반적으로 컴포넌트 테스팅은 코드를 중심으로 수행하며,

단위 테스트 프레임워크 또는 디버깅 툴 같은 개발 환경의 지원을 필요로 한다.

실무에서는 보통 코드를 작성한 프로그래머가 직접 테스트에 참여하여,

결함을 발견할 때마다 바로 수정하고, 결함에 대한 기록 과정은 생략하는 것이 일반적

그러나 테스트 프로세스 관리와 개선을 위해 단위 테스트에서 발견되는 결함에 대한

통계적인 테스터가 필요한 경우는 인시던트(또는 결함) 기록 과정이 있어야 한다.

컴포넌트 테스팅은

일반적으로 프로그램 소스 코드를 활용하여 테스트를 설계하며

주된 테스팅 방법은 구조기반 테스팅이다.

대표적인 구조 기반 기법

-제어흐름테스팅(Control Flow),

-조건/결정 커버리지 테스팅(condition/decisoin)

-최소비교 테스팅 (Elementary comparison test)

동등분할 & 경계값 분석 테스팅과 같은 명세기반 기법을 적용하기도 한다.

컴포넌트 테스팅의 일반적인 목적

-기본 경로(Path)를 확인

-모든 오류 처리 경로(Error handling Path)를 확인

-컴포넌트 내의 인터페이스 확인

-로컬 데이터 확인, 경계값 확인

컴포넌트 테스팅의 접근법 중에는

코딩 전에 테스트 케이스를 준비하고 자동화하는 방법이 있다.

이 것이 테스트 중심의 개발 방법론(Test-First approach 또는 test-driven development)이다.

이는 반복적인 성향이 매우 강한 접근법으로,

테스트 케이스를 개발한 후 작은 규모의 코드를 작성하여 통합하고

테스트가 통과할 때까지 반복 수행한다.


2.2.2. 통합 테스팅 (Integration testing)

통합 테스팅은

컴포넌트간의 인터페이스를 테스트 하는 것은 물론,

os, 파일 시스템, 하드웨어 또는 시스템간 인터페이스와 같은

시스템의 각기 다른 부분과 상호 연동하는 동작을 테스트 한다.

통합 테스팅은 하나 이상의 테스트 레벨이 있을 수 있으며,

다양한 크기의 테스트 대상에 대해 수행될 수 있다.

컴포넌트 통합 테스팅

소프트웨어 컴포넌트 사이의 상호작용을

테스트 하며 컴포넌트 테스팅 이후에 수행된다.

시스템 통합 테스팅

시스템 사이의 상호작용을 테스트하며,

시스템 테스팅 이후에 수행된다.

이 경우에 개발 조직은 한 쪽 시스템에 국한되어 제어 권한을 갖게 되고

변경 사항이 발생 하였을 때 시스템 전체 차원에서의 불안정을 유발할 수 있다.

비즈니스 프로세스가 시스템간의 업무 흐름을 가지고 있는 경우

시스템 간의 교차점에서 중대한 문제를 야기 할 수 있다.

통합하는 범위가 크면 클수록 장애나 결함의 위치를 찾아 격리하기가 쉽지 않다.

이는 개발의 리스크를 증가시키기도 한다.

따라서 상향식(Bottom-up), 하향식(Top-down), 백본(Back-bone)통합 과 같은

순차적이고 체계적인 통합 전략(Incremental approach)이

한 번에 통합하는 빅뱅(Big-Bang)전략보다 리스크를 줄이는데 효과적이다.

통합 테스팅은 기능적 특성은 물론 특정한 비기능적 특성을 테스팅해야 한다.

통합 테스팅의 설계는 기능적 접근법, 구조적 접근법을 모두 사용하여,

통합 그 자체에만 집중하는 오류를 범하지 않아야 한다.

이상적으로는 테스터가 아키텍처에 대한 이해를 바탕으로 통합 테스트 계획에 관여 해야 한다.

 

728x90
반응형