본문 바로가기

정보처리기사 실기/2020 정처기 암기 모음

[2020 정보처리기사 실기 암기] 7-1. 애플리케이션 테스트 케이스 설계

* 소프트웨어 테스트

  기능, 성능, 사용성, 안정성 만족하는지 확인하고 소프트웨어 결함을 찾아내는 활동

 

* 소프트웨어 테스트 필요성

 - 오류 발견 관점 : 잠재된 오류 발견, 수정

 - 오류 예방 관점 : 코드 리뷰, 동료 검토, 인스펙션으로 오류를 사전에 발견

 - 품질 향상 관점 : 반복적인 테스트로 신뢰도 향상하는 품질 보증 

 

* 소프트웨어 테스트 원리

  결함 존재, 완벽한 테스팅 불가능, 초기에 테스팅 시작, 결함 집중, 살충제 패러독스, 정황에 의존, 오류-부재 궤변

 

* 살충제 패러독스

  동일한 테스트 케이스에 의한 반복적 테스트는 새로운 버그를 찾지 못함

  테스트 케이스의 정기적 리뷰와 개선 및 다른 시각적 접근 필요

 

* 소프트웨어 테스트 원리 중 오류 부재의 궤변

  요구사항을 충족시켜주지 못하면 결함이 없어도 품질이 높다고 볼 수 없는 원리

 

* 소프트웨어 테스트 원리

 - 결함집중 : 20% 모듈에서 80%의 결함 발견

 - 테스팅은 정황에 의존적 : 소프트웨어 성격에 맞게 테스트 실시, 정황과 비즈니스 도메인에 따라 다르게 수행

 

* 소프트웨어 테스트 산출물

  테스트 결과서, 테스트 시나리오, 테스트 계획서, 테스트 케이스

 

* 테스트 프로세스

 1) 테스트 계획

 2) 테스트 분석 및 디자인

 3) 테스트케이스 및 시나리오 작성

 4) 테스트 수행

 5) 테스트 결과 평과 및 리포팅

 

* 테스트 시나리오

  테스트 수행을 위한 여러 테스트 케이스의 집합으로 테스트케이스 동작 순서 기술한 문서, 절차를 명세

 

* 정적 테스트 유형

 - 동료 검토 : 2~3명이 리뷰, 요구사항 명세서 설명, 이해관계자들이 설명을 들으면서 결함 발견

 - 워크스루 : 사전 검토 후 회의 진행하며 리뷰를 통해 오류 검출하고 문서화

 - 인스펙션 : 다른 전문가 또는 팀이 검사하여 오류 찾는 공식 검토 기법

 

* 인스펙션

  개발단계별 산출물을 검토하기 위한 공식적 검토 기법의 정적 테스트

 

 

* 화이트 박스 테스트 유형

  프로그램 내부 로직을 보면서 수행하는 테스트 - 구조 테스트 - 

 

* 블랙박스 테스트 유형

  동등 분할 테스트, 경계 값 분석 테스트, 결정 테이블 테스트, 상태전이 테스트

 - 동등분할 테스트 : 입력 데이터의 영역을 유사한 도메인 별로 유무효 값 그루핑하여 대표 값 테스트 케이스 도출

- 경계 값 분석 테스트 : 등가분할 후 경계 값 부분에서 오류 발생 확률이 높아서 경계 값을 포함하여 테스트 케이스 도출

- 유스케이스 테스트 : 유스케이스로 모델링 되어 있을 때 프로세스 흐름 기반으로 테스트 케이스 명세화

- 분류트리 테스트 : 소프트웨어 일부나 전체를 트리구조로 분석 및 표현하여 테스트케이스 설계

- 페어와이즈 테스트 : 테스트 데이터 값들을 최소 한 번씩 조합하는 방식, 상대적으로 적은 테스트 세트 구성

 

 

* 테스트 시간에 따른 테스트 분류

 - 검증 : 소프트웨어 과정를 테스트

 - 확인 : 소프트웨어 결과를 테스트

 

* 안전테스트 

  불법 소프트웨어가 접근하지 못하게 소스코드 내의 보안적인 결함을 미리 점검하는 테스트

 

* 강도테스트

  시스템에 과다 정보량을 부과하여 과부하 시에도 시스템이 정상적으로 작동되는지 검증하는 테스트

 

* 회귀 테스트

  오류를 제거하거나 수정한 시스템에서 오류 제거,수정으로 인해 새로 유입된 오류가 있는지 반복 테스트

 

* 테스트 종류에 따른 테스트 분류

 - 명세 기반 테스트 : 프로그램 요구사항 명세서 기반으로 테스트케이스 선정하여 테스트

 - 구조 기반 테스트 : 소프트웨어 내부 논리 흐름에 따라 테스트케이스 작성하고 확인하는 테스트

 - 경험 기반 테스트 : 유사 소프트웨어나 유사 기술 평가에서  테스터 경험 토대로 직관과 기술 능력 기반 수행 테스트

 

* 테스트 케이스 작성 절차

 1) 테스트 계획 검토 및 자료 확보

 2) 위험 평가 및 우선 선위 결정

 3) 테스트 요구사항 정의

 4) 테스트 구조 설계 및 테스트 방법 결정

 5) 테스트 케이스 정의 

 6) 타당성 확인 및 유지 보수

 

* 테스트 오라클

  테스트 결과가 참인지 거짓인지 판단을 위해 사전에 정의된 참 값을 입력하여 비교하는 기법

  참 오라클, 샘플링 오라클, 휴리스틱 오라클, 일관성 검사 오라클

 - 일관성 검사 오라클 : 애플리케이션 변경이 있을 때, 수행 전과 후의 결괏값이 동일한지 확인

 

* 테스트 시나리오

  테스트 케이스 집합, 절차 명세화한 문서, 대안 흐름과 같은 테스트 항목을 빠짐없이 테스트하기 위함

 

* 테스트 케이스 명세 작성

 - 테스트 케이스 공통 작성 : 테스트 단계 명, 작성자, 승인자, 작성일자,

                                     문서 버전 식별, 대상 시스템 식별, 변경 여부 식별, 테스트 범위 식별, 테스트 조직 식별

 - 개별 테스트 케이스 : 테스트 ID, 테스트 목적, 테스트할 기능, 입력 데이터, 기대 결과, 테스트 환경, 전제 조건

                               성공/실패 기준, 기타 요소