- 용어 - 

비지니스 프로세스 기반 테스팅 : 테스트케이스를 비지니스 프로세스 상세(설명 내용)와 지식에 기반하여 설계하는 테스팅 접근법.

 

5.1 테스트 조직

 

5.1.1 독립적인 테스팅 - 테스팅 ㄱ업은 특정 테스팅 역할을 부여 받은 사람이나 다른 역할을 하는 사람도 수행할 수 있다.(예 고객) 저자와 테스터가 가지는 인지편향의 차이 대문에 일정 수준의 독립성은 테스터가 결함을 더 효과적으로 찾게 해 준다. 그러나 독립성이 친숙함을 대체할 수 없으며 개발자도 자신이 작성한 코드에서 많은 결함을 효율적으로 찾아낼 수 있다.

 

테스팅의 독립성 수준은 다음과 같다. (낮은 수준에서 높은 수준까지) : 

  • 독립적인 테스터 없음 : 유일하게 개발자가 자신의 코드를 직접 테스트하는 형태
  • 개발팀이나 프로젝트팀에 속한 독립적인 개발자나 테스터 : 개발자가 동료의 제품을 테스트하는 형태도 포함
  • 조직 내 독립적인 테스트티미나 그룹이 프로젝트 관리자나 상위 관리자에게 직접 보고
  • 비지니스 조직 또는 사용자 커뮤니티 소속이거나 사용성, 보안성, 성능, 준수성, 이식성 등 특정 테스트 분야를 전문으로 하는 독립적인 테스터
  • 현장 또는 현장 외에서 일하는 조직 외부의 독립적인 테스터

테스트 독립성의 잠재적 이점

  • 독립적인 테스터는 그들이 가지고 있는 다양한 배경, 기술적인 관점 , 성향이 달라 개발자와는 다른 유형의 장애를 찾아낼수 있다.
  • 독립적인 테스터는 이해관계자가 시스템 명세를 정의하고 구현하면서 만든 가정에 대해 확인하고 이의를 제기하고 틀렸음을 입증할 수 있다.
  • 벤더의 독립 테스터는 테스트할 시스템을 고용한 회사의 (정치적) 압박 없이 똑바로 그리고 객관적으로 보고할 수 있다.

테스트 독립성의 잠재적 단점

  • 개발팀과의 고립으로 협업이 어려울 수 있고, 개발팀에게 피드백 전달이 늦어지고, 개발팀과 적대적인 관계가 형성 될 수 있다. 
  • 개발자가 품질에 대한 책임감을 잃을 수 있다.
  • 독립적인 테스터가 병목 현상의 장본인으로 비쳐질 수 있다.
  • 독립적인 테스터는 중요한정보( 테스트 대상에 대한 정보)를 전달받지 못할 수 있다.

**5.1.2 테스트 관리자 및 테스터의 역할 ** (샘플 A - Q 30)

 

테스터 관리자의 역할 - 테스트 관리자의 업무는 테스트 프로세스에 대한 전반적인 책임과 테스트 활동을 성공적으로 이끄는 것이다. 테스트 관리자는 전문 테스트 관리자, 프로젝트 관리자, 개발 관리자, 품질 보증 관리자 역할을 맡을 수 있다.

  • 조직의 테스트 정책과 테스트 전략을 개발하고 리뷰
  • 정황을 고려한 테스트 활동과 테스트 목적과 리스크 이해를 바탕으로 테스트 활동을 계획, 예를들어 테스트 접근법 선택, 테스트 추정( 테스트 시간, 노력, 비용), 리소스 획득, 테스트 레벨과 테스트 주기정의, 결함 관리 등이 계획에 포함될 수 있다.
  • 테스트 계획서 작성과 업데이트 
  • 프로젝트 관리자, 제품 오너, 기타 관계자와 테스트 계획 관련 협의
  • 통합 계획 등과 같은 다른 프로젝트 활동과 테스팅 관점 공유
  • 테스트 분석, 설계, 구현, 실행 활동을 개시하고, 테스트 진행과 결과를 모니터링하며 종료 조건(또는 종료 조건 정의) 의 상태를 점검하고 테스트 완료 활동을 촉진
  • 수집한 정보를 바탕으로 테스트 진행 상황 보고서나 이미 완료된 다른 테스트 프로젝트의 테스트
  • 테스트 결과와 진행상황에 따라 계획을 조정하고 테스트 제어에 필요한 모든 조치를 취함
  • 결함 관리 시스템과 테스트웨어에 적합한 형상 관리 체제 구축 지원
  • 테스트 진척 상황 측정과 테스팅 및 제품 품질 평가를 위한 적절한 메트릭 도입
  • 테스트 프로세스 지원용 도구 선택과 구현 지원. 예를 들자면 도구 선택 예산(경우에 따라 구입하거나 지원 비용까지) 에 대한 권고,  파일럿 프로젝트에 시간과 노력 할당, 도구 사용에 대한 지속적인 지원 제공 등
  • 테스트 환경 구축에 관한 결정
  • 조직에 테스터, 테스트팀, 테스트 활동을 홍보하고 지지를 요청
  • 테스터의 역량과 경력 개발

