애자일 테스트-스크럼

스크럼 지지자 Whole Team Approach, 모든 팀원이 모든 프로젝트 활동에 참여해야한다는 의미입니다. 스크럼 팀은 프로젝트 결과물에 대한 책임을 가지고 자체 구성합니다. 의사 결정은 팀에 맡겨져 시간 지연없이 적절한시기에 적절한 조치를 취합니다. 이 접근법은 또한 하나의 활동으로 제한하는 대신 팀 재능의 적절한 사용을 장려합니다. 테스터는 또한 테스트에 대한 전문 지식을 제공하는 모든 프로젝트 및 개발 활동에 참여합니다.

전체 팀은 테스트 전략, 테스트 계획, 테스트 사양, 테스트 실행, 테스트 평가 및 테스트 결과보고에 대해 함께 작업합니다.

협업 사용자 스토리 생성

테스터는 사용자 스토리 생성에 참여합니다. 테스터는 시스템의 가능한 동작에 대한 아이디어를 제공합니다. 이를 통해 고객 및 / 또는 최종 사용자가 실제 환경에서 시스템을 이해하고 결과로 실제로 원하는 것이 무엇인지 명확하게 파악할 수 있습니다. 이로 인해 요구 사항이 더 빨리 동결되고 나중에 요구 사항이 변경 될 가능성도 줄어 듭니다.

테스터는 또한 고객이 동의 한 모든 시나리오에 대한 수락 기준을 제시합니다.

테스터는 테스트 가능한 사용자 스토리 생성에 기여합니다.

출시 계획

릴리스 계획은 전체 프로젝트에 대해 수행됩니다. 그러나 스크럼 프레임 워크에는 스프린트를 실행하는 과정에서 더 많은 정보를 얻을 수 있으므로 반복적 인 의사 결정이 포함됩니다. 따라서 프로젝트 시작 부분의 릴리스 계획 세션에서는 전체 프로젝트에 대한 자세한 릴리스 계획을 생성 할 필요가 없습니다. 관련 정보를 사용할 수 있으므로 지속적으로 업데이트 할 수 있습니다.

모든 스프린트 엔드는 릴리스가 필요하지 않습니다. 릴리스는 스프린트 그룹 이후 일 수 있습니다. 릴리스의 주요 기준은 고객에게 비즈니스 가치를 제공하는 것입니다. 팀은 릴리스 계획을 입력으로 사용하여 스프린트 길이를 결정합니다.

릴리스 계획은 릴리스에 대한 테스트 접근 방식 및 테스트 계획의 기초입니다. 테스터는 테스트 노력을 추정하고 릴리스에 대한 테스트를 계획합니다. 릴리스 계획이 변경되면 테스터는 변경 사항을 처리하고 더 큰 릴리스 컨텍스트를 고려하여 적절한 테스트 기반을 확보해야합니다. 테스터는 또한 모든 스프린트가 끝날 때 필요한 테스트 노력을 제공합니다.

스프린트 계획

스프린트 계획은 각 스프린트 시작시 수행됩니다. 스프린트 백로 그는 특정 스프린트에서 구현하기 위해 제품 백 로그에서 가져온 사용자 스토리로 생성됩니다.

테스터는-

  • 스프린트를 위해 선택한 사용자 스토리의 테스트 가능성 결정
  • 수락 테스트 만들기
  • 테스트 수준 정의
  • 테스트 자동화 식별

테스터는 스프린트의 테스트 노력 및 기간에 대한 추정치로 테스트 계획을 업데이트합니다. 이를 통해 타임 박스 스프린트 동안 필요한 테스트에 필요한 시간을 제공하고 테스트 노력의 책임도 보장합니다.

테스트 분석

스프린트가 시작되면 개발자가 설계 및 구현을위한 스토리 분석을 수행함에 따라 테스터는 스프린트 백 로그의 스토리에 대한 테스트 분석을 수행합니다. 테스터는 수동 및 자동 테스트 모두에서 필요한 테스트 케이스를 생성합니다.

테스팅

스크럼 팀의 모든 구성원이 테스트에 참여해야합니다.

  • 개발자는 사용자 스토리에 대한 코드를 개발하면서 단위 테스트를 실행합니다. 단위 테스트는 코드가 작성되기 전에 모든 스프린트에서 생성됩니다. 단위 테스트 사례는 저수준 설계 사양에서 파생됩니다.

  • 테스터는 사용자 스토리의 기능적 및 비 기능적 기능을 수행합니다.

  • 테스터는 스크럼 팀의 다른 구성원에게 테스트 전문 지식을 멘토링하여 전체 팀이 제품 품질에 대한 공동 책임을 갖도록합니다.

  • 스프린트가 끝나면 고객 및 / 또는 최종 사용자가 사용자 수락 테스트를 수행하고 스크럼 팀에 피드백을 제공합니다. 이것은 다음 스프린트에 대한 입력으로 형성됩니다.

  • 테스트 결과가 수집되고 유지됩니다.

자동화 테스트

