실라버스 정리) 테스트 유형 및 유형과 테스트 레벨

2021. 1. 4. 09:07IT관련

728x90
반응형

2.3 테스트 유형

특정 테스트 목적을 위해 소프트웨어 시스템이나, 시스템의 일부 특정 속성을 테스트하는 활동의 집합.

대표적인 목적 :

- 완전성, 정확성, 적합성 등과 같은 기능 품질 특성 평가

- 신뢰성, 성능 효율성, 보안성, 호환성, 사용성 등과 같은 비기능 품질 특성 평가

- 컴포넌트나 시스템의 아키텍처 및 구조가 정확하고 완전하며 명시된 것과 일치하는지 평가

- 수정의 효과 평가. 예를 들어, 결함이 수정됐는지 확인(확인 테스팅)하고

소프트웨어나 환경의 변화로 인해 동작에 의도하지 않은 변화가 없는지(리그레션 테스팅) 평가

2.3.1 기능 테스팅 (Functional Testing)

※ 기능이란 : 시스템이 해야 하는 그 '무엇'을 얘기한다.

※ 기능 커버리지란 : 어떤 기능이 테스트에 의해 어느 정도 실행됐는지를 말하며,

커버되고 있는 요소 유형에 대한 백분율로 표기된다.

기능 테스팅 :

- 시스템이 수행해야 하는 기능을 평가하기 위한 테스트를 포함한다.

기능 요구사항은 비즈니스 요구사항 명세, 에픽(epic), 사용자 스토리, 유스케이스, 기능 명세 등이 있으며,

문서로 기록되지 않는 경우도 존재한다.

- 모든 테스트 레벨에서의 수행

- 소프트웨어 동작을 보기 때문에 컴포넌트나 시스템의 기능에 대한

테스트 컨디션과 테스트 케이스 도출을 위해 블랙박스 기법을 활용할 수 있다.

- 기능 테스팅이 얼마나 철저하게 수행됐는지 기능 커버리지를 통해 측정할 수 있다.

- 기능 테스트 설계 및 실행에는 특수한 역량이나 지식이 필요할 수 있다.

2.3.2 비기능 테스팅 (Non-functional Testing)

※ 비기능 테스팅이란 : 시스템이 '얼마나 잘' 동작하는지에 대한 테스팅을 말한다.

※ 비기능 커버리지란 : 특정 비기능 요소가 테스트로 어느 정도 실행됐는지를 말해주며

커버하고 있는 요소 유형에 대한 백분율로 표기한다.

비기능 테스팅 :

- 사용성, 성능 효율성 또는 보안성과 같은 시스템 특성을 평가한다.

- 모든 테스트 레벨에서 수행할 수 있고, 수행해야 한다.

- 가능한 초반에 수행하는 것이 좋다.

- 비기능 결함을 늦게 발견하게 되면 프로젝트의 성공에 큰 위협이 될 수 있다.

- 블랙박스 기법은 비기능 테스팅을 위한 테스트 컨디션과 테스트 케이스를 도출하는 데 사용할 수 있다.

ex) 성능 테스트를 위한 스트레스(stress) 조건을 정의하는 데 경계값 분석을 활용할 수 있다.

- 비기능 테스팅을 어라마 철저하게 수행했는지는 비기능 커버리지를 사용해서 측정할 수 있다.

- 비기능 테스트 설계 및 실행에는 특수한 역량이나 지식이 필요할 수 있다.

2.3.3 화이트박스 테스팅 (White-box Testing)

※ 코드 버커리지란 : 컴포넌트 코드 중 테스트된 비율

컴포넌트의 실행 가능한 구문 중 테스트된 비율이나 결정 결과값 중 테스트된 비율 등 코드의 여러 가지 측면으로 측정될 수 있다.

※ 구조 커버리지란 : 특정 구조 요소가 테스트에 의해 어느 정도 실행됐는지를 말하며, 커버되고 있는 요소 유형에 대한 백분율로 표기한다.