테스터의 역할과 업무

  • 테스트 계획을 리뷰하고 계획 작성에 참여
  • 요구사항, 사용자 스토리와 인수조건, 명세, 모델(즉, 테스트 베이시스)의 테스트 용이성을 분석, 리뷰, 평가
  • 테스트 컨디션을 식별 및 기록하고, 테스트 케이스, 테스트 컨디션, 테스트 베이시스 간의 추적성 설정
  • 테스트 환경을 설계, 구축, 검증하고 필요한 경우 시스템 관리자, 네트워크 관리자와 협업
  • 테스트 케이스와 테스트 프로시저를 설계 및 구현
  • 테스트 데이터를 준비하고 획득
  • 상세 테스트 실행 일정 수립
  • 테스트를 실행하고 결과를 평과해, 기대 결과와 차이 기록
  • 테스트 프로세스에 적합한 도구 사용
  • 필요한 경우 테스트 자동화
  • 수행 효율성, 신뢰성, 사용성, 보안성, 호환성, 이식성과 같은 비기능 품질 특성 평가
  • 테스트 산출물 리뷰

5.2 테스트 계획과 추정

 

5.2.1 테스트 계획의 목적과 내용 -테스트 계획 활동은 제품의 수명주기 전반에 걸쳐 이루어지는 지속적인 활동.

  • 테스팅의 범위 정의, 목적, 리스크 결정
  • 전반적인 테스팅 접근법 정의
  • 테스트 활동을 소프트웨어 수명주기 활동에 통합하고 조정
  • 테스트 대상 다양한 테스트 활동에 필요한 인력과 기타 자원, 테스트 활동 수행 방법 결정
  • 테스트 분석, 설계, 구현, 실행, 평가 활동의 일정 조정. 일정은 특정 날짜나 반복주기로 편성할 수 있다.
  • 테스트 모니터링과 제어에 사용할 메트릭 선정
  • 테스트 활동 예산 결정
  • 테스트 문서의 구조와 상세화 정도 정의

5.2.2 테스트 전략과 테스트 접근법 - 테스트 전략은 테스트 프로세스의 일반적 모습을 반영한다.

  • 분석적 : 특정요소에 대한 분석을 기반으로 한 테스트 전략. 리스크 수준에 따라 테스트를 설계하고 우선순위를 결정하는 리스크 기반 테스팅이 분석적 접근법의 예.
  • 모델 기반 : 이러한 유형의 테스트 전략에서 테스트는 요구되는 제품의 특정 측면에 대한 모델을 기반으로 만들어 짐. 특정 측면에는 기능, 비지니스 프로세스, 내부 구조, 비기능 특성 등이 있다. 모델에는 비지니스 프로세스 모델, 상태 모델, 신뢰성 성장 모델 등이 있다.
  • 방법론적 : 이 테스트 전략은 사전에 정의한 테스트 셋이나 테스트 컨디션을 체계적으로 사용하는데 의존한다
  • 프로세스 준수 또는 표준 준수 : 이 테스트 전략은 외부 규정이나 표준을 기반으로 테스트를  분석, 설계, 구현.
  • 전문가 조언 또는 자문 : 이 테스트 전략은 주로 이해관계자, 비지니스 도메인 전문가, 기술 전문가 등의 조언, 지도 지시를 바탕으로 이루어진다. 이 사람들은 외부 테스트팀이나 외부 조직 소속일 수 있다.
  • 리그레션-기피 : 기존 기능에 대한 리그레션 테스트를 기피를 목표로 한다. 이 테스트 전략에는 기존 테스트웨어( 특히 테스트 케이스와 테스트 데이터)의 재사용, 리그레션 테스트 자동화 확대, 테스트 스위트 표준화가 포함된다.
  • 반응적 : 지금까지 소개한 사전 계획에 따라 실행하는 테스트 전략과는 달리 테스트 대상 컴포넌트나 시스템에 따라 대응하고 테스트 실행 중 발생하는 이벤트에 따라반응적으로 수행하는 테스트 접근법. 이전 테스트 결과에서 얻은 지식을 바탕으로 테스트를 설계하고 구현하며 즉각 테스트를 실행할 수 있다. 

5.2.3 시작 조건과 종료 조건( 준비의 정의와 완료의 정의 -애자일에서) - 활동의 시작 시점과 완료 시점에 대한 조건을 정의해 놓는 것이 좋다. 

 

