설계

화이트박스 테스트(White Box Test)와 블랙박스 테스트(Black Box Test)

Sigfriede 2024. 2. 5. 18:00

  화이트박스 테스트(White Box Test)란 모듈의 원시 코드를 오픈시킨 상태에서 프로시저 설계의 제어 구조를 사용하여 원시 코드의 논리적인 모든 경로를 테스트하여 테스트 케이스를 설계하는 방법이다. 프로그램의 제어 구조에 따라 선택, 반복 등의 분기점 부분들을 수행하여 논리적 경로를 제어한다. 설계된 절차에 초점을 두며 테스트 과정의 초기에 적용된다. 모듈 안의 동작을 직접 관찰한다. 

  화이트박스 테스트는 절차적 설계의 논리적 복잡성을 측정하는 기초 경로 검사(Base Path Testing)와 제어 구조 검사(Control Structure Testing) 등이 있다. 제어 구조 검사는 다시 여러 가지로 나눌 수 있는데, 모듈 내 논리적 조건을 테스트하는 조건 검사(Condition Testing), 반복 구조에 초점을 맞춘 루프 검사(Loop Testing), 변수의 정의와 변수 사용의 위치에 초점을 맞춘 데이터 흐름 검사(Data Flow Testing)가 있다.

  화이트박스 테스트의 검증 기준에는 소스 코드의 모든 구문이 한 번 이상 수행되도록 검증하는 문장 검증 기준(Statement Coverage), 소스 코드의 모든 조건이 True와 False인 경우가 한 번 이상 수행되도록 검증하는 분기 검증 기준(Branch Coverage), 소스 코드의 조건문에 포함된 개별 조건식의 결과가 True와 False인 경우가 한 번 이상 수행되어 검증하는 조건 검증 기준(Condition Coverage), 분기 검증 기준과 조건 검증 기준을 모두 만족하는 분기/조건 기준(Branch/Condition Coverage)이 있다.

 

  블랙박스 테스트(Black Box Test)란 기능 테스트라고도 하며 각 기능이 완전히 작동되는 것을 입증한다. 소프트웨어 인터페이스에서 실시되며 주로 구현된 기능을 테스트한다. 부정확하거나 누락된 기능, 인터페이스 오류 등을 발견하기 위해 사용되며 테스트 과정의 후반에 적용된다.

  블랙박스 테스트는 해당 입력 자료에 맞는 결과가 출력되는지 확인하는 동치 분할 검사(Equivalence Partitioning Testing), 입력 조건의 경계값을 테스트 케이스로 선정하여 검사하는 경계값 분석(Boundary Value Analysis), 입력 데이터 간 관계와 출력에 미치는 상황을 체계적으로 분석한 다음 효용성이 높은 테스트 케이스를 선정하여 검사하는 원인-효과 그래프 검사(Cause-Effect Graphing Testing), 과거의 경험이나 확인자의 감각으로 테스트하는 오류 예측 검사(Error Guessing), 여러 버전의 프로그램에 동일한 테스트 자료를 제공하여 동일한 결과가 출력되는지 확인하는 비교 검사(Comparison Testing) 등이 있다.

'설계' 카테고리의 다른 글

모듈(Module)  (0) 2024.02.02
트랜잭션 스크립트 패턴과 도메인 모델 패턴  (1) 2024.01.15
객체 지향 프로그래밍  (2) 2023.12.07