화이트박스 테스팅 :

- 시스템의 내부 구조나 구현을 기반으로 테스트를 도출한다.

내부 구조 : 코드, 아키텍처, 워크플로우(workflow), 시스템 내 데이터 플로우(data flow)

- 구조 커버리지를 통해 측정할 수 있다.

- 컴포넌트 테스팅 레벨에서 컴포넌트 간의 인터페이스와 같은 시스템의 아키텍처를 기반으로 화이트박스 테스팅을 할 수 있다.

구조 커버리지를 인터페이스 중 테스트된 비율의 측면에서 측정할 수 있다

- 화이트박스 테스트 설계와 구현에는 특수한 역량이나 지식이 필요할 수 있다.

ex) 코드가 구축된 방법, 데이터가 저장되는 방법, 코드 커버리지 도구를 사용하는 방법과 해당 결과를 제대로 분석하기 위한 지식 등.

2.3.4 변경 관련 테스팅 (Chnage-related Testing)

결함을 수정하고자 했든 또는 기능을 추가하거나 개선하기 위해서 했든 시스템이 변경되면,

해당 변경이 결함을 제대로 수정했는지, 기능을 올바르게 구현했는지

또 예상하지 못한 부작용이 발생하지 않았는지 확인하기 위한 테스팅을 수행할 필요가 있다.

확인 테스팅 (Confirmation testing)

- 결함이 수정된 후 이 결함으로 인해 불합격했던 모든 테스트 케이스를

새로운 소프트웨어 버전에서 재실행할 수 있다. 결함 수정에 필요한 변경을 커버하기 위해

소프트웨어를 대상으로 새로운 테스트를 수행할 수도 있다. 결함 수정에 필요한 변경을 커버하기 위해

최소한 결함으로 발생했던 장애의 재현절차를 새로운 소프트웨어 버전에서 실행해 볼 필요가 있다.

확인 테스팅의 목적은 원래 제대로 결함을 제대로 수정했는지 확인하는 것이다.

- 확인 테스팅은 모든 테스트 레벨에서 수행 가능하다.

리그레션 테스팅 (Regression Testing)

- 코드의 특정 부분에 대한 변경이 무언가를 수정하기 위해서거나 또는

다른 목적이든 관계없이 이런 변경은 의도치 않게 코드의 다른 부분에 영향을 줄 수 있다.

여기서 다른 부분이란 같은 컴포넌트의 다른 부분, 같은 시스템의 다른 컴포넌트, 경웨 따라서는 다른 시스템일 수도 있다.

변경에는 운영 시스템이나 데이터베이스 관리 시스템의 신규 버전 등과 같은 환경에 대한 변경도 포함된다.

이런 의도하지 않은 부작용을 리그레션이라 부른다.

리그레션 테스팅은 이런 의도하지 않은 부작용을 발견하기 위한 테스트를 수행하는 것이다.

- 리그레션 테스팅은 모든 테스트 레벨에서 수행 가능하다.

반복적 점진적 개발 수명주기(예: 애자일)에서는 신규 기능, 기존 기능에 대한 변경,

코드 리팩토링(code re-factoring) 때문에 코드에 잦은 변경이 가해지고 결국 변경 관련 테스팅이 필요하게 된다.

시스템이 진화하는 특성 때문에 확인 및 리그레션 테스팅은 매우 중요하다.

리그레션 테스트 스위트는 여러번 반복 수행되며 대개는 서서히 변화하기 때문에 리그레션 테스팅은 자동화에 적합하다.

이런 테스트의 자동화는 프로젝트 초반에 시작해야 한다.

★★★★★★매우 중요★★★★★★★

2.3.5 테스트 유형과 테스트 레벨 (Test Types and Test Levels)

테스트 유형(기능 테스팅, 비기능 테스팅, 화이트박스 테스팅, 변경 관련 테스팅)

