실라버스정리) 소프트웨어 개발 수명주기 모델, 테스트 레벨

2020. 12. 29. 16:23IT관련

728x90
반응형


2.1 소프트웨어 개발 수명주기 모델 

 2.1.1 소프트웨어 개발과 소프트웨어 테스팅 (Software Development and Software Testing)
  테스터의 중요한 역할 중 하나는 필요한 테스트 활동을 수행할 수 있도록 소프트웨어 개발 수명주기 모델을 잘 이해하는 것이다. 

  모든 소프트웨어 개발 수명주기 모델에 적용하기 좋은 테스팅의 특성을 들면 다음과 같다
   - 모든 개발 활동은 그에 상응하는 테스트 활동이 있다. 
   - 각 테스트 레벨은 그 레벨에 맞는 구체적인 목적을 가진다. 
   - 주어진 테스트 레벨에 맞는 테스트 분석과 설계는 개발 활동이 이루어지고 있는 동안 시작해야 한다. 
   - 테스터가 요구사항과 설계의 정의와 개선을 위한 대화에 참여하고, 
     작업 산출물의 초안이 나오는 즉시 리뷰에 참여한다. 

  대표적인 소프트웨어 개발 수명주기 모델
   - 순차적(sequential) 개발 모델 
   - 반복적 점진적(iterative and incremental) 개발 모델

   순차적(sequential) 개발 모델에서는 소프트웨어 개발 프로세스를 1차원적 선형(linear)의 순차적 활동으로 설명한다. 
   즉, 개발 프로세스의 모든 단계는 이전 단계가 완료될 때 시작돼야 한다. 
   각 단계가 서로 중첩하지 않지만, 실제로는 다음 단계에서 빨리 피드백을 받는 것이 유익하다. 
   
   순차적 개발 모델에서는 완성된 기능 세트를 포함한 소프트웨어를 배포할 수 있지만, 일반적으로 이해관계자와 
   사용자에게 배포하기까지 몇 개월 또는 몇 년이 걸린다. 

   폭포수 모델(Waterfall model)에서는 개발 활동이 순차적으로 이루어진다. 
   이 모델에서의 테스트 활동은 모든 개발 활동을 완료한 후에 이루어진다. 

   V-Model은 테스팅을 초기에 시작하면 좋다는 원리를 토대로 테스트 프로세스를 전반적인 개발 프로세스에 통합한다. 
   v-Model은 대응하는 각 개발 단계에 테스트 레벨을 부여함으로써 조기 테스팅을 좀 더 적극적으로 구현하고 있다. 
   이 모델에서는 각 테스트 레벨의 테스트 실행이 순차적으로 이루어지도록 하고 있지만 경우에 따라서는 중첩되기도 한다. 

   점진적 개발에서는 요구사항 정의, 시스템의 설계, 구축, 테스팅을 조각으로 나눠서 진행한다. 
   따라서 소프트웨어 기능은 점진적으로 늘어나게 된다. 
   이런 기능 증분(feature increments)의 크기는 다양하게 설정할 수 있다. 일부 방법론에서는 증분을 크게 설정하며
   다른 방법론에서는 작게 설정하기도 한다.
   기능 증분은 사용자 인터페이스 화면이나 신규 문의 옵션에 생기는 변경 하나만큼 작을 수도 있다.

   반복적 개발은 기능 집합을 종종 고정된 기간의 일련의 주기 안에서 같이 명시, 설계, 구축, 테스트할 때 발생한다. 
   반복주기에는 전체 프로젝트 범위에 대한 변경이나 기존 반복주기 동안 개발한 기능에 대한 수정이 포함될 수 있다. 
   각 반복주기에서는 전체 기능 세트 중 일부의 기능을 하는 소프트웨어를 만들어내고 
   소프트웨어의 기능은 반복주기 횟수가 늘어남에 따라 점차 늘어나게 되고, 완성된 소프트웨어가 
   배포되거나 개발이 중단될 때까지 진행된다. 

   - 래셔널 통합 프로세스(Rational Unified Process) : 각 반복주기가 상당히 긴 경우가 많으며, 따라서 기능 증분도 상당히 큼 
   - 스크럼(Scrum) : 각 반복주기가 짧은 성향을 가지며(몇 시간, 며칠, 몇 주)따라서 기능 증분도 작음.
   - 칸반(Kanban) : 반복주기 기간이 고정된 경우와 고정되지 않은 경우가 있으며,
                    각 반복주기는 완료 후 하나의 개선 사항이나 기능을 전달하거나 몇 개의 기능을 묶어 한번에 전달할 수도 있음. 
   - 나선형(Spiral) : 실험적인 증분을 생성, 일부는 차후 개발 과정에서 상당 부분 수정되거나 심한 경우 폐기되기도 함.

   반복적 점진적 모델은 사용 가능한 소프트웨어를 몇 주, 또는 며칠 만에 전달할 수 있다. 
   다만, 전체 요구사항을 충족하는 제품은 몇 개월 또는 몇 년에 걸쳐 전달하게 된다. 


 2.1.2 정황에 따른 소프트웨어 개발 수명주기 모델 (Software Development Lifecycle Models in Context)
  프로젝트의 목표, 개발 대상 제품 유형, 비즈니스 특성, 식별된 제품 및 프로젝트 리스크 등을 기반으로 
  적합한 소프트웨어 개발 모델을 선택할 필요가 있다. 

  소프트웨어 개발 수명주기 모델도 조합할 수 있다. 
  백엔드 시스템과 그것의 통합에 대한 개발과 테스팅에는 V-Model을 사용하고, 
  프런트엔드 사용자 인터페이스(UI) 기능의 개발과 테스트에는 애자일 개발 모델을 사용할 수 있다. 
  
  프로젝트 초반에는 프로토타이핑(prototyping)을 사용하다 실험적인 단계가 끝나면 점진적 개발 모델을 적용하는 경우도 있다. 

  소프트웨어 개발 모델이 프로젝트 및 제품 특성의 맥락에 맞게 조정되어야 하는 이유 
   - 시스템의 제품 리스크의 차이 (복잡하거나 간단한 프로젝트)
   - 많은 사업부가 프로젝트나 프로그램의 일부일 수 있다. (순차적 및 애자일 개발의 조합)
   - 제품의 짧은 출시 기간 (테스트 레벨에서 테스트 유형의 통합 및 테스트 레벨 병합)