시작 조건 

  • 테스트 가능한 요구사항, 사용자 스토리나 모델의 가용 여부
  • 이전 테스트 레벨의 종료 조건을 충족한 테스트 항목의 가용 여부
  • 테스트 환경 가용 여부
  • 필요한 테스트 도구 가용 여부
  • 테스트 데이터와 기타 필요한 자원의 가용 여부

종료 조건

  • 계획한 테스트 실행 완료
  • 정의한 커버리지 수준( 예 : 요구사항, 사용자 스토리, 인수 조건, 리스크, 코드 등의 커버리지)의 도달
  • 해결하지 못한 결함 수가 합의된 수보다 적음
  • 추정 잔존 결함의 수가 충분히 적음
  • 신뢰성, 수행 효율성 사용성, 보안성, 기타 관련된 품질 특성의 수준이 원하는 수준에 도달

5.2.4 테스트 실행 일정

테스트 케이스와 테스트 프로시저를 작성하고 (일부 프로시저는 가능하다면 자동화) 테스트 프로시저와 테스트 케이스를 조합해 테스트 스위트를 생성한 후 테스트 스위트의 순서를 정해 실행 일정을 만들 수 있다. 테스트 실행 일정에서 테스트 스위트를 어떤 순서로 실행할지 정의한다. 테스트 실행 일정을 만들 때는 우선순위, 종속관계, 확인 테스트, 리스레션 테스트, 가장 효율적인 테스트 실행 순서 등을 고려해야 한다.

테스트 케이스가 서로 종속 관계를 가지고 있다면 각자의 우선순위와 상관없이 필요에 따라 배치해야 한다.

상황에 따라테스트를 다양한 순서로 배치할 수 있으며 각 순서 배치에 따라 효율성 수준이 다를 수 있다. 이런 경우 테스트 실행 효율성과 우선순위 준수 간의 절충을 고려한 결정이 필요하다. (테스트 관리자 역할)

 

5.2.5 테스트 노력에 영향을 미치는 요소 - 테스트 노력 추정은 테스트 관련 작업에 필요한 노력의 양을 예측하는 활동으로 이는 특정 프로젝트, 릴리스, 반복주기에서 테스팅의 목적을 충족하는 데 필요하다.

 

  • 제품 특성
  • 제품과 관련된 리스크
  • 테스트 베이시스의 품질
  • 제품의 크기
  • 제품 도메인의 복잡도
  • 품질 특성 요구사항
  • 요구되는 테스트 문서의 상세화 정도
  • 법적, 규제 준수 요구사항

 

개발 프로세스 특성

  • 조직의 안정성과 성숙도
  • 사용하는 개발 모델
  • 테스트 접근법
  • 사용하는 도구
  • 테스트 프로세스
  • 시간적 압박

인력 특성

  • 관련된 인원의 역량과 경험, 특히 유사한 프로젝트나 제품 관련( 도메인 지식)
  • 팀 응집력과 리더십

테스트 결과

  • 발견한 결함 수와 심각도
  • 필요한 재작업 규모

5.2.6 테스트 추정 기법

- 충분한 테스팅을 하는 데 필요한 노력을 추정하는 예측 기법 몇 가지가 있다.

  • 메트릭 기반 기법 : 기존 유사한 프로젝트에서 얻은 메트릭에 기반하거나 보편적인 값을 바탕으로 테스트 노력 예측
  • 전문가 기반 기법 : 테스팅 작업의 책임자나 전문가의 경험을 기반으로 테스트 노력 예측

5.3 테스트 모니터링과 제어

- 테스트 모니터링의 목적은 정보 수집 및 테스트 활동에 대한 피드백과 가시성 제공. 모니터링 대상 정보는 수동 혹은 자동으로 수집할 수 있고, 테스트 진행 상황을 평가하는 데 활용한다. 그리고 테스트 종료 조건을 만족하는지 또는 애자일 프로젝트에서 완료의 정의와 관련된 테스팅 작업을 만족하는지 측정하는 데 이용.

테스트 제어는 수집하고 보고된 정보와 메트릭의 결과로 취해진 수정 조치나 가이드를 의미한다 수정조치는 어떤 테스트 활동을 커버하거나 소프트웨어 수명주기 활동에 영향을 미칠수 있다.

 

테스팅 제어 활동의 예

  • 식별한 리스크 발생 시 테스크 우선순위의 변경
  • 테스트 환경이나 기타 자원의 가용 여부에 따라 테스트 일정 변경
  • 재작업으로 인해 테스트 항목이 시작 조건이나 종료 조건 만족하는지 재평가

5.3.1 테스팅에 사용하는 메트릭

테스팅 활동 중이나 종료 시점에 아래와 같은 사항을 평가하기 위해 메트릭을 수집할 수 있다.

  • 계획한 일정과 예산 대비 진행 상황
  • 테스트 대상의 현재 품질
  • 테스트 접근법의 타당성
  • 목적 대비 테스트 활동의 효과