자동화 테스트는 스크럼 팀에서 매우 중요합니다. 테스터는 자동화 된 테스트 및 결과를 생성, 실행, 모니터링 및 유지하는 데 시간을 할애합니다. 스크럼 프로젝트에서 언제든지 변경이 발생할 수 있으므로 테스터는 변경된 기능 테스트와 관련된 회귀 테스트를 수용해야합니다. 자동화 테스트는 변경과 관련된 테스트 노력의 관리를 용이하게합니다. 모든 수준에서 자동화 된 테스트를 통해 지속적인 통합이 가능합니다. 자동 테스트는 추가 노력없이 수동 테스트보다 훨씬 빠르게 실행됩니다.

수동 테스트는 탐색 적 테스트, 제품 취약성, 결함 예측에 더 중점을 둡니다.

테스트 활동 자동화

테스트 활동을 자동화하면 반복 작업의 부담이 줄어들고 비용이 절감됩니다. 자동화

  • 테스트 데이터 생성
  • 테스트 데이터로드
  • 테스트 환경에 배포 빌드
  • 테스트 환경 관리
  • 데이터 출력 비교

회귀 테스트

스프린트에서 테스터는 해당 스프린트에서 새롭거나 수정 된 코드를 테스트합니다. 그러나 테스터는 또한 이전 스프린트에서 개발 및 테스트 된 코드가 새 코드와 함께 작동하는지 확인해야합니다. 따라서 회귀 테스트는 스크럼에서 중요합니다. 자동화 된 회귀 테스트는 지속적 통합으로 실행됩니다.

구성 관리

자동화 된 빌드 및 테스트 프레임 워크를 사용하는 구성 관리 시스템은 Scrum 프로젝트에서 사용됩니다. 이를 통해 새 코드가 구성 관리 시스템에 체크인 될 때 ​​정적 분석 및 단위 테스트를 반복적으로 실행할 수 있습니다. 또한 새 코드와 시스템의 지속적인 통합을 관리합니다. 자동 회귀 테스트는 지속적 통합 중에 실행됩니다.

수동 테스트 케이스, 자동화 된 테스트, 테스트 데이터, 테스트 계획, 테스트 전략 및 기타 테스트 아티팩트는 버전 제어가 필요하고 관련 액세스 권한이 보장되어야합니다. 이는 구성 관리 시스템에서 테스트 아티팩트를 유지하여 수행 할 수 있습니다.

애자일 테스트 사례

스크럼 팀의 테스터는 다음 Agile Practice를 따를 수 있습니다.

  • Pairing− 두 명의 팀원이 함께 앉아 협업합니다. 두 사람은 두 명의 테스터 또는 한 명의 테스터와 한 명의 개발자가 될 수 있습니다.

  • Incremental Test Design − 스프린트가 점진적으로 진행되고 사용자 스토리가 추가됨에 따라 테스트 케이스가 개발됩니다.

애자일 메트릭

소프트웨어 개발 중에 메트릭 수집 및 분석은 프로세스를 개선하여 생산성, 품질 결과물 및 고객 만족도를 높이는 데 도움이됩니다. 스크럼 기반 개발에서는 이것이 가능하며 테스터는 필요한 메트릭에주의를 기울여야합니다.

스크럼 개발을 위해 몇 가지 메트릭이 제안됩니다. 중요한 지표는 다음과 같습니다.

  • Ratio of Successful Sprints(Number of successful Sprints / Total number of Sprints) * 100. 성공적인 스프린트는 팀이 약속을 이행 할 수있는 것입니다.

  • Velocity− 팀의 속도는 스프린트 동안 팀이 획득 한 스토리 포인트의 양을 기준으로합니다. 스토리 포인트는 추정 중에 계산 된 사용자 스토리의 척도입니다.

  • Focus Factor(Velocity / Team’s Work Capacity) / 100. Focus Factor는 완성 된 스토리를 만드는 팀의 노력의 비율입니다.

  • Estimation Accuracy(Estimated effort / Actual effort) / 100. 추정 정확도는 노력을 정확하게 추정하는 팀의 능력입니다.

  • Sprint Burndown− 남은 작업 (스토리 포인트 또는 시간) 대. 이상적으로 남아 있어야하는 작업 (예상치에 따라).

    • 더 많으면 팀이 할 수있는 것보다 더 많은 작업을 수행했음을 의미합니다.

    • 더 적 으면 팀이 정확하게 추정하지 않았 음을 의미합니다.

  • Defect Count− 스프린트의 결함 수. 결함 수는 백 로그와 비교하여 소프트웨어의 결함 수입니다.

  • Severity of Defects− 결함은 심각도에 따라 경미, 중대 및 중요로 분류 할 수 있습니다. 테스터는 분류를 정의 할 수 있습니다.

스프린트 회고

Sprint Retrospectives에서는 모든 팀원이 참여합니다. 그들은 공유-

  • 잘 된 것
  • Metrics
  • 개선 범위
  • 적용 할 작업 항목