모든 테스트 레벨에서 수행할 수 있다.

기능 테스트 :

- 컴포넌트 테스팅에 적용 : 컴포넌트가 복잡한 이자 계산을 어떻게 해야 하는지를 기반으로 테스트 설계

- 컴포넌트 통합 테스팅에 적용 : 사용자 인터페이스에서 포착하는 계정 정보가 어떻게 비즈니스 로직으로 전달되는지를 기반으로 테스트 설계

- 시스템 통합 테스팅에 적용 : 시스템이 외부 마이크로서비스를 사용해서 계좌 소유주의 신용 점수를 확인하는 방법을 기반으로 테스트 설계

- 시스템 테스팅에 적용 : 계좌 소유주가 어떻게 자신의 예금 통장에 신용 한도를 부여할 수 있는지를 기반으로 테스트 설계

- 인수 테스티엥 적용 : 은행이 신용 한도를 승인하거나 거절하는 방법을 기반으로 테스트 설계

비기능 테스트 :

- 컴포넌트 테스팅에 적용 : 복잡한 전체 이자 계산을 수행하기 필요한 CPU 사이클 횟수를 평가하기 위해 성능 테스트 설계

- 컴포넌트 통합 테스팅에 적용 : 사용자 인터페이스에서 비즈니스 로직으로 전달되는 데이터로 인한 버퍼 오버플로우 취약성을 위한 보안 테스트 설계

- 시스템 통합 테스팅에 적용 : 신용 점수 마이크로서비스가 응답하지 않을 때 시스템의 강건성(robustness)을 평가하기 위한 신뢰성 테스트 설계

- 시스템 테스팅에 적용 : 보이는 화면이 모든 지우너 대상 브라우저와 모바일 기기에서 제대로 동작하는지 확인하기 위한 이식성 테스트 설계

- 인수 테스팅에 적용 : 은행 신용 처리 인터페이스에 장애인의 접근성을 평가하는 사용성 테스트 설계

화이트 박스 테스트 :

- 컴포넌트 테스팅에 적용 : 금융 계산을 수행하는 모든 컴포넌트에 대한 완벽한 구문 및 결정 커버리지를 달성하기 위한 테스트 설계

- 컴포넌트 통합 테스팅에 적용 : 브라우저 인터페이스의 각 화면이 다음 화면과 비즈니스 로직을 기반으로

데이터를 어떻게 전달하는지 확인하기 위한 테스트 설계

- 시스템 통합 테스팅에 적용 : 신용 점수 마이크로서비스로 보내는 모든 조회(inqurey) 유형을 실행하기 위한 테스트 설계

- 시스템 테스팅에 적용 : 신용 한도 신청 도중 순차적으로 거치게 되는 웹페이즈를 커버하기 위한 테스트 설계

- 인수 테스팅에 적용 : 은행 간 이체에서 지원하는 모든 금융 데이터 파일 구조와 값 범위를 커버하기 위한 테스트 설계

변경 관련 테스트 :

- 컴포넌트 테스팅에 적용 : 각 컴포넌트를 위한 자동 리그레션 테스트가 구축되고 지속적인 통합 프레임워크에 포함

- 컴포넌트 통합테스팅에 적용 : 인터페이스 관련 결함 수정이 코드 저장소에 체크인 됐을 때 해당 수정을 확인하기 위한 테스트 설계

- 시스템 통합 테스팅에 적용 : 신용 점수 마이크로서비스에 대한 지속적인 개발의 일환으로

해당 마이크로서비스와 상호작용하는 애플리케이션에 대한 테스트를 매일 실행

- 시스템 테스팅에 적용 : 특정 워크플로우에 속하는 화면 중 하나만 변경되더라도 해당 워크플로우에 대한 모든 테스트 실행

- 인수 테스팅에 적용 : 인수 테스팅에서 발견된 결함이 수정되면 기존에 불합격했던 모든 테스트를 재실행

 

728x90
반응형