일반적인 테스트 메트릭

  • 계획 대비 테스트 케이스 준비 작업 완료율 ( 또는 계획 대비 테스트 케이스 작성률)
  • 계획 대비 테스트 환경 준비 작업 완료율
  • 테스트 케이스 실행률(예- 수행한/수행하지 않은 테스트 케이스 수 , 테스트 케이스 합격/불합격 수, 테스트 컨디션 합격/ 불합격 수)
  • 결함 정보
  • 요구사항 커버리지, 사용자 스토리 커버리지, 인수 기준 커버리지, 리스크 커버리지, 코드 커버리지
  • 작업 완료 , 자원 할당과 사용, 노력
  • 다음 결함을 발견하면 얻는 이익 대비 비용이나 테스트를 계속 실행해 얻게 되는 이익 대비 비용 등을 포함하는 테스팅 비용

5.3.2 테스트 보고의 목적, 내용 , 독자 

테스트 보고의 목적은 테스트 활동 중이나 마무리 시점의 테스트 활동 정보 요약과 공유이다. 테스트 활동 중 작성하는 테스트 보고서는 테스트 진행 상황 보고사, 테스트 활동 종료 시점에 작성하는 테스트 보고서는 테스트 요약 보고서라고 부르기도 한다.

상황 보고서에 들어가는 정보는 아래와 같다

  • 테스트 계획 대비 테스트 활동과 진행 상황
  • 진행을 방해하는 요소
  • 다음 보고 기간에 진행하기로 계획한 테스팅
  • 테스트 대상의 품질

종료 조건을 만족하면 테스트 관리자는 테스트 요약 보고서를 작성한다.

일반적인 테스트 요약 보고서는 다음과 같은 내용을 포함.

  • 테스팅 수행 내용 요약
  • 테스트 기간 도중에 발생한 상황 정보
  • 계획 대비 편차
  • 종료 조건 및 완료의 정의에 대한 테스팅 현황과 제품 품질
  • 진행을 방해했거나 계속해서 방해하고 있는 요소
  • 메트릭
  • 잔존 리스크
  • 재사용 가능한 테스트 작업 산출물

5.4 형상 관리

- 형상 관리의 목적은 프로젝트와 제품 수명주기 동안 컴포넌트나 시스템, 테스트웨어와 이들 서로간의 관계 통합을 수립하고 유지하는 데 있다. 형상 관리는 테스팅을 적절히 지원하고 아래 내용을 확인한다.

  • 모든 테스트 항목에 고유 식별번호를 부여하고, 버전을 관리하고, 변경 이력을 기록한다. 형상 관리에서 테스트 항목은 서로 연관돼 있다.
  • 모든 테스트웨어 항목에 고유 식별번호를 부여하고, 버전을 관리하고 , 변경사항을 추적하고, 서로 연결해 테스트 항목 버전과도 연결되도록 해서 테스트 프로세스 전반에 걸쳐 추적성을 유지할 수 있게 한다.
  • 식별한 모든 문서와 소프트웨어 아이템은 테스트 문서 내에서 명확하게 상호 참조되도록 한다.

테스트 계획을 수립하면서 형상관리 절차와 인프라(도구)를 식별하고 구현해야 한다.

 

5.5 리스크와 테스팅 

5.5.1 리스크의 정의

리스크란 미래에 부정적 결과를 가져오는 이벤트의 발생 가능성이다. 리스크 수준은 이벤트 발생 가능성가 이벤트로 인한 영향도(피해)로 결정한다.

 

5.5.2 제품 및 프로젝트 리스크

제품 리스크는 작업 산출물이 사용자나 이해관계자의 합당한 니즈를 충족하지 못할 가능성이다. 제품리스크가 제품의 특정 품질 특성( 예 : 기능 안전성, 신뢰성, 성능 효율성, 사용성, 보안성,호환성, 유지보수성, 이식성)과 연관되는 경우 품질 리스크라고 한다. 

제품리스크의 예

  • 소프트웨어가 명세에서 의도한 기능을 수행하지 못함
  • 소프트웨어가 사용자, 고객이나 이해관계자가 요구하는 기능을 수행하지 못함
  • 시스템 아키텍처가 일부 비기능 요구사항을 충분히 지원하지 못함
  • 특정 계산식이 특정 상황에서 올바르게 수행되지 못함
  • 루프 제어 구조 코딩이 잘못됨
  • 고성능 거래 처리 시스템의 응답 시간이 적절하지 않
  • 사용자 경험 피드백이 제품 기대치에 미치지 못함