2.2 테스트 레벨 Test Levels


 이 실라버스에서 다루고 있는 테스트 레벨은 다음과 같다:
  - 컴포넌트 테스팅
  - 통합 테스팅 
  - 시스템 테스팅 
  - 인수 테스팅 

  테스트 레벨은 다음과 같은 특성을 기준으로 분류된다.
   - 구체적인 목적
   - 테스트 케이스를 도출하기 위해 참고하는 테스트 베이시스 
   - 테스트 대상 (즉, 테스트 되고 있는 것)
   - 일반적인 결함과 장애
   - 구체적인 접근법과 역할 

  모든 테스트 레벨에는 적절한 테스트 환경이 필요하다. 예를 들어 
  인수 테스팅에는 실제 사용 환경과 유사한 환경이 가장 이상적이지만, 
  컴포넌트 테스팅에서는 개발자가 자신의 개발 환경을 사용하는 경우가 대부분이다. 




 2.2.1 컴포넌트 테스팅(Component Testing)
  컴포넌트 테스팅의 목적(Objectives of component testing)
   - 리스크 완화 
   - 컴포넌트의 기능과 비기능 동작이 설계 및 명세와 일치하는지 여부 판단 
   - 컴포넌트 품질 수준에 대한 자신감 획득 
   - 컴포넌트에 존재하는 결함 발견
   - 다음 단계로의 결함 전이 방지 

  점진적 반복적 개발 모델에서는 코드 변경이 지속해서 변경되고 수정으로 인해 
  기존 컴포넌트가 손상되지 않았다는 확신을 얻는 데 자동 컴포넌트 리그레션 테스트가 중요한 역할을 한다. 

  컴포넌트 테스팅은 소프트웨어 개발 수명주기 모델과 시스템에 따라 개별적으로 이루어지는 경우가 많으며, 
  그럴 경우 목 오브젝트, 서비스 가상화, 하네스, 스텁, 드라이버 등이 필요할 수도 있다. 

  컴포넌트 테스팅은 기능(연산의 정확성), 비기능 특성(메모리 누수 탐지), 구조적 속성(결정 테스팅) 등을 커버할 수 있다. 

  테스트 베이시스로 활용할 수 있는 작업 산출물 : 
   - 상세 설계
   - 코드 
   - 데이터 모델 
   - 컴포넌트 명세 

  테스트 대상 :
   - 컴포넌트, 단위, 모듈
   - 코드 및 데이터 구조
   - 클래스 
   - 데이터베이스 모듈 

   대표적인 결함과 장애 
    - 잘못된 기능 (예: 설계 명세의 설명과 다름)
    - 데이터 흐름 문제 
    - 잘못된 코드 및 논리 

   결함은 발견하는 즉시 수정되며, 공식적인 결함 관리 프로세스 없이 이루어지는 경우가 많다. 
   하지만 개발자가 결함에 대해 보고하는 경우, 근본 원인 분석 및 프로세스 개선에 활용할 수 있는 중요한 정보를 제공하게 된다.

   구체적인 접근법과 책임 (Specific approaches and responsibilities)
    일반적으로 컴포넌트 테스팅은 코드를 작성한 개발자가 수행하지만,
    다른 사람이 수행하더라도 최소한 테스트 대상 코드에 접근할 수 있어야 한다. 
    개발자는 컴포넌트 개발과 결함 발견 및 수정을 번갈아 가며 진행할 수 있다. 
    개발자는 컴포넌트 코드를 작성한 후 테스트를 작성하고 실행하는 경우가 많다. 

    특히 애자일 개발에서는, 애플리케이션 코드보다 자동화된 컴포넌트 테스트 케이스를 먼저 작성하는 경우도 있다. 

    테스트 주도 개발(TDD)을 생각해보자, 테스트 주도 개발은 자동 테스트 케이스를 개발한 후, 
    작은 코드 조각들을 빌드하고 통합해서 컴포넌트 테스트를 실행하고, 발생한 이슈를 수정하고 
    코드를 리팩토링(re-factoring)하는 것으로 구성된 주기를 기반으로 이루어지는 매우 반복적인 프로세스이다. 

    이 프로세스는 전체 컴포넌트가 완성되고 모든 컴포넌트 테스트가 통과할 때까지 계속된다. 
    테스트 주도 개발은 테스트 우선 접근법의 한가지 예이다. 
    테스트 주도 개발은 익스트림 프로그래밍(XP, eXtreme Programming)에서 처음 등장했지만, 
    현재는 다른 애자일 방법론뿐만 아니라 순차적 수명주기 모델에서도 활용하고 있다. 




 2.2.2 통합 테스팅 (Integration Testing)
  통합 테스팅의 목적(Objectives of integration testing)
   - 리스크 완화 
   - 인터페이스의 기능과 비기능 동작이 설계 및 명세와 일치하는지 여부 판단 
   - 인터페이스 품질 수준에 대한 자신감 획득 
   - 결함 발견 (결함은 인터페이스 자체 또는 컴포넌트나 시스템에 존재할 수 있다.)
   - 다음 단계로의 결함 전이 방지

   자동 통합 리그레션 테스트를 수행하여 수정으로 인해 기존 인터페이스, 
   컴포넌트, 시스템 등이 손상되지 않았다는 확신을 얻는 경우가 있다. 

   통합 테스팅 : 
    - 컴포넌트 통합 테스팅은 통합된 컴포넌트 간의 상호운용성과 인터페이스에 초점을 맞춘다. 
      컴포넌트 통합 테스팅은 컴포넌트 테스팅 후 수행하며 자동화하는 경우가 많다. 
      반복적 점진적 개발에서는 컴포넌트 통합 테스트를 지속적 통합 프로세스의 일부로 수행한다. 
    
    - 시스템 통합 테스팅은 시스템, 패키지, 마이크로 서비스 간의 상호 운용성과 인터페이스에 초점을 맞춘다. 
      시스템 통합 테스팅은 또한 기존 컴포넌트(예: 웹 서비스)와의 상호운용 혹은 인터페이스를 커버하기도 한다.
      이 경우 개발 조직이 외부 인터페이스를 제어하지 않으므로 테스팅에 여러 가지 어려움을 겪게 될 수 있다. 
      (예: 테스트의 진행을 막고 있는 외부 조직의 코드에 존재하는 결함의 해결, 테스트 환경 구성, 등).
      시스템 통합 테스팅은 (순차적 개발과 점진적 반복적 개발 모두에서) 시스템 테스팅 후
      또는 진행 중인 시스템 테스팅 활동과 병행해서 수행할 수 있다. 


    테스트 베이시스로 활용할 수 있는 작업 산출물 : 
    - 소프트웨어 및 시스템 설계
    - 시퀀스 다이어그램(sequence diagram)
    - 인터페이스 및 통신 프로토콜 명세 
    - 유스케이스 
    - 컴포넌트나 시스템 레벨의 아키텍쳐
    - 워크플로우(workflow)
    - 외부 인터페이스 정의서 


    테스트 대상 :
    - 서브시스템 (subsystems)
    - 데이터베이스 (database)
    - 인프라 (infrastructure)
    - 인터페이스 (interface)
    - APIs
    - 마이크로서비스 (microservices)


    대표적인 결함과 장애 

      컴포넌트 통합 테스팅의 대표적인 결함 :
       - 잘못된 데이터, 누락된 데이터, 잘못된 데이터 인코딩
       - 잘못된 인터페이스 콜 순서나 타이밍 
       - 인터페이스 불일치
       - 컴포넌트 간의 통신 장애 
       - 컴포넌트 간의 통신 실패처리 누락 및 오류 
       - 컴포넌트 간 주고 받는 데이터의 의미, 단위, 경계에 대한 잘못된 가정

      시스템 통합 테스팅의 대표적인 결함 : 
       - 시스템 간의 일관적이지 않은 메시지 구조 
       - 잘못된 데이터, 누락된 데이터, 잘못된 데이터 인코딩 
       - 인터페이스 불일치 
       - 시스템 간의 통신 장애 
       - 시스템 간의 통신 실패 처리 누락 및 오류 
       - 시스템 간 주고 받는 데이터의 의미, 단위, 경계에 대한 잘못된 가정 
       - 필수 보안 규정 준수 실패 
    
     컴포넌트 통합 테스트와, 시스템 통합 테스트는 통합 자체에 집중해야 한다. 
     예를들어 모듈A, 모듈B 를 통합하는 경우, 
     모듈 간의 커뮤니케이션에 테스트를 집중해야 한다. 
     컴포넌트 테스팅에서 커버했어야 할 개별 모듈의 기능에 초점을 맞춰서는 안된다. 

     시스템X 와 시스템Y를 통합하는 경우, 시스템 간의 커뮤니케이션에 테스트를 집중해야 하며, 
     시스템 테스팅에서 커버했어야 할 개별 시스템의 기능에 초점을 맞춰서는 안 된다.

     기능, 비기능, 구조적 테스트 유형이 적용될 수 있다. 

     컴포넌트 통합 테스팅은 개발자의 책임인 경우가 많다. 
     시스템 통합 테스팅은 일반적으로 테스터의 책임이다.

     이상적인 상황에서는 시스템 통합 테스팅을 수행하는 테스터는 
     시스템 아키텍쳐를 이해하고 통합 계획에 참여했어야 한다. 

     컴포넌트나, 시스템을 빌드하기 전에 통합 테스트와 통합 테스트 전략을 세운 경우, 
     가장 효과적인 테스팅이 가능한 순서대로 컴포넌트나 시스템을 빌드할 수 있다. 
     시스템 통합 전략은 시스템 아키텍쳐(예: 상향식과 하향식), 기능 작업, 트랜잭션 처리 순서,
     시스템 또는 컴포넌트의 기타 측면 등을 기반으로 수립할 수 있다. 
     결함 격리를 좀 더 수월하게 하고 결함을 일찍 발견하기 위해 통합은 한번에 모든 것을 통합하지 않고
     가능한 점진적으로 진행해야 한다. (즉, 한번에 몇 개의 컴포넌트나 시스템만 추가). 
     가장 복잡한 인터페이스에 대한 리스크 분석은 통합 테스팅의 노력을 집중시키는데 도움이 된다.

     통합하는 범위가 넓으면 장애를 특정 컴포넌트나 시스템으로 격리하기 어려워지고, 
     이는 개발의 리스크와 문제해결(Troubleshooting) 시간을 증가시킬 수 있다. 
     이것은 지속적인 통합이 관행으로 자리 잡은 배경 중 하나이다. 
     지속적인 통합에서 소프트웨어는 컴포넌트 단위로 통합(즉, 기능적 통합)된다. 
     이런 지속적인 통합은 이상적으로 여러 테스트 레벨에 자동 리그레션 테스팅을 적용하는 경우가 많다.



   2.2.3 시스템 테스팅(System Testing)
    시스템 테스팅의 목적(Objectives of system testing)
     시스템 테스팅은 전체 시스템 또는 제품의 동작이나 능력에 관심을 가지며, 
     시스템이 수행할 엔드-투-엔드(end-to-end) 작업과 그런 작업을 수행할 때 나타나는 비기능 동작을 고려한다. 
    
    시스템 테스팅의 대표적인 목적 : 
     - 리스크 완화 
     - 시스템의 기능/비기능 동작이 설계 및 명시된 대로 이루어지는지 검증 
     - 완성된 시스템이 기대한 대로 동작하는지 확인
     - 전체 시스템 품질에 대한 자신감 획득
     - 결함 발견 
     - 결함이 상위 테스트 레벨이나 생산 단계로의 전이 방지

    시스템에 따라서 데이터 품질 검증 또한 목적일 수도 있다. 
    컴포넌트 테스팅이나 통합 테스팅과 마찬가지로, 자동 시스템 리그레션 테스트를 통해 어떤 부분의 수정으로 기존 기능이나 
    엔드-투-엔드 기능에 문제가 생기지 않았다는 자신감을 얻을 수 있는 경우가 있다. 

    시스템 테스팅은 이해관계자가 릴리스 결정시 사용하는 정보를 제공하는 경우가 많다.
    시스템 테스팅을 통해 법적, 규정 요구사항이나 표준을 만족시킬 수도 있다. 
    테스트 환경은 최종 사용, 생산 환경과 부합하는 것이 가장 이상적이다.

    테스트 베이시스 (Test Basis)
     - 시스템 및 소프트웨어 요구사항 명세 (기능/비기능)
     - 리스크 분석 보고서 
     - 유스케이스
     - 에픽(epic)과 사용자 스토리
     - 시스템 동작 모델 
     - 상태 다이어그램 
     - 시스템 및 사용자 매뉴얼


    테스트 대상 (Test Objects)
     - 애플리케이션 
     - 하드웨어/소프트웨어 시스템 
     - 운영 시스템 
     - 테스트 대상 시스템(SUT, System Under Test)
     - 시스템 설정과 설정 데이터 

    일반적인 결함과 장애 (Typical defects and failures)
     - 잘못된 연산 
     - 시스템의 잘못되거나 예상치 못한 기능/비기능 동작 
     - 시스템 내 잘못된 제어 및 데이터 흐름
     - 엔드-투-엔드 기능 작업 수행 실패 
     - 시스템 환경에서 시스템의 정상 동작 실패 
     - 시스템 및 사용자 매뉴얼대로의 시스템 동작 실패  

     시스템 테스팅은 기능과 비기능 모두의 측면에서 전반적인 시스템의 엔드-투-엔드 동작에 관심을 가진다. 
     시스템 테스팅은 일반적으로 명세에 과도하게 의존하는 독립적인 테스터가 수행한다. 
     명세 결함(예: 누락된 사용자 스토리, 잘못 기술된 비즈니스 요구사항 등)
     은 기대하는 시스템 동작에 대한 이해 부족이나 의견 불일치를 가져올 수 있다. 
     이런 상황은 시간을 허비하게 만드는 거짓양성이나 결함 발견 효과를 감소시키는 거짓음성의 원인이 될 수 있다. 

     테스터가 사용자 스토리 개선이나 리뷰와 같은 정적 테스팅 활동에
     좀 더 일찍 참여하면 이런 상황을 예방하는 데 도움이 된다.

 



   2.2.4 인수 테스팅(Acceptance Testing)
    인수 테스팅의 목적 (Objectives of Acceptance testing)
     - 전체 시스템의 품질에 대한 자신감 획득 
     - 완성된 시스템이 기대한 대로 동작하는지 확인 
     - 시스템의 기능/비기능 동작이 명세대로 동작 하는지 검증 

     인수 테스팅의 결과로 시스템을 배포하거나 고객(최종 사용자)
     사용할 준비가 어느 정도 됐는지 평가할 수 있는 정보를 만들 수 있다. 

     인수 테스팅에서 상당수의 결함이 발견되면 심각한 프로젝트 리스크로 인식하는 경우도 있다. 
     인수 테스팅으로 법적, 규정 욕사항이나 표준을 만족할 수도 있다. 

     인수 테스팅의 대표적인 형태 : 
      - 사용자 인수 테스팅 
      - 운영 인수 테스팅 
      - 계약 및 규제 인수 테스팅 
      - 알파(alpha) 및 베타(beta) 테스팅 

      사용자 인수 테스팅(UAT, User Acceptance Testing) : 
        실제 또는 시뮬레이션된 운영 환경에서 예정된 사용자가 사용하기에 얼마나 적합한지 확인하는 데 관심을 둔다. 
        가장 중요한 목적은 사용자가 그들의 필요에 따라 요구사항을 충족하면서 최소한의 어려움, 비용, 리스크 등으로 
        비즈니스 프로세스를 수행할 수 있다는 자신감을 획득하는 것이다. 

      운영 인수 테스팅 (OAT, Operational Acceptance Testing) : 
        운영자 또는 시스템 관리 직원에 의해 수행되는 시스템 인수 테스팅은 생산 환경에서 이루어지는 경우가 많다. 
        - 백업 및 복원 테스팅 
        - 설치, 삭제, 업그레이드 
        - 긴급 복구(disaster recovery)
        - 사용자 관리 
        - 유지보수 작업 
        - 데이터 로딩 및 이관(migration)작업 
        - 보안 취약점 확인
        - 성능 테스팅 

        운영 인수 테스팅의 가장 중요한 목적은 운영자 또는 시스템 관리자가 비록 예외적이고 어려운 조건에서라도 
        운영 환경에서 사용자를 위해 시스템을 정상적으로 유지할 수 있다는 자신감을 얻는 것이다.

       계약 및 규제 인수 테스팅(Contractual and regulatory acceptance testing)
        주문 개발 소프트웨어의 생산을 위한 계약서에 명시된 인수 조건을 가지고 수행한다. 
        인수 조건은 모든 계약당사자가 계약에 동의할 때 정의해야 한다. 
        계약 인수 테스팅은 사용자나 독립적인 테스터가 수행하는 경우가 많다. 
        규제 인수 테스팅은 정부, 법적 안전 규제 등과 같이 준수해야 하는 모든 규제를 가지고 수행한다. 
        규제 인수 테스팅은 사용자나 독립적인 테스터가 수행하는 경우가 많으며, 
        규제 기관이 결과에 대한 실사나 감사를 진행 하기도 한다.

       알파 및 베타 테스팅 (Alpha and beta testing)
        소프트웨어 제품을 시장에 출시하기 전에 기존 혹은 신규 사용자, 고객, 운영자 등으로부터 
        피드백을 받기 원하는 상용 소프트웨어 개발자가 사요하는 경우가 많다. 
        알파 테스팅) 개발 조직의 현장에서 개발팀이 아닌 신규 혹은 기존 고객이나 운영자, 독립적 테스트팀이 수행한다. 
        베타 테스팅) 신규 혹은 기존 고객이나 운영자가 자신의 환경에서 수행한다. 
                     베타 테스팅은 알파 테스팅 후에 진행하거나 사전 알파 테스팅 없이 수행할 수도 있다. 
        
        알파 및 베타의 목적 중 하나는 신규 혹은 기존 고객이나 운영자가 시스템을 일반적인 조건과 운영환경에서 
        사용해 자신의 목적을 최소한의 어려움, 비용, 리스크 등으로 완수할 수 있다는 자신감을 획득하는 것이다. 

        시스템을 사용할 조건 및 환경과 관련된 결함의 발견일 수 있다.
        특히, 이런 조건과 환경을 개발팀에서 동일하게 연출하기 어려운 경우 더 그러하다. 

        알파 및 베타 테스팅의 테스트 베이시스로 활용할 수 있는 작업 산출물 : 
         - 비즈니스 프로세스 
         - 사용자 또는 비즈니스 요구사항
         - 규제, 법적 계약, 표준 
         - 유스케이스 및 사용자 스토리 
         - 시스템 요구사항 
         - 시스템 또는 사용자 문서 
         - 설치 절차 
         - 리스크 분석 보고서 

    운영 인수 테스팅의 테스크 케이스를 도출하기 위한 테스트 베이시스로 다음과 같은 산출물 사용 된다. :
        - 백업 및 복원 절차 
        - 긴급 복구 절차
        - 비기능 요구사항
        - 운영 문서 
        - 배포 및 설치 지침 
        - 성능 목표
        - 데이터베이스 패키지
        - 보안 표준 또는 규정 

    일반적인 테스트 대상 (Typical test Objects)
        - 테스트 대상 시스템 
        - 시스템 설정과 설정 데이터 
        - 완전히 통합된 시스템의 비즈니스 프로세스 
        - 복원 시스템이나 비즈니스 연속성 및 긴급 복구 테스팅을 위한 핫 사이트(hot site)
        - 운영 및 유지보수 프로세스 
        - 양식 
        - 보고서 
        - 기존 및 전환된 생산 데이터 
    
    일반적인 결함과 장애(Typical defects and failures)
     - 비즈니스나 사용자 요구사항을 충족하지 못하는 시스템 워크플로우
     - 잘못 구현된 비즈니스 규칙
     - 계약 혹은 규제 요구사항을 충족하지 못하는 시스템 
     - 보안 취약성, 많은 부하가 걸렸을 때 성능 효율성 저하, 
       지원 대상 플랫폼상에서의 잘못된 운영 등과 같은 비기능 장애 
    
    구체적인 접근법과 역할 (Specific approaches and responsibilities)
      인수 테스팅은 주로 고객, 비즈니스 사용자, 제품 소유자, 혹은 시스템 운영자가 담당하며, 
      기타 이해관계자가 참여하는 경우도 있다. 

      - 상용 소프트웨어 제품에 대한 인수 테스팅은 그것이 설치되거나 통합될 때 이루어진다. 
      - 신규 기능 개선 사항에 대한 인수 테스팅은 시스템 테스팅 전에 이루어질 수 있다. 

 

728x90
반응형