프로젝트 리스크는 발생하면 프로젝트 목적 달성 능력에 부정적인 영향을 줄 수 있는 상황이다.

  • 프로젝트 이슈 :
    • 배포, 작업 완료, 종료조건이나 완료의 정의를 만족하지 못하고 지연된다.
    • 부정확한 추정, 우선순위가 높은 프로젝트에 예산 재배정, 또는 조직 전반에 걸친 예산 삭감으로 예산이 부족할 수 있다.
    • 프로젝트 후반에 발생하는 변경은 상당한 재작업을 불러올 수 있다.
  • 조직 이슈 : 
    • 역량 교육 인력이 부족할수 있다.
    • 개인적인 문제로 갈등이나 문제가 생길수 있다.
    • 사용자, 비지니스 인력, 해당 분야 전문가들이 비즈니스 우선순위 마찰로 참여하지 못할 수 있다.
  • 정치적 이슈
    • 테스터가 필요한 사항이나 테스트 결과를 제대로 전달하지 못할 수 있다.
    • 개발자나 테스터가 테스팅과 리뷰도중 발견한 사항에 대한 후속 조치를 못할 수 있다.
    • 테스팅에 대한 잘못된 태도나 기대가 있을 수 있다
  • 기술적 이슈
    • 요구사항이 충분히 잘 정의되지 않을 수 있다.
    • 기존 제약 사항으로 요구사항을 만족하지 못할 수 있다.
    • 테스트 환경이 필요한 시점에 준비되지 않을 수 있다.
    • 데이터 변환, 마이그레이션 계획 및 도구 지원이 필요한 시점에 제공되지 않을 수 있다.
    • 개발 프로세스의 약점은 프로젝트 작업 산출물의 품질이나 일관성에 영향을 줄 수 있다.
    • 결함 관리가 부실하고 기타 유사한 문제 때문에 축적된 결함이나 기타 기술적 부채를 가져올 수 있다.
  • 공급자 이슈
    • 외부 공급자가 필요한 제품이나 서비스를 공급하지 못하거나 파산할 수있다.
    • 계약 관련 이슈로 프로젝트에 문제가 생길 수 있다.

5.5.3 리스크 기반 테스팅과 제품 품질 

리스크는 테스팅 노력을 집중하는 데 사용된다.  리스크 기반 접근법은 제품 리스크 수준을 조기에 낮추는데 기여한다. 리스크 기반 테스팅은 제품 리스크식별과 리스크 발생 가능성과 영향을 평가하는 제품 리스크 분석을 포함한다.

 

리스크 기반 접근법에서 제품 리스크 분석 결과

  • 사용할 테스트 기법 결정
  • 수행할 테스트 레벨과 유형 확정
  • 테스트 수행 범위 결정
  • 가능한 조기에 심각한 결함을 발견하기 위해 테스트 우선순위 결정
  • 기존 테스팅 활동 외 리스크 완화를 위한 다른 활동의 식별

리스크 관리 활동 - 리스크 기반 테스팅은 프로젝트 이해관계자의 집단 지식과 통찰력을 기반으로 제품 리스크를 분석한다. 제품 장애 발생 가능성을 최소하하기 위해 리스크 관리 활동은 다음과 같은 절차를 따르게 된다.

  • 잘못될 수 있는 것을 분석
  • 처리해야 할 중요한 리스크가 무엇인지 판단
  • 해당 리스크를 완화하기 위한 행동 구현
  • 리스크의 실제 발생을 대비한 대책 수립

5.6 결함 관리 

 - 테스팅의 목적 중 하나가 결함을 찾는 것이기 때문에 테스팅 중 발견한 결함은 반드시 기록해야 한다. 결함을 기록하는 방법은 테스트 대상 컴포넌트나 시스템의 정황, 테스트 레벨, 소프트웨어 개발 수명주기 모델에 따라 달라진다. 찾아낸 모든 결함은 조사하고, 발견에서 결함 분류까지 추적해야 한다. 모든 결함응ㄹ 해결까지 관리하기 위해 조직은 결함 관리 프로세스( 워크플로우와 결함 분류 규칙)를 수립해야 한다. 아키텍처, 설계자, 개발자, 테스터, 제폼오너 등 결함 관리에 참여하는 모든 사람이 프로세스에 동의해야 한다. 일부 조직에서는 결함 로깅과 추적이 매우 비공식적일 수 있다.

효율적이고 효과적인 결함 관리 프로세스를 위해 조직은 결함의 속성, 분류, 워크플로우에 대한 표준을 정의해 놓을 수 있다.

 

일반적인 결함 보고서의 목적

  • 발생한 모든 부정적인 이벤트 정보를 개발자와 기타 관계자에게 제공해 구체적인 영향을 식별하고, 재현 테스트로 문제를 격리하고, 잠재 결함을 수정하고, 필요에 따라서 문제를 해결할 다른 방법을 찾을 수 있도록 한다.
  • 테스트 관리자에게 작업 산출물의 품질과 테스팅 영향을 추적할 방법을 제공한다.
  • 개발과 테스트 프로세스 개선에 대한 아이디어를 제공한다.

동적 테스팅에서 작성하는 결함 보고서의 내용

  • 식별 번호
  • 제목, 보고하는 결함에 대한 짧은 요약
  • 결함 보고 날짜, 보고 주체 조직 및 작성자
  • 테스트 항목 식별자와 환경
  • 결함을 발견한 개발 수명주기 단계
  • 로그 데이터베이스덤프 , 스크린샷, 녹화기록등의 결함 재현과 해결을 위한 설명
  • 기대 및 실제 결과
  • 이해관계자의 관점에서의 결함 영향도의 범위와 정도
  • 수정 우선수위
  • 결함보고서의 상태
  • 결혼, 의경 승인 여부
  • 글로벌 이슈
  • 변경이력
  • 참조

'자격증 > ISTQB' 카테고리의 다른 글

정리 1  (0) 2020.06.22
[Part 6] 테스트 지원 도구  (0) 2020.06.14
[part 3] 정적 테스팅  (0) 2020.06.11
[Part 2] 소프트웨어 수명주기와 테스팅  (0) 2020.06.08
[Part 1] 소프트웨어 테스팅의 기초  (0) 2020.06.07

4.1 테스트 기법의 종류

 

테스트 기법의 선택은 다음과 같은 여러 요소를 기반으로 이루어짐.

  • 컴포넌트나 시스템의 복잡도
  • 규제 기준
  • 고객 또는 계약 요구사항
  • 리스크 수준과 유형
  • 사용 가능한 문서
  • 테스터의 지식과 역량
  • 사용 가능한 도구
  • 시간과 예산
  • 소프트웨어 개발 수명 주기 모델
  • 컴포넌트나 시스테에서 에상되는 결함 유형

4.1.1 테스트 기법의 종류와 특성

 

이 실라버스에서는 테스트 기법을 블랙박스, 화이트박스, 경험 기반으로 분류.

 

블랙박스 테스트 기법 특징 -테스트 대상의 내부 구조를 고려하지 않고, 입력과 출력에 집중

  • 테스트 컨디션, 테스트 케이스, 테스트 데이터는 소프트웨어 요구사항, 명세서, 유스케이스, 사용자 스토리와 같은 테스트 베이시스로 부터 도출.
  • 테스트 케이스는 요구사항과 요구사항 구현 결과물 간 차이와 편차를 식별하는 데 사용
  • 커버리지는 테스트 베이시스에서 테스트된 항목과 테스트 베이시스에 적용한 기법을 기반으로 측정.

화이트박스 테스트 기법 특징 - 테스트 대상의 내부 구조와 처리에 집중

  • 테스트 컨디션, 테스트 케이스, 테스트 데이터는 코드, 소프트웨어 아키텍처, 상세 설계 또는 소프트웨어 구조와 관련된 기타 정보를 포함한 테스트 베이시스로부터 도출.
  • 커버리지는 선택한 구조 ( 코드나 인터페이스) 내에서 테스트한 항목과 테스트 베이시스에 적용된 기법을 기준으로 측정

경험 기반 테스트 기법 특징 - 개발자, 테스터, 사용자의 경험을 활용하여 테스트를 설계, 구현, 실행. 이 기법은 화이트박스 및 블랙박스 테스트 기법과 결합해서 사용하는 경우가 많음.

  • 테스트 컨디션, 테스트 케이스, 테스트 데이터는 테스터, 개발자, 사용자, 기타 이해관계자의 지식과 경험과 같은 테스트 베이시스로부터 도출.

4.2 블랙박스 테스트 기법 - 동등분할 , 경계값 분석, 결정 테이블 테스팅, 상태 전이 테스팅, 유스케이스 테스팅

 

4.2.1 동등분할 - 특정 파티션의 모든 변수는 동일한 방식으로 처리된다는 가정으로 파티션( 동등 클래스)에 데이터를 분할. 유효한 값과 비유효한 값 모두에 대해 동등 분할 구성.

  • 유호값이란 컴포넌트나 시스템에 입력되는 값. 유효한 값을 포함하는 동등한 파티션을 "유효 동등 분할"이라고 함
  • 비유효값이란 컴포넌트나 시스템이 거부하는 값. 유효하지 않은 값을 포함하는 동등한 파티션을 "비유효 동등 분할"이라고 함.
  • 분할은 입력값, 출력값, 내부값, 시간관련, 인터페이스 매개변수를 포함하여 테스트 대상과 관련된 모든 데이터 요소에 대해 식별.
  • 필요한 경우 모든 파티션은 하위 파티션으로 나눌 수 있음.
  • 모든 값은 동등 분할에 포함되어야 하며, 하나의 값은 하나의 동등 분할에만 속해야 함.
  • 비유효 동등 분할을 테스트 케이스로 만들 때는 장애가 마스크 즉, 가려지는 것을 방지하기 위해 개발적으로 테스트해야 하며, 다른 비유효 동등 분할과 조합하지 않아야 함.

4.2.2 경계값 분석 - 동등 분할의 확장 형태이지만 각 파티션이 순서화되어 있고, 숫자 또는 연속 데이터로 구성된 경우에만 적용. 분할의 최소값과 최대값은 해당 분할의 경계값이 됨.

예제) 유효 범위는 1이상 5이하 일때 3개의 동등 분할이 존재. 비유효(너무 낮음), 유효; 비유효(너무 높음) 유효 동등 분할의 경계값은 1과 5. 비유효(너무 높음) 분할의 경값은 6이다. 비유효(너무 낮음)은 0이 경계값이 된다. 이 예제에서는 각 경계에 대해 두개값을 식별했다. 비유효(너무낮음)과 유효는 0 ,1 이고 유효와 비유효(너무높음)에는 5,6을 선택 . 이 기법의 여러 유형 중에는 경계당 세 개의 경계값을 식별하는 것도 있다. 경계직전값, 경계 해당값, 경계직후의 값 0 1 2 , 4 5 6 이 됨.

 

4.2.3 결정 테이블 테스팅 - 시스템이 구현해야 하는 복잡한 비즈니스 규칙을 기록하기에 좋은 방법. 결정 테이블을 작성할 때 테스터는 시스템의 조건(주로 입력)과 예상 동작(주로 출력) 을 식별. 이것들은 테이블의 행을 형성하며 일반적으로 조건은 위쪽에, 기대 결과는 아래쪽에 둔다. 각 열은 하나의 결정규칙으로 특정 조건의 고유한 조합과 연관된 기대 결과로 정의. 조건과 기대 결과의 값은 일반적으로 참 또는 거짓으로 표기 하거나, 빨간색 녹색 파란색등과 같은 비연속 값을 표기하지만 숫자나 숫자 범위로 표현하는 경우도 있음.

 

일반적인 표기법

조건 : 

  • Y, 조건이 참이라는 것을 의미 ( T또는 1로 표기할 수 있음)
  • N, 조건이 거짓이라는 것을 의미(F 또는 0으로 표기)
  • ㅡ, 조건의 값이 중요하지 않다는 것을 의미(N/A 표기가능)

기대 결과 : 

  • X, 행동이 일어난다는 것을 의미(Y,T,1로 표기 가능)
  • 공백 행동이 일어나지 않음을 표기(ㅡ, N, F, 0으로 "")

4.2.4 상태 전이 테스팅 - 컴포넌트나 시스템은 현재 조건이나 기존 이력( 예를 들어, 시스템이 초기화되고 난 후 발생한 이벤트) 에 따라 이벤트에 대해 다르게 반응할 수 있다. 기존 이력은 상태라는 개념을 활용해서 요약 가능. 상태 전이다이어그램은 소프트웨어의 가능한 상태뿐만 아니라 소프트웨어가 상태 간에 어떻게 진입하고 빠져나오는지에 대한 전이 방법을 보여줌. 전이는 이벤트에 의해 시작(예를 들어, 사용자가 입력 필드에 값을 입력), 이 이벤트는 전이라는 결과를 가져옴. 하나의 이벤트에 의해 동일한 상태로부터 두 개 이상의 다른 전이가 발생할 수 있다. 상태 변화로 소프트웨어가 특정 행동을 할 수도 있다.(예 연산결과 오류 메시지 출력). 상태전이 테이블은 상태 간의 모든 유효 전이와 잠재적인 비유효 전이뿐만 아니라, 유효 전이와 관련된 이벤트, 결과 조치를 보여줌. 상태 전이 다이어그램은 일반적으로 유효한 전이만 보여주며, 비유효 전이는 표시하지 않는다.

테스트는 상태의 일반적인 순서를 커버하거나, 모든 상태를 실행하거나 모든 상태 전이를 실행하거나 특정한 상태 전이 순서를 실행하거나 또는 불가능한 상태 전이를 테스트하도록 설계 할 수 있다.

 

4.2.5 유스케이스 테스팅 - 유스케이스에서 테스트를 도출할 수 있으며, 이것은 소프트웨어 항목 간의 상호작용을 설계하는 특정 방법. 유스케이스는 소프트웨어 기능에 대한 요구사항을 통합한다. 유스케이스는 엑터( 즉 사용자, 외부 하드웨어, 기타 컴포넌트나 시스템)와 대상(유스케이스를 적용하는 컴포넌트나 시스템)간의 관계

 

각 유스케이스는 대상이 하나 이상의 엑터와 협력하여 수행할 수 있는 동작들을 명시하고 있다.유스케이스를 상호작용과 활동으로 설명하기도 하고, 적절한 경우 사전조건, 사후조건 및 자연어로 설명할 수도 있다. 엑터와 대상 간의 상호작용으로 대상의 상태가 변경될 수 있다. 상호작용은 워크플로우, 활동다이어그램, 비지니스 프로세스 모델로 시각화 할 수 있다. 유스케이스에는 예외 동작 및 오류 처리를 포함한 기본동작의 가능한 변형이 포함. 

 

4.3 화이트박스 테스트 기법  - 구문 테스팅과 커버리지, 결정 테스팅과 커버리지

 

4.3.1 구문 테스팅과 커버리지 - 잠재적으로 실행 가능한 구문을 실행한다. 테스트로 실행한 구문의 수를 테스트 대상의 모든 실행 가능한 구문의 수로 나눠서 계산

 

4.3.2 결정 테스팅과 커버리지 - 코드에 존재하는 결정문을 실행하고 결정문의 결과에 따라 실행하는 코드를 테스트함. 이것을 달성하기 위해 테스트 케이스는 결정문에서 시작되는 제어 흐름을 따라 실행된다.(예를 들어 , IF문에서 결과가 참인 경우와 거짓인 경우 ; CASE 문에서 기본 결과를 포함한 가능한 모든 결과를 필요로 하는 테스트 케이스).

결정문 결과의 수를 테스트 대상의 가능한 모든 결정문 결과의 수로 나눠서 계산.

 

4.3.3 구문 및 결정 테스팅의 가치 - 구문 커버리지는 다른 테스트에 의해 실행되지 않은 코드의 결함을 찾는데 도움이 된다. 결정 커버리지는 다른 테스트가 참과 거짓 결과 모두를 테스트하지 않은 코드의 결함을 찾는데 도움이 된다. 100% 결정 커버리지는 100%구문 커버리지를 보장하지만 반대의 경우는 성립하지 않는다.

 

4.4 경험 기반 테스트 기법 - 경험 기반 테스느 기법을 적용할 경우 테스트 케이스는 테스터의 기술 역량과 직관 그리고 유사한 에플리케이션과 기술에 대한 경험을 기반으로 도출. 

 

4.4.1 오류 추정

오류 추정은 다음을 포함한 테스트 지식을 기반으로 오류, 결함 및 장애 발생을 예측하는 데 적용하는 기술

  • 애플리케이션의 과거 동작
  • 발생하기 쉬운 오류의 유형
  • 다른 애플리케이션에서 발생한 장애

4.4.2 탐색적 테스팅 - 탐색적 테스팅에서는 비공석(사전에 정의되지 않은) 테스트를 테스트 실행 중에 동적으로 설계, 실행, 기록하고 평가. 테스트 결과는 컴포넌트나 시스템에 대해 더 많이 학습하고, 더 많은 테스트가 필요한 영역에 대한 테스트를 작성하는 데 활용. 탐색적 테스팅은 때로 세션기반 테스팅을 사용하여 활동을 구성. 정해진 시간동안 수행하며, 테스터는 테스트 목적이 포함된 테스트 차터를 활용해 테스트 방향을 설정.테스터는 테스트 세션 시트에 수행 단계와 발견 사항 기록.

탐색적 테스팅은 명세가 충분하지 않거나 적은 경우 또는 테스팅에 상당한 시간적 압박이 있을 때 가장 유용. 또한, 탐색적 테스팅은 다른 보다 공식적인 테스팅 기법을 보완하는 데도 유용.

4.4.3 체크리스트 기반 테스팅 - 체크리스트에 기록된 테스트 컨디션을 커버하기 위해 테스터가 테스트를 설계, 구현, 실행한다. 테스터는 분석의 일환으로 새로운 체크리스트를 작성하거나 기존 체크리스트를 확장할 수 있지만, 기존 체크리스트를 수정하지 않고 그대로 사용하는 경우도 있다. 체크리스트는 경험, 사용자에게 무엇이 중요한지에 대한 지식 또는 소프트웨어가 실패하는 이유와 방법에 대한 이해를 기반으로 작성할 수 있다. 체크리스트는 기능 및 비기능 테스팅을 포함한 다양한 테스트 유형을 지원하기 위해 작성할 수 있다. 구체적인 테스트 케이스가 없는 경우, 체크리스트 기반 테스팅은 대략적인 지침과 일관성을 제공할 수 있다. 이런 체크리스트는 상위 수준으로 작성되기 때문에 실제 테스팅에서 어느 정도의 가변성이 있기 마련이며, 따라서 커버리지는 늘어날 수 있지만 재현 가능성은 줄어들 수 있다.

+ Recent posts