애자일 테스트-퀵 가이드
Agile반복적 인 개발 방법론으로 개발 및 테스트 활동이 동시에 수행됩니다. 테스트는 별도의 단계가 아닙니다. 코딩 및 테스트는 대화식으로 점진적으로 수행되므로 최종 제품의 품질이 향상되어 고객 요구 사항을 충족합니다. 또한 지속적인 통합을 통해 결함을 조기에 제거 할 수 있으므로 시간, 노력 및 비용이 절약됩니다.
애자일 선언
Agile Manifesto는 2001 년 소프트웨어 개발자 팀에 의해 발표되었으며, 변화하는 요구 사항과 고객 참여를 수용하는 개발 팀의 중요성을 강조했습니다.
The Agile Manifesto is −
우리는 소프트웨어를 개발하고 다른 사람들이 그렇게하도록 도와줌으로써 더 나은 소프트웨어 개발 방법을 찾고 있습니다. 이 작업을 통해 우리는 가치를 얻었습니다.
- 프로세스 및 도구에 대한 개인 및 상호 작용.
- 포괄적 인 문서에 대한 작업 소프트웨어.
- 계약 협상을 통한 고객 협력.
- 계획에 따라 전환에 응답합니다.
즉, 오른쪽 항목에는 가치가 있지만 왼쪽 항목에는 더 가치가 있습니다.
애자일 테스트 란 무엇입니까?
애자일 테스팅은 애자일 소프트웨어 개발 원칙을 따르는 소프트웨어 테스트 방식입니다.
애자일 테스트에는 테스터가 제공하는 특별한 전문 지식을 갖춘 프로젝트 팀의 모든 구성원이 참여합니다. 테스트는 별도의 단계가 아니며 요구 사항, 디자인 및 코딩, 테스트 케이스 생성과 같은 모든 개발 단계와 통합됩니다. 테스트는 개발 수명주기 동안 동시에 진행됩니다.
또한 테스터가 부서 간 팀 구성원과 함께 전체 개발 라이프 사이클에 참여하면 더 나은 디자인과 코드로 고객 요구 사항에 따라 소프트웨어를 구축하는 데 테스터의 기여가 가능해질 것입니다.
애자일 테스트는 모든 수준의 테스트와 모든 유형의 테스트를 다룹니다.
애자일 테스트 대. 폭포 테스트
폭포 개발 방법론에서 개발 수명주기 활동은 순차적 인 단계에서 발생합니다. 따라서 테스트는 별도의 단계이며 개발 단계가 완료된 후에 만 시작됩니다.
다음은 Agile Testing과 Waterfall Testing의 차이점에 대한 하이라이트입니다.
애자일 테스트 | 폭포 테스트 |
---|---|
테스트는 별도의 단계가 아니며 개발과 동시에 발생합니다. | 테스트는 별도의 단계입니다. 모든 레벨과 유형의 테스트는 개발 완료 후에 만 시작할 수 있습니다. |
테스터와 개발자가 함께 작업합니다. | 테스터는 개발자와 별도로 작업합니다. |
테스터는 요구 사항을 제시하는 데 관여합니다. 이는 실제 시나리오의 동작에 대한 요구 사항 매핑 및 수용 기준 구성에 도움이됩니다. 또한 요구 사항과 함께 논리적 수용 테스트 케이스가 준비됩니다. | 테스터는 요구 사항 단계에 참여할 수 없습니다. |
수락 테스트는 모든 반복 후 수행되며 고객 피드백을 구합니다. | 수락 테스트는 프로젝트가 끝날 때만 수행됩니다. |
모든 반복은 자체 테스트를 완료하므로 새로운 기능이나 로직이 출시 될 때마다 회귀 테스트를 구현할 수 있습니다. | 회귀 테스트는 개발 완료 후에 만 구현할 수 있습니다. |
코딩과 테스트 사이에 시간 지연이 없습니다. | 코딩과 테스트 사이의 일반적인 시간 지연. |
겹치는 테스트 수준으로 연속 테스트. | 테스트는 시간 제한 활동이며 테스트 수준은 겹칠 수 없습니다. |
테스트는 모범 사례입니다. | 테스트는 종종 간과됩니다. |
애자일 테스트 원칙
애자일 테스트의 원칙은 다음과 같습니다.
Testing moves the project forward− 지속적인 테스트는 지속적인 진행을 보장하는 유일한 방법입니다. Agile Testing은 지속적으로 피드백을 제공하며 최종 제품은 비즈니스 요구를 충족합니다.
Testing is not a phase− 애자일 팀은 개발 팀과 함께 테스트하여 주어진 반복 동안 구현 된 기능이 실제로 수행되는지 확인합니다. 테스트는 이후 단계를 위해 보관되지 않습니다.
Everyone tests− 애자일 테스트에서는 분석가, 개발자 및 테스터를 포함한 전체 팀이 애플리케이션을 테스트합니다. 모든 반복 후에 고객도 사용자 수락 테스트를 수행합니다.
Shortening Feedback Loops− Agile Testing에서 비즈니스 팀은 매 반복마다 제품 개발을 파악합니다. 그들은 모든 반복에 관여합니다. 지속적인 피드백은 피드백 응답 시간을 단축하므로이를 수정하는 데 드는 비용이 적습니다.
Keep the Code Clean− 동일한 반복 내에서 발생하는 결함이 수정됩니다. 이것은 개발의 모든 마일스톤에서 깨끗한 코드를 보장합니다.
Lightweight Documentation − 포괄적 인 테스트 문서 대신 애자일 테스터 −
재사용 가능한 체크리스트를 사용하여 테스트를 제안하십시오.
부수적 인 세부 사항보다는 테스트의 본질에 집중하십시오.
간단한 문서 스타일 / 도구를 사용합니다.
탐색 적 테스트를 위해 헌장에 테스트 아이디어를 캡처합니다.
여러 목적으로 문서를 활용합니다.
Leveraging one test artifact for manual and automated tests− 동일한 테스트 스크립트 아티팩트를 수동 테스트 및 자동화 테스트를위한 입력으로 활용할 수 있습니다. 이렇게하면 수동 테스트 문서와 동등한 자동화 테스트 스크립트가 필요하지 않습니다.
“Done Done,” not just done − Agile에서 기능은 개발 후가 아니라 개발 및 테스트 후에 수행된다고합니다.
Test-Last vs. Test Driven− 테스트 케이스는 요구 사항과 함께 작성됩니다. 따라서 테스트를 통해 개발을 주도 할 수 있습니다. 이 접근 방식을 TDD (Test Driven Development) 및 ATDD (Acceptance Test Driven Development)라고합니다. 이것은 Waterfall Testing의 마지막 단계 인 테스트와는 대조적입니다.
애자일 테스트 활동
프로젝트 수준의 애자일 테스트 활동은 다음과 같습니다.
릴리스 계획 (테스트 계획)
모든 반복에 대해
반복 중 애자일 테스트 활동
회귀 테스트
릴리스 활동 (테스트 관련)
반복 중 애자일 테스트 활동에는 다음이 포함됩니다.
- 반복 계획에 참여
- 테스트 관점에서 작업 추정
- 기능 설명을 사용하여 테스트 케이스 작성
- 단위 테스트
- 통합 테스트
- 기능 테스트
- 결함 수정
- 통합 테스트
- 수락 테스트
- 테스트 진행 상황보고
- 결함 추적
Agile은 전체 프로젝트 팀이 모든 활동에 참여하는 반복적 인 개발 방법론입니다. 요구 사항은 고객과 자체 구성 팀 간의 협업을 통해 반복이 진행됨에 따라 진화합니다. 코딩 및 테스트가 대화식으로 점진적으로 수행되므로 개발 과정에서 최종 제품의 품질이 향상되고 고객 요구 사항이 보장됩니다.
모든 반복은 통합 된 작업 제품 증분을 가져오고 사용자 승인 테스트를 위해 제공됩니다. 이렇게 얻은 고객 피드백은 다음 / 후속 반복에 대한 입력이됩니다.
지속적인 통합, 지속적인 품질
지속적인 통합은 애자일 개발 성공의 핵심입니다. 필요한 경우 릴리스를 준비 할 수 있도록 최소한 매일 자주 통합하십시오. 애자일 테스트는 제품의 지속적인 품질을 보장하는 모든 개발 단계의 필수 구성 요소가됩니다. 프로젝트에 참여한 모든 사람의 지속적인 피드백은 제품의 품질을 향상시킵니다.
Agile에서는 커뮤니케이션이 가장 중요하며 고객 요청은 필요할 때 수신됩니다. 이를 통해 모든 입력이 고려되고 개발 과정에서 작업 품질의 제품을 사용할 수 있다는 만족감을 고객에게 제공합니다.
애자일 방법론
애자일 개발을 지원하는 여러 애자일 방법론이 있습니다. 애자일 방법론에는 다음이 포함됩니다.
스크럼
스크럼은 팀 중심 접근 방식을 강조하는 애자일 개발 방법입니다. 모든 프로젝트 개발 활동에 전체 팀의 참여를 옹호합니다.
XP
eXtreme Programming은 고객 중심이며 끊임없이 변화하는 요구 사항에 중점을 둡니다. 잦은 릴리스와 고객 피드백을 통해 최종 제품은 프로세스 중에 더 명확해진 고객 요구 사항을 충족하는 품질이 될 것입니다.
결정
Crystal은 전세, 주기적 배송 및 마무리를 기반으로합니다.
차 터링에는 개발 팀 구성, 예비 타당성 분석 수행, 초기 계획 및 개발 방법론에 도달하는 것이 포함됩니다.
두 개 이상의 배송주기가있는 순환 배송은 개발 단계와 최종 통합 제품 배송에 중점을 둡니다.
Wrap up 중에 사용자 환경에 배포, 배포 후 검토 및 반영이 수행됩니다.
FDD
FDD (Feature Driven Development)에는 기능 설계 및 구축이 포함됩니다. FDD와 다른 애자일 개발 방법론의 차이점은 기능이 특정 단계와 짧은 단계에서 별도로 개발된다는 것입니다.
DSDM
DSDM (동적 소프트웨어 개발 방법)은 RAD (Rapid Application Development)를 기반으로하며 Agile Framework에 맞춰 조정됩니다. DSDM은 사용자를 적극적으로 참여시키고 팀이 신속한 결정을 내릴 수 있도록 제품을 자주 제공하는 데 중점을 둡니다.
린 소프트웨어 개발
린 소프트웨어 개발에서는 낭비를 제거하고 고객에게 가치를 제공하는 데 중점을 둡니다. 그 결과 신속한 개발과 가치 제품이 탄생합니다.
낭비에는 부분적으로 완료된 작업, 관련없는 작업, 고객이 사용하지 않는 기능, 배송 지연을 추가하는 결함 등이 포함됩니다.
그만큼 Lean Principles -
- 낭비 제거
- 학습 확대
- 지연 약속
- 팀 역량 강화
- 빠른 전달
- 무결성 구축
- 전체보기
칸반
Kanban은 팀원에게 부담을주지 않으면 서 JIT (Just-In-Time) 제공에 중점을두고 작업 관리에 중점을 둡니다. 모든 참가자가 볼 수 있고 팀 구성원이 대기열에서 작업을 가져올 수있는 작업이 표시됩니다.
Kanban은-
- Kanban 보드 (개발 전반에 걸쳐 시각적 및 영구적)
- 진행중인 작업 (WIP) 제한
- 리드 타임
애자일 테스트 방법론
테스트 관행은 애자일 여부에 관계없이 모든 프로젝트에 대해 잘 정의되어 고품질 제품을 제공합니다. 전통적인 테스트 원칙은 애자일 테스트에서 자주 사용됩니다. 그중 하나는에 초점을 맞춘 초기 테스트입니다.
시스템의 동작을 표현하기위한 테스트 케이스 작성.
조기 결함 예방, 감지 및 제거.
적절한 테스트 유형이 적시에 적절한 테스트 수준의 일부로 실행되도록합니다.
우리가 논의한 모든 애자일 방법론에서 애자일 테스트 그 자체가 방법론입니다. 모든 접근 방식에서 테스트 케이스는 코딩 전에 작성됩니다.
이 튜토리얼에서는 Agile 테스트 방법론으로서 Scrum에 초점을 맞출 것입니다.
일반적으로 사용되는 다른 애자일 테스트 방법은 다음과 같습니다.
Test-Driven Development (TDD) − TDD (Test-Driven Development)는 테스트 지침에 따라 코딩을 기반으로합니다.
Acceptance Test-Driven Development (ATDD) − ATDD (Acceptance Test-Driven Development)는 고객, 개발자 및 테스터 간의 의사 소통을 기반으로하며 사전 정의 된 수락 기준 및 수락 테스트 사례에 따라 진행됩니다.
Behavior-Driven Development (BDD) − BDD (In Behavior-Driven Development) 테스트는 개발중인 소프트웨어의 예상되는 동작을 기반으로합니다.
애자일 테스트 라이프 사이클
스크럼에서 테스트 활동에는 다음이 포함됩니다.
테스트 케이스로 표시된 시스템의 예상 동작을 기반으로 사용자 스토리에 기여
테스트 노력 및 결함을 기반으로 한 릴리스 계획
사용자 스토리 및 결함을 기반으로 한 스프린트 계획
지속적인 테스트를 통한 스프린트 실행
스프린트 완료 후 회귀 테스트
테스트 결과보고
자동화 테스트
테스트는 아래 다이어그램에 표시된대로 반복적이고 스프린트 기반입니다.
Agile Development는 팀 중심이며 개발자와 테스터는 모든 프로젝트 및 개발 활동에 참여합니다. 팀워크는 Agile 프로젝트에서 테스트의 성공을 극대화합니다.
애자일 팀의 테스터는 모든 프로젝트 활동에 참여하고 기여해야하며 동시에 테스트의 전문 지식을 활용해야합니다.
애자일 테스터는 전통적인 테스트 기술을 가지고 있어야합니다. 또한 애자일 테스터는-
좋은 대인 관계 기술.
팀 구성원 및 이해 관계자와 함께 긍정적이고 솔루션 지향적으로 행동 할 수있는 능력.
제품에 대해 비판적이고 품질 지향적이며 회의적인 생각을 표시하는 능력.
이해 관계자로부터 정보를 적극적으로 습득 할 수있는 적극적인 태도
테스트 가능한 사용자 스토리, 수락 기준을 정의 할 때 고객 및 이해 관계자와 효과적으로 협력하는 기술.
양질의 코드를 생산하는 개발자와 함께 일하는 훌륭한 팀원이되는 재능.
스프린트 기간 내에 적절한 테스트 케이스를 적시에 적절한 수준으로 확보하고이를 잘 실행하기위한 테스트 기술의 유용성.
테스트 결과, 테스트 진행 상황 및 제품 품질을 평가하고보고하는 기능.
테스트 케이스 변경, 추가 또는 개선을 포함하여 변경에 신속하게 대응할 수있는 개방성.
작업을 스스로 구성 할 수있는 잠재력.
지속적인 기술 성장에 대한 열정.
테스트 자동화, 테스트 주도 개발 (TDD), 수용 테스트 주도 개발 (ATDD), 행동 주도 개발 (BDD) 및 경험 기반 테스트의 역량.
애자일 팀에서 테스터의 역할
애자일 팀의 테스터는 모든 프로젝트 및 개발 활동에 참여하여 최고의 테스트 전문성을 제공합니다.
애자일 테스터 활동에는 다음이 포함됩니다.
테스트 도구의 적절한 사용 보장.
테스트 환경 및 테스트 데이터 구성, 사용 및 관리.
테스트의 관련 측면에서 다른 팀원을 멘토링합니다.
릴리스 및 스프린트 계획 중에 적절한 테스트 작업이 예약되었는지 확인합니다.
테스트 전략 이해, 구현 및 업데이트.
테스트 가능성, 일관성 및 완전성 측면에서 요구 사항을 명확히하기 위해 개발자, 고객 및 이해 관계자와 협력합니다.
적시에 적절한 테스트 수준에서 적절한 테스트를 수행합니다.
결함을보고하고이를 해결하기 위해 팀과 협력합니다.
적용 가능한 모든 커버리지 차원에서 테스트 커버리지를 측정하고보고합니다.
스프린트 회고에 참여하여 사전에 개선을 제안하고 구현합니다.
애자일 라이프 사이클에서 테스터는 다음에서 중요한 역할을합니다.
- Teamwork
- 테스트 계획
- 스프린트 제로
- Integration
- 애자일 테스트 관행
팀워크
애자일 개발에서 팀워크는 기본이므로 다음이 필요합니다.
Collaborative Approach− 테스트 전략, 테스트 계획, 테스트 사양, 테스트 실행, 테스트 평가 및 테스트 결과보고에 대해 교차 기능 팀 구성원과 협력합니다. 다른 팀 활동과 함께 테스트 전문 지식을 제공합니다.
Self-organizing − 다른 팀원의 전문 지식을 통합하여 테스트 목표를 달성하기 위해 스프린트 내에서 잘 계획하고 조직합니다.
Empowerment − 팀의 목표를 달성하기 위해 적절한 기술적 결정을 내립니다.
Commitment − 고객과 이해 관계자가 요구하는대로 제품의 동작과 특성을 이해하고 평가하기 위해 노력합니다.
Transparent − 개방, 의사 소통 및 책임감.
Credibility− 테스트 전략, 구현 및 실행의 신뢰성 보장. 고객과 이해 관계자들에게 테스트 전략에 대한 정보를 제공합니다.
Open to Feedback− 스프린트 회고에 참여하여 성공과 실패를 모두 배웁니다. 고객 피드백을 찾고 품질 결과물을 보장하기 위해 신속하고 적절하게 행동합니다.
Resilient − 변경에 대한 대응.
테스트 계획
테스트 계획은 릴리스 계획 중에 시작하고 각 스프린트 중에 업데이트해야합니다. 테스트 계획은 다음 작업을 포함해야합니다.
테스트 범위, 테스트 범위, 테스트 및 스프린트 목표를 정의합니다.
테스트 환경, 테스트 도구, 테스트 데이터 및 구성을 결정합니다.
기능 및 특성 테스트 할당.
테스트 작업 예약 및 테스트 빈도 정의.
테스트 방법, 기술, 도구 및 테스트 데이터 식별.
선행 작업, 전문 지식 및 교육과 같은 전제 조건을 확인합니다.
기능, 코드, 시스템 구성 요소, 공급 업체, 기술, 도구, 활동, 작업, 팀, 테스트 유형, 테스트 수준 및 제약 조건과 같은 종속성을 식별합니다.
고객 / 사용자 중요성 및 종속성을 고려하여 우선 순위를 설정합니다.
테스트에 필요한 시간과 노력에 도착합니다.
각 스프린트 계획에서 작업 식별.
스프린트 제로
Sprint Zero는 첫 번째 스프린트 전에 준비 활동을 포함합니다. 테스터는 다음 활동에 대해 팀과 협력해야합니다.
- 범위 식별
- 사용자 스토리를 스프린트로 나누기
- 시스템 아키텍처 만들기
- 도구 (테스트 도구 포함) 계획, 획득 및 설치
- 모든 테스트 수준에 대한 초기 테스트 전략 만들기
- 테스트 메트릭 정의
- 승인 기준 지정 ( "완료"정의라고도 함)
- 종료 기준 정의
- 스크럼 보드 만들기
- 스프린트 전체에서 테스트 방향 설정
완성
Agile에서는 개발 수명주기의 어느 시점에서든 품질이 우수한 제품을 출시 할 준비가되어 있어야합니다. 이것은 개발의 일부로서 지속적인 통합을 의미합니다. 애자일 테스터는 지속적인 테스트와의 지속적인 통합을 지원해야합니다.
이를 수행하기 위해 테스터는 다음을 수행해야합니다.
- 통합 전략을 이해합니다.
- 기능과 기능 간의 모든 종속성을 식별합니다.
애자일 테스트 관행
애자일 테스터는 애자일 프로젝트에서 테스트하기 위해 애자일 관행을 조정해야합니다.
Pairing− 두 팀원이 같은 키보드에서 함께 작업합니다. 그들 중 하나가 테스트 할 때 다른 하나는 테스트를 검토 / 분석합니다. 두 팀원은
테스터 1 명과 개발자 1 명
테스터 1 명과 비즈니스 분석가 1 명
두 명의 테스터
Incremental Test Design − 테스트 케이스는 간단한 테스트로 시작하여 더 복잡한 테스트로 이동하는 사용자 스토리에서 구축됩니다.
Mind Mapping− 마인드 맵은 정보를 시각적으로 정리하기위한 다이어그램입니다. 마인드 매핑은 필요한 테스트 세션, 테스트 전략 및 테스트 데이터와 관련된 정보를 사용하여 Agile 테스트에서 효과적인 도구로 사용할 수 있습니다.
테스트 상태를 전달할 수 있습니다-
- 매일 스탠드 업 회의 중
- 표준 테스트 관리 도구 사용
- 메신저를 통해
테스트 통과 상태에 따라 결정되는 테스트 상태는 작업이 "완료"인지 여부를 결정하는 데 중요합니다. 완료는 작업 통과에 대한 모든 테스트를 의미합니다.
테스트 진행
테스트 진행 상황은 다음을 사용하여 추적 할 수 있습니다.
- 스크럼 보드 (애자일 작업 보드)
- 번 다운 차트
- 자동화 된 테스트 결과
테스트 진행은 또한 개발 진행에 직접적인 영향을 미칩니다. 사용자 스토리를 이동할 수 있기 때문입니다.Done합격 기준에 도달 한 후에 만 상태. 이는 합격 기준이 테스트 상태에 의해 판단되므로 테스트 상태에 의해 결정됩니다.
테스트 진행이 지연되거나 막히는 경우 전체 팀이 논의하고 공동으로 작업하여 동일한 문제를 해결합니다.
애자일 프로젝트에서는 변경이 자주 발생합니다. 많은 변경이 발생하면 테스트 상태, 테스트 진행률 및 제품 품질이 지속적으로 발전 할 것으로 예상 할 수 있습니다. 애자일 테스터는 적절한 시간에 적절한 결정을 내릴 수 있도록 해당 정보를 팀에 전달하여 각 반복을 성공적으로 완료 할 수 있도록해야합니다.
변경이 발생하면 이전 반복의 기존 기능에 영향을 미칠 수 있습니다. 이러한 경우 회귀 위험을 효과적으로 처리하려면 수동 및 자동 테스트를 업데이트해야합니다. 회귀 테스트도 필요합니다.
제품의 품질
제품 품질 메트릭에는 다음이 포함됩니다.
- 테스트 통과 / 실패
- 결함 발견 / 수정
- 테스트 범위
- 테스트 통과 / 실패율
- 결함 발견 비율
- 결함 밀도
제품 품질 메트릭의 수집 및보고를 자동화하면 다음과 같은 이점이 있습니다.
- 투명성 유지.
- 적시에 필요한 모든 관련 지표 수집.
- 통신 지연없이 즉시보고합니다.
- 테스터가 테스트에 집중할 수 있습니다.
- 메트릭 오용 필터링.
전반적인 제품 품질을 확보하기 위해 Agile 팀은 제품이 고객 기대치를 충족하는지 여부에 대한 고객 피드백을 받아야합니다. 이 작업은 각 반복이 끝날 때 수행되어야하며 피드백은 후속 반복에 대한 입력이됩니다.
주요 성공 요인
애자일 프로젝트에서 애자일 테스트가 성공하면 양질의 제품을 제공 할 수 있습니다.
애자일 테스트의 성공을 위해 다음 사항을 고려해야합니다.
애자일 테스트는 테스트 우선 및 연속 테스트 접근 방식을 기반으로합니다. 따라서 테스트-마지막 접근 방식을 기반으로 구축 된 기존 테스트 도구는 적합하지 않을 수 있습니다. 따라서 Agile 프로젝트에서 테스트 도구를 선택하는 동안 Agile 테스트에 대한 조정을 확인해야합니다.
개발 수명주기 초기에 테스트를 자동화하여 총 테스트 시간을 줄입니다.
애자일 테스터는 개발 릴리스 일정에 맞춰 속도를 유지해야합니다. 따라서 테스트 활동의 적절한 계획, 추적 및 재 계획은 제품 품질을 목표로하여 즉시 수행되어야합니다.
수동 테스트는 프로젝트 테스트의 80 %를 차지합니다. 따라서 전문성을 갖춘 테스터는 Agile 팀의 일원이되어야합니다.
개발 라이프 사이클 전반에 걸쳐 전문성을 갖춘 이러한 테스터의 참여는 전체 팀이 고객 기대치를 충족하는 고품질 제품에 집중하게합니다.
최종 사용자가 기대하는 제품 동작을 강조하는 사용자 스토리 정의.
고객의 기대에 따라 사용자 스토리 수준 / 작업 수준에서 수락 기준 식별.
테스트 활동에 대한 노력 및 기간 추정.
테스트 활동 계획.
개발 팀과 협력하여 선행 테스트 설계를 통해 요구 사항을 충족하는 코드 생산을 보장합니다.
첫 번째 및 지속적인 테스트를 테스트하여 완료 상태가 예상 시간에 허용 기준을 충족하는지 확인합니다.
스프린트 내의 모든 수준에서 테스트를 보장합니다.
각 스프린트 종료시 회귀 테스트.
프로젝트 성공에 유용한 제품 메트릭을 수집하고 분석합니다.
현재 스프린트에서 수정해야 할 부분과 후속 스프린트로 지연 될 수있는 부분을 식별하기 위해 결함을 분석합니다.
고객의 관점에서 중요한 것에 집중합니다.
Lisa Crispin은 애자일 테스트 성공을위한 7 가지 핵심 요소를 정의했습니다.
Whole Team approach− 이러한 접근 방식에서 개발자는 테스터를 교육하고 테스터는 다른 팀 구성원을 교육합니다. 이는 모든 사람이 프로젝트의 모든 작업을 이해하는 데 도움이되므로 공동 작업과 기여가 최대한의 이점을 얻을 수 있습니다. 테스터와 고객의 협업은 또한 처음부터 기대치를 설정하고 허용 기준을 테스트를 통과하는 데 필요한 것으로 변환하는 데 중요한 요소입니다.
Agile Testing Mindset − The testers are proactive in continually improving the quality and collaborating constantly with the rest of the team.
Automate Regression Testing − Design for testability and drive development with tests. Start simple and allow the team to choose the tools. Be ready to provide advice.
Provide and Obtain Feedback − As this is a core Agile value, the entire team should be open for feedback. As the testers are expert feedback providers, need to focus on relevant and necessary information. In return, on obtaining feedback should accommodate test case changes and testing.
Build a Foundation of Core Agile Practices − Focus on testing alongside coding, continuous integration, collaborative test environments, working incrementally, acceptance for changes, maintaining synergy.
Collaborate with Customers − Elicit examples, understanding, and checking the requirements mapping to the product behavior, setting up Acceptance Criteria, obtaining feedback.
Look at the Big Picture − Drive development with business-facing tests and examples using real world test data and thinking about impacts on other areas.
In this chapter, we will see some significant attributes of Agile Testing.
Agile Testing Benefits
The benefits of Agile testing are −
Customer satisfaction by quick, continuous completely tested product and seeking customer feedback.
Customers, developers, and testers continuously interact with one another, thereby reducing the cycle time.
Agile testers participate in defining requirements contributing their testing expertise to focus on what is workable.
Agile testers participate in estimation assessing testing effort and time.
Early test design reflecting Acceptance Criteria.
Testing requirements consolidated by the whole team, avoiding drawbacks.
Constant focus on quality of the product by the entire team.
Definition of Done status reflecting tests pass ensures that the requirement is met.
Continuous feedback on delays or blockages so that resolution can be made immediately with effort from the whole team.
Quick responses to changing requirements and accommodating them soon.
Continuous integration driven regression testing.
No time delays between development and testing. test first, continuous testing approaches are followed.
Automation testing implemented early in the development lifecycle, thereby reducing total testing time and effort.
Best Practices in Agile Testing
Follow the best practices given below −
Inclusion of testers with expertise in all types of testing at all levels.
Testers participating in the definition of requirements, collaborating with customers on the expected behavior of the product.
Testers sharing feedback continuously with the developers and customer.
Test first and continuous testing approaches to align to the development work.
Tracking test status and test progress promptly and constantly with focus on delivering quality product.
Automation testing early in the development lifecycle to reduce cycle time.
To perform Regression Testing leverage Automation Testing as an effective way.
Challenges in Agile Testing
The following challenges exist in Agile testing −
Failure to understand the Agile approach and its limitations by the Business and Management can lead to unachievable expectations.
Agile follows whole-Team approach, but not everyone knows the essentials of Testing Practices. Testers are advised to coach the others, but in real scenario can be impracticable with time-boxed Sprints (Iterations).
Test First Approach requires Developers to base the coding on Tester Feedback, but in real scenarios Developers are more accustomed to base the coding on the Requirements coming from Customer or Business.
Accountability for the Quality Product is with the entire Agile Team, but in initial stages the Developers may not Focus on Quality as they are more into the implementation mode.
Continuous Integration calls for Regression Testing that requires considerable effort, even if it has to be automated.
Testers can be adaptable to changes with the Agile mind-set, but accommodating the resulting Test Changes and Testing can be impracticable to target to finish during the Sprint.
Early Automation is advised so that Manual Testing Effort and Time can be reduced. But, in the real scenario, arriving at the Tests that can be automated and automating them require Time and Effort.
Agile Testing Guidelines
Use the following guidelines while performing Agile Testing.
Participate in Release Planning to identify the required Testing activities and come up with the initial version of test plan.
Participate in estimation session to arrive at testing effort and duration so that testing activities are accommodated in the iterations.
Participate in User Story Definition to arrive at Acceptance Test Cases.
Participate in every Sprint Planning Meeting to understand the scope and update Test Plan.
Continuously collaborate with the Development Team during the Sprint to make Testing and Coding a success well within the Sprint.
Participate in Daily Stand-up Meetings and convey Test Delays or Blockages if any, to receive immediate resolution.
Track and Report Test Status, Test Progress and Product Quality regularly.
Be ready to accommodate changes, responding with modifications to Test Cases, Test Data.
Participate in Sprint Retrospectives to understand and contribute the Best Practices and Lessons Learned.
Collaborate in obtaining Customer Feedback at each Sprint.
As in the case of Traditional Testing, Agile Testing also need to cover all the Test Levels.
- Unit Testing
- Integration Testing
- System Testing
- User Acceptance Testing
Unit Testing
- Done along with Coding, by Developer
- Supported by Tester who writes Test Cases ensuring 100% Design Coverage
- Unit Test Cases and Unit Testing results need to be reviewed
- Unresolved major defects (as per priority and severity) are not left
- All Unit Tests are automated
Integration Testing
- Done along with Continuous Integration as the Sprints progress
- Done at the end after all the Sprints are completed
- All Functional Requirements are tested
- All Interfaces between Units are tested
- All the Defects are Reported
- Tests are automated where possible
System Testing
- Done as the Development progresses
- Users Stories, Features and Functions are Tested
- Testing done in Production Environment
- Quality Tests are executed (Performance, Reliability, etc.)
- Defects are reported
- Tests are automated where possible
User Acceptance Testing
Done at the end of each Sprint and at the end of the project
Done by the Customer. Feedback is taken by the Team
Feedback will be an input to subsequent Sprints
User Stories in a Sprint are pre-verified to be testable and are with defined Acceptance Criteria
Test Types
- Component Tests (Unit Tests)
- Functional Tests (User Stories Tests)
- Non-functional Tests (Performance, Load, Stress, etc.)
- Acceptance Tests
Tests can be fully Manual, fully Automated, Combination of Manual and Automated or Manual supported by Tools.
Support Programming and Critique Product Tests
Tests can be for −
Supporting Development (Support Programming) − Support Programming Tests are used by the Programmers.
To decide on what code they need to write to accomplish a certain behavior of a System
What Tests need to be run after Coding to ensure the new Code does not hamper the rest of the behaviors of the System
Verification only (Critique Product) − Critique Product Tests are used for discovering inadequacies in the finished Product
Business Facing and Technology Facing Tests
To decide on what tests to be performed when, you need to determine whether a test is −
- Business Facing, or
- Technology Facing
Business Facing Tests
A Test is a business-facing test if it answers the questions framed with words from business domain. These are understood by the business experts and would interest them so that behavior of the system can be explained in the real time scenario.
Technology Facing Tests
A Test is a technology-facing test if it answers the questions framed with words from technology domain. The programmers understand what needs to be implemented based on the clarifications on technology.
These two aspects of test types can be viewed using the Agile Testing Quadrants defined by Brian Marick.
Agile Testing Quadrants
Combining the two aspects of Testing Types, the following Agile Testing Quadrants are derived by Brian Marick −
The Agile Testing Quadrants provide a helpful taxonomy to help teams identify, plan and execute the testing needed.
Quadrant Q1 − Unit Level, Technology Facing, and supports the developers. Unit tests belong to this Quadrant. These tests can be Automated tests.
Quadrant Q2 − System level, business facing, and conform product behavior. Functional tests belong to this quadrant. These tests are either manual or automated.
Quadrant Q3 − System or User Acceptance Level, Business Facing and focus on real time scenarios. User Acceptance Tests belong to this quadrant. These tests are manual.
Quadrant Q4 − System or Operational Acceptance Level, Technology Facing and Focus on Performance, Load, Stress, Maintainability, Scalability Tests. Special tools can be used for these tests along with automation testing.
Combining these, the Agile Testing Quadrants that reflect What-Testing-When can be visualized as follows −
Scrum advocates Whole Team Approach, in the sense that every team member has to take part in every project activity. Scrum team is self-organizing with accountability to the project deliverables. Decision-making is left to the team that results in appropriate actions being taken at the right time without any time delays. This approach also encourages proper use of the team talent instead of restricting to one activity. Testers also participate in all the project and development activities contributing their expertise in testing.
The whole team works together on Test Strategy, Test Planning, Test Specification, Test Execution, Test Evaluation, and Test Results Reporting.
Collaborative User Story Creation
Testers participate in User Story Creation. Testers contribute their ideas on possible behavior of the system. This helps in the customer and/or end user understanding the system in the real environment and thus getting clarity on what actually they want as the outcome. This results in faster freezing of requirements and also reduces the probability of changes in the requirements later on.
Testers also come up with the Acceptance Criteria for every scenario agreed by the customer.
Testers contribute to the creation of testable user stories.
Release Planning
Release Planning is done for the entire project. However, Scrum framework involves iterative decision making as more information is obtained in the due course of executing sprints. Hence, Release Planning session at the beginning of the project need not produce a detailed release plan for the entire project. It can be updated continually, as relevant information is available.
Every sprint-end need not have a release. A release can be after a group of sprints. The main criteria of a release is to deliver business value to the customer. The team decides on the sprint length with release planning as an input.
Release Planning is the basis of test approach and test plan for release. Testers estimate Test Effort and plan Testing for the release. When release plans change, testers must handle changes, obtain an adequate test basis considering larger context of release. Testers also provide testing effort that is required at the end of all the sprints.
Sprint Planning
Sprint planning is done at the beginning of each sprint. The sprint backlog is created with the user stories picked up from the product backlog for implementation in that particular sprint.
The testers should −
- Determine the testability of the user stories selected for the sprint
- Create acceptance tests
- Define test levels
- Identify test automation
Testers update the test plan with the estimates for testing effort and durations in the sprint. This ensures provision of time for required testing during the time-boxed sprints and also accountability of the testing effort.
Test Analysis
When a sprint begins, as the developers carry on story analysis for design and implementation, testers perform test analysis for the stories in the sprint backlog. Tester create the required test cases – both manual and automated tests.
Testing
All the members of the Scrum team should participate in testing.
The developers execute the unit tests as they develop code for the user stories. Unit Tests are created in every sprint, before the code is written. The unit test cases are derived from low level design specifications.
The testers perform functional and non-functional features of the user stories.
The testers mentor the other members in the scrum team with their expertise in testing so that the entire team will have a collective accountability for the quality of the product.
At the end of the sprint, customer and/or end users carry out User Acceptance Testing and provide feedback to the scrum team. This forms as an input to the next sprint.
Test results are collected and maintained.
Automation Testing
Automation testing is given high importance in Scrum teams. The testers devote time in creating, executing, monitoring and maintaining of automated tests and results. As changes can occur any time in scrum projects, testers need to accommodate testing of changed features and also the regression testing involved. Automation testing facilitates managing of test effort associated with the changes. Automated tests at all levels facilitate achieving continuous integration. Automated tests run much faster than manual tests at no additional effort.
The manual testing focuses more on exploratory testing, product vulnerability, predicting defects.
Automation of Testing Activities
Automation of testing activities reduces the burden of repeated work and result in cost savings. Automate
- Test Data Generation
- Test Data Loading
- Build Deployment into Test Environment
- Test Environment Management
- Data Output Comparison
Regression Testing
In a sprint, testers test the code that is new / modified in that sprint. However, testers also need to ensure that the code developed and tested in the earlier sprints also is working along with the new code. Hence Regression testing is given importance in scrum. Automated regression tests are run in continuous integration.
Configuration Management
A Configuration management system that uses automated build and test frameworks is used in Scrum projects. This allows to run static analysis and unit tests repeatedly as new code is checked into the Configuration Management System. It also manages continuous integration of the new code with the system. Automated Regression Tests are run during Continuous Integration.
Manual Test Cases, Automated Tests, Test Data, Test Plans, Test Strategy and other Testing Artifacts need to be Version Controlled and require relevant Access Permissions to be ensured. This can be accomplished by maintaining the Testing Artifacts in the Configuration Management System.
Agile Testing Practices
Testers in a Scrum Team can follow the following Agile Practices −
Pairing − Two Team Members sit together and work collaboratively. The two people can be two Testers or one Tester and one Developer.
Incremental Test Design − Test Cases are developed as the Sprints progress incrementally and User Stories are added up.
Agile Metrics
During software development, collection and analysis of metrics help in improving the process and thereby achieving better productivity, quality deliverables and customer satisfaction. In Scrum based development, this is possible and the testers have to pay attention to the metrics that they need to.
Several metrics are suggested for Scrum development. The significant metrics are −
Ratio of Successful Sprints − (Number of successful Sprints / Total number of Sprints) * 100. A Successful Sprint is one in which the Team could meet its commitment.
Velocity − A team’s Velocity is based on the amount of Story Points a team earned during a sprint. Story Points are the measure of the User Stories counted during estimation.
Focus Factor − (Velocity / Team’s Work Capacity) / 100. Focus Factor is the percentage of the team’s effort that results in finished stories.
Estimation Accuracy − (Estimated effort / Actual effort) / 100. Estimation Accuracy is the Team’s ability in estimating the effort accurately.
Sprint Burndown − Work (in Story Points or in hours) that is Remaining Vs. Work that needs to be Remaining ideally (as per the Estimation).
If it is more, then it means that the Team has taken up more Work than they can do.
If it is less, then it means the Team did not Estimate accurately.
Defect Count − Number of defects in a Sprint. Defect count is the amount of defects in the software as against the backlog.
Severity of Defects − Defects can be categorized as minor, major and critical as per their severity. Testers can define the categorization.
Sprint Retrospectives
In Sprint Retrospectives, all the team members will participate. They share −
- The things that went well
- Metrics
- The scope for improvements
- Action items to apply
In Agile Testing, the commonly used Testing methods are from the traditional practices and are aligned to the principle – Test Early. The Test Cases are written before the code is written. The emphasis is on defect prevention, detection, and removal running the right test types at the right time and at right level.
이 장에서는 방법에 대해 이해하게 될 것입니다.
- 테스트 주도 개발 (TDD)
- 수용 테스트 주도 개발 (ATDD)
- 행동 중심 개발 (BDD)
테스트 주도 개발
TDD (Test Driven Development) 방법에서 코드는 Automated Test Cases에서 지시하는 Testfirst 접근 방식을 기반으로 개발됩니다. 테스트 케이스는 먼저 실패로 작성되고 코드는 테스트를 통과하는지 확인하기 위해 개발됩니다. 방법이 반복되고 코드 개발을 통해 리팩토링이 이루어집니다.
TDD는 다음 단계를 통해 이해할 수 있습니다.
Step 1 − 작성해야하는 코드 기능의 예상되는 동작을 반영하는 테스트 케이스를 작성합니다.
Step 2− 테스트를 실행합니다. 코드가 아직 개발되지 않았기 때문에 테스트가 실패합니다.
Step 3 − 테스트 케이스를 기반으로 코드를 개발합니다.
Step 4− 테스트를 다시 실행하십시오. 이번에는 기능이 코딩 될 때 테스트를 통과해야합니다. 테스트가 통과 할 때까지 단계 (3) 및 단계 (4)를 반복합니다.
Step 5 − 코드를 리팩터링합니다.
Step 6 − 테스트를 다시 실행하여 통과하는지 확인하십시오.
반복 Step 1 – Step 6기능을 추가하기 위해 테스트 케이스를 추가합니다. 추가 된 테스트와 이전 테스트는 코드가 예상대로 실행되는지 확인하기 위해 매번 실행됩니다. 이 프로세스를 빠르게 수행하기 위해 테스트가 자동화됩니다.
테스트는 단위, 통합 또는 시스템 수준 일 수 있습니다. 테스터와 개발자 간의 지속적인 커뮤니케이션이 보장되어야합니다.
수용 테스트 주도 개발
ATDD (Acceptance Test Driven Development) 방법에서 코드는 Acceptance Test Cases에서 지시하는 테스트 우선 접근 방식을 기반으로 개발됩니다. 초점은 고객, 최종 사용자 및 관련 이해 관계자와 협력하여 사용자 스토리 생성 중에 테스터가 작성한 수락 기준 및 수락 테스트 사례에 있습니다.
Step 1 − 고객 및 사용자와 협력하여 사용자 스토리와 함께 수락 테스트 케이스를 작성합니다.
Step 2 − 관련 허용 기준을 정의합니다.
Step 3 − 승인 테스트 및 승인 기준에 따라 코드를 개발합니다.
Step 4 − 승인 테스트를 실행하여 코드가 예상대로 실행되는지 확인합니다.
Step 5− 수락 테스트를 자동화합니다. 반복Step 3 – Step 5 반복의 모든 사용자 스토리가 구현 될 때까지
Step 6 − 회귀 테스트를 자동화합니다.
Step 7 − 지속적인 회귀를 보장하기 위해 자동화 된 회귀 테스트를 실행합니다.
행동 중심 개발 (BDD)
BDD (Behavior Driven Development)는 TDD (Test Driven Development)와 유사하며 시스템의 예상 동작을 확인하기 위해 코드를 테스트하는 데 중점을 둡니다.
BDD에서는 영어와 같은 언어가 사용되므로 사용자, 테스터 및 개발자가 이해할 수 있습니다. 그것은 보장합니다-
- 사용자, 테스터 및 개발자 간의 지속적인 커뮤니케이션.
- 개발 및 테스트중인 항목에 대한 투명성.
전통적인 테스트의 테스트 기술은 Agile 테스트에서도 사용할 수 있습니다. 이 외에도 Agile 프로젝트에서는 Agile 특정 테스트 기술 및 용어가 사용됩니다.
테스트 기준
애자일 프로젝트에서 제품 백로 그는 요구 사항 사양 문서를 대체합니다. 제품 백 로그의 내용은 일반적으로 사용자 스토리입니다. 비 기능적 요구 사항도 사용자 스토리에서 처리됩니다. 따라서 Agile 프로젝트의 테스트 기반은 사용자 스토리입니다.
품질 테스트를 보장하기 위해 다음을 테스트 기준으로 추가로 고려할 수도 있습니다.
- 동일한 프로젝트 또는 과거 프로젝트의 이전 반복 경험.
- 시스템의 기존 기능, 아키텍처, 디자인, 코드 및 품질 특성.
- 현재 및 과거 프로젝트의 결함 데이터.
- 고객 피드백.
- 사용자 문서.
완료의 정의
완료 정의 (DoD)는 Sprint 백 로그의 활동 완료를 보장하기 위해 Agile 프로젝트에서 사용되는 기준입니다. DoD는 스크럼 팀마다 다를 수 있지만 한 팀 내에서 일관성이 있어야합니다.
DoD는 사용자 스토리의 일부인 비 기능적 요구 사항과 함께 사용자 스토리의 기능 및 기능 구현을 보장하는 필수 활동의 체크리스트입니다. 사용자 스토리는 DoD 체크리스트의 모든 항목이 완료된 후 완료 단계에 도달합니다. DoD는 팀간에 공유됩니다.
사용자 스토리에 대한 일반적인 DoD에는 다음이 포함될 수 있습니다.
- 세부적인 테스트 가능한 허용 기준
- 반복에서 사용자 스토리와 다른 사용자 스토리의 일관성을 보장하기위한 기준
- 제품과 관련된 특정 기준
- 기능적 행동 측면
- 비 기능적 특성
- Interfaces
- 테스트 데이터 요구 사항
- 테스트 범위
- Refactoring
- 검토 및 승인 요건
사용자 스토리를위한 DoD 외에도 DoD도 필요합니다.
- 모든 수준의 테스트에서
- 각 기능에 대해
- 각 반복에 대해
- 출시 용
테스트 정보
테스터는 다음과 같은 테스트 정보가 필요합니다.
- 테스트가 필요한 사용자 스토리
- 관련 수락 기준
- 시스템 인터페이스
- 시스템이 작동 할 것으로 예상되는 환경
- 도구 가용성
- 테스트 범위
- DoD
애자일 프로젝트에서 테스트는 순차적 인 활동이 아니며 테스터는 협업 모드로 작업해야하므로 테스터는 다음을 수행해야합니다.
- 지속적으로 필요한 테스트 정보를 얻습니다.
- 테스트에 영향을 미치는 정보 격차를 식별합니다.
- 다른 팀 구성원과 공동으로 격차를 해결하십시오.
- 테스트 레벨에 도달하는시기를 결정하십시오.
- 적절한 시간에 적절한 테스트가 실행되도록합니다.
기능 및 비 기능 테스트 설계
Agile 프로젝트에서는 기존 테스트 기술을 사용할 수 있지만 초점은 초기 테스트에 있습니다. 구현이 시작되기 전에 테스트 케이스가 있어야합니다.
기능 테스트 설계의 경우 테스터와 개발자는 다음과 같은 전통적인 블랙 박스 테스트 설계 기술을 사용할 수 있습니다.
- 등가 분할
- 경계 값 분석
- 의사 결정 테이블
- 상태 전환
- 클래스 트리
비 기능적 테스트 디자인의 경우 비 기능적 요구 사항도 각 사용자 스토리의 일부이기 때문에 블랙 박스 테스트 디자인 기술은 관련 테스트 케이스를 디자인하는 데만 사용할 수 있습니다.
탐색 적 테스트
애자일 프로젝트에서 시간은 종종 테스트 분석 및 테스트 설계의 제한 요소입니다. 이러한 경우 탐색 적 테스트 기술을 기존 테스트 기술과 결합 할 수 있습니다.
탐색 테스트 (ET)는 동시 학습, 테스트 설계 및 테스트 실행으로 정의됩니다. 탐색 적 테스트에서 테스터는 테스트가 수행 될 때 테스트 디자인을 적극적으로 제어하고 테스트 중에 얻은 정보를 사용하여 새롭고 더 나은 테스트를 디자인합니다.
탐색 적 테스트는 Agile 프로젝트의 변경 사항을 수용하는 데 유용합니다.
위험 기반 테스트
위험 기반 테스트는 실패 위험을 기반으로 테스트하고 테스트 설계 기술을 사용하여 위험을 완화합니다.
제품 품질 위험은 제품 품질의 잠재적 인 문제로 정의 할 수 있습니다. 제품 품질 위험은 다음과 같습니다.
- 기능적 위험
- 비 기능적 성능 위험
- 비 기능적 사용성 위험
위험 분석은 각 위험의 가능성 (가능성)과 영향을 평가하기 위해 수행되어야합니다. 그런 다음 위험이 우선 순위가 지정됩니다.
- 고위험에는 광범위한 테스트가 필요합니다
- 낮은 위험은 커서 테스트 만 필요
테스트는 각 위험의 위험 수준 및 위험 특성에 따라 적절한 테스트 기술을 사용하여 설계됩니다. 그런 다음 위험을 완화하기 위해 테스트가 실행됩니다.
적합 테스트
적합성 테스트는 자동화 된 수락 테스트입니다. Tools Fit 및 FitNesse는 수락 테스트를 자동화하는 데 사용할 수 있습니다.
FIT는 JUnit을 사용하지만 테스트 기능을 확장합니다. HTML 테이블은 테스트 케이스를 표시하는 데 사용됩니다. Fixture는 HTML 테이블 뒤에있는 Java 클래스입니다. 픽스처는 HTML 테이블의 내용을 가져와 테스트중인 프로젝트에서 테스트 케이스를 실행합니다.
테스트 계획은 출시 계획시 준비되며 모든 스프린트 계획에서 수정됩니다. 테스트 계획은 전체 테스트 범위를 갖기 위해 테스트 프로세스의 가이드 역할을합니다.
테스트 계획의 일반적인 내용은 다음과 같습니다.
- 테스트 전략
- 테스트 환경
- 테스트 범위
- 테스트 범위
- 노력 및 일정 테스트
- 테스트 도구
Agile Projects에서 모든 팀원은 제품의 품질에 대해 책임을집니다. 따라서 모든 사람이 테스트 계획에도 참여합니다.
테스터의 책임은 필요한 지침을 제공하고 나머지 팀에게 테스트 전문 지식을 멘토링하는 것입니다.
사용자 스토리
User Stories는 원칙적으로 작업 제품을 테스트하지 않습니다. 그러나 애자일 프로젝트에서 테스터는 사용자 스토리 생성에 참여합니다. 테스터는 고객에게 가치를 제공하고 시스템의 다양한 가능한 동작을 다루는 사용자 스토리를 작성합니다.
테스터는 또한 모든 사용자 스토리가 테스트 가능한지 확인하고 수락 기준을 확인합니다.
수동 및 자동 테스트
테스트를 처음 실행하는 동안 수동 테스트가 사용됩니다. 그들은 포함합니다-
- 단위 테스트
- 통합 테스트
- 기능 테스트
- 비 기능 테스트
- 수락 테스트
그런 다음 테스트는 후속 실행을 위해 자동화됩니다.
에 Test Driven Development, 단위 테스트는 먼저 실패로 작성되고 코드는 테스트를 통과하도록 개발 및 테스트됩니다.
에 Acceptance Test Driven Development, 합격 테스트는 먼저 실패로 작성되고 코드는 테스트를 통과하도록 개발 및 테스트됩니다.
다른 개발 방법에서는 테스터가 나머지 팀과 협력하여 테스트 범위를 보장합니다.
모든 유형의 방법에서 지속적 통합 테스트를 포함하는 지속적 통합이 발생합니다.
팀은 자동화 할 테스트시기와 테스트를 결정할 수 있습니다. 테스트를 자동화하려면 노력과 시간이 필요하더라도 결과로 생성되는 자동화 된 테스트는 Agile 프로젝트를 반복하는 동안 반복적 인 테스트 노력과 시간을 크게 줄여줍니다. 이를 통해 팀은 새로운 사용자 스토리, 변경 사항 등과 같은 다른 필수 활동에 더 많은주의를 기울일 수 있습니다.
에 Scrum, 반복은 타임 박스입니다. 따라서 특정 스프린트에서 사용자 스토리 테스트를 완료 할 수없는 경우 테스터는 일일 스탠드 업 미팅에서 사용자 스토리가 해당 스프린트 내에서 완료 상태에 도달 할 수 없으므로 다음 스프린트에 보류 상태로 유지되어야한다고보고 할 수 있습니다.
시험 결과
애자일 프로젝트의 대부분의 테스트가 자동화되므로 도구는 필요한 테스트 결과 로그를 생성합니다. 테스터는 테스트 결과 로그를 검토합니다. 테스트 결과는 각 스프린트 / 릴리스에 대해 유지되어야합니다.
다음을 포함하는 테스트 요약도 준비 할 수 있습니다.
- 테스트 범위 (테스트 대상 및 테스트되지 않은 항목)
- 가능한 경우 근본 원인 분석과 함께 결함 분석
- 결함 수정 후 회귀 테스트 상태
- 문제 및 해당 해결 방법
- 보류중인 문제 (있는 경우)
- 테스트 전략에 필요한 모든 수정
- 테스트 지표
테스트 지표 보고서
애자일 프로젝트에서 테스트 지표에는 각 스프린트에 대해 다음이 포함됩니다.
- 노력 테스트
- 추정 정확도 테스트
- 테스트 범위
- 자동화 된 테스트 범위
- 결함 수
- 결함률 (사용자 스토리 포인트 당 결함 수)
- 결함 심각도
- 동일한 스프린트에서 결함을 수정하는 데 걸리는 시간 (현재 스프린트에서 벗어나는 버그 수정 비용의 24 배 비용)
- 동일한 스프린트에서 수정 된 결함 수
- Sprint 내에서 고객의 수락 테스트 완료
스프린트 검토 및 회고 보고서
테스터는 Sprint Review 및 Retrospective 보고서에도 기여합니다. 일반적인 내용은-
- 테스트 지표
- 테스트 결과 로그 검토 결과
- 제대로 된 점과 테스트 관점에서 개선 할 수있는 점
- 모범 사례
- 교훈
- Issues
- 고객 피드백
Kanban 개념을 사용하여 애자일 테스트 활동을 효과적으로 관리 할 수 있습니다. 다음은 테스트가 반복 / 스프린트 내에서 적시에 완료되도록 보장하므로 고품질 제품 제공에 중점을 둡니다.
테스트 가능하고 효과적인 크기의 사용자 스토리는 지정된 시간 제한 내에 개발 및 테스트를 수행합니다.
WIP (Work-In-Progress) 제한을 사용하면 한 번에 제한된 수의 사용자 스토리에 집중할 수 있습니다.
워크 플로를 시각적으로 나타내는 Kanban 보드는 테스트 활동 및 병목 현상이있는 경우이를 추적하는 데 도움이됩니다.
Kanban 팀 협업 개념을 사용하면 대기 시간없이 병목 현상이 식별되는 즉시 해결할 수 있습니다.
테스트 케이스를 미리 준비하고, 개발이 진행됨에 따라 테스트 스위트를 유지하고, 고객 피드백을 받으면 반복 / 스프린트 내에서 결함을 제거하는 데 도움이됩니다.
DoD (Done-Done) 정의는 테스트가 완료된 후에 만 스토리가 완료 상태에 도달한다는 의미에서 Done-Done이라고합니다.
제품 개발에서의 테스트 활동
제품 개발에서 기능 Kanban 보드로 릴리스를 추적 할 수 있습니다. 특정 릴리스의 기능은 기능 개발 상태를 시각적으로 추적하는 기능 Kanban 보드에 지정됩니다.
릴리스의 기능은 애자일 접근 방식을 사용하여 릴리스 내에서 스토리로 분할되고 개발됩니다.
다음 Agile Testing 활동은 모든 릴리스와 모든 릴리스의 마지막에 품질 제공을 보장합니다.
테스터는 사용자 스토리 생성에 참여하여 다음을 보장합니다.
시스템의 가능한 모든 동작은 사용자 스토리와 사용자 스토리의 일부인 비 기능적 요구 사항을 통해 캡처됩니다.
사용자 스토리는 테스트 할 수 있습니다.
사용자 스토리의 크기를 통해 반복 내에서 개발 및 테스트를 완료 (완료) 할 수 있습니다.
비주얼 작업 간판 보드 −
작업의 상태 및 진행 상황을 설명합니다.
병목 현상이 발생하면 즉시 식별
최적화 할 수있는주기 시간 측정을 용이하게합니다.
팀 협업은 다음에 도움이됩니다-
품질 제품에 대한 전체 팀의 책임
병목 현상이 발생하는 즉시 해결하여 대기 시간 절약
모든 활동에 대한 모든 전문 지식의 기여
지속적 통합 테스트에 초점을 맞춘 지속적 통합
테스트 노력과 시간을 절약하기위한 테스트 자동화
개발 초기에 작성된 테스트 케이스를 통한 결함 방지 및 시스템의 다양한 동작에 의해 예상되는 사항에 대해 개발자를 멘토링
한 번에 제한된 수의 사용자 스토리에 집중할 수있는 WIP 제한
개발이 진행됨에 따라 지속적인 테스트를 통해 반복 내에서 결함 수정을 보장합니다.
테스트 범위 보장
미결 결함 수를 낮게 유지
스토리 탐색
Story Exploration은 제품 소유자가 개발 승인을 위해 스토리를 전달할 때 스토리 이해를 탐색하기위한 Agile 팀 내의 커뮤니케이션입니다.
제품 소유자는 시스템에서 기대하는 기능을 기반으로 이야기를 제시합니다. 개발자는 수용 할 준비가되었다고 표시하기 전에 각 스토리를 더 많이 탐색합니다. 또한 테스터는 테스트 관점에서 커뮤니케이션에 참여하여 가능한 한 테스트 할 수 있도록합니다.
스토리의 마무리는 제품 소유자, 개발자 및 테스터 간의 지속적이고 지속적인 커뮤니케이션을 기반으로합니다.
견적
릴리스 계획 및 각 반복 계획에서 추정이 이루어집니다.
릴리스 계획에서 테스터는 다음을 제공합니다.
- 어떤 테스트 활동이 필요한지에 대한 정보
- 동일에 대한 노력 추정
반복 계획에서 테스터는 반복에 포함될 수있는 스토리의 수와 내용을 결정하는 데 기여합니다. 결정은 테스트 노력 및 테스트 일정 추정에 따라 다릅니다. Story Estimation은 테스트 견적도 반영합니다.
Kanban에서 Done-Done은 스토리가 개발되고 테스트되고 결함없이 완료로 표시 될 때만 수행됩니다.
따라서 테스트 추정은 스토리 추정에서 중요한 역할을합니다.
스토리 기획
스토리 계획은 스토리가 추정되고 현재 반복에 할당 된 후에 시작됩니다.
스토리 계획에는 다음 테스트 작업이 포함됩니다.
- 테스트 데이터 준비
- 수용 테스트 확장
- 수동 테스트 실행
- 탐색 적 테스트 세션 수행
- 지속적인 통합 테스트 자동화
이러한 테스트 작업 외에도 다음과 같은 다른 작업이 필요할 수 있습니다.
- 성능 시험
- 회귀 테스트
- 관련 지속적 통합 테스트 업데이트
스토리 진행
Story Progression은 개발자와 테스터 간의 지속적인 의사 소통에 필요한 추가 테스트를 발견합니다. 개발자가 구현에 대해 더 명확한 설명이 필요한 상황에서 테스터는 탐색 테스트를 수행합니다.
연속 테스트는 스토리 진행 중에 수행되며 연속 통합 테스트를 포함합니다. 전체 팀이 테스트 활동에 참여합니다.
이야기 수용
스토리 수락은 스토리가 완료-완료 상태에 도달 할 때 발생합니다. 즉, 스토리가 개발되고 테스트되고 완료되었음을 알립니다.
스토리 테스트는 스토리 통과 또는 테스트 자동화 수준과 관련된 모든 테스트가 충족 될 때 완료된다고합니다.
애자일 프로젝트에서 테스터는 다음과 같은 일일 작업을 담당합니다.
시스템의 예상 동작에 대한 설명과 함께 코딩 개발자를 지원합니다.
개발자가 효과적이고 효율적인 단위 테스트를 만드는 데 도움이됩니다.
자동화 스크립트를 개발하십시오.
회귀 테스트를 위해 자동화 테스트 도구 / 스크립트를 지속적 통합과 통합합니다.
이러한 작업의 효과적이고 빠른 구현을 위해 대부분의 Agile 프로젝트에서 코드 및 테스트 구성 요소의 CI를 지원하는 지속적 통합 (CI) 시스템이 사용됩니다.
애자일 프로젝트의 테스터와 개발자는 다양한 도구를 사용하여 테스트 세션을 관리하고 결함 보고서를 작성 및 제출할 수 있습니다. 애자일 테스트를위한 특수 도구 외에도 애자일 팀은 테스트 자동화 및 테스트 관리 도구의 이점을 누릴 수 있습니다.
Note − 기록 및 재생, Test-Last, Heavyweight 및 테스트 자동화 솔루션은 다음과 같이 민첩하지 않습니다.
이러한 도구에서 권장하는 마지막 테스트 워크 플로는 애자일 팀에서는 작동하지 않습니다.
이러한 도구로 만든 유지 관리 할 수없는 스크립트는 변경을 방해합니다.
이러한 특수 도구는 테스트 자동화 전문가에 대한 요구를 생성하여 사일로를 조성합니다.
널리 사용되는 도구는 다음과 같습니다.
S. 아니. | 도구 및 목적 |
---|---|
1 | Hudson CI 프레임 워크 |
2 | Selenium 기능 테스트 – Hudson과 통합 |
삼 | CruiseControl CI 프레임 워크 |
4 | Junit 자바 단위 테스트 |
5 | Nunit .Net 단위 테스트 |
6 | Cobertura / JavaCodeCoverage / JFeature / JCover / 자바 테스트 커버리지 |
7 | Jester 자바-돌연변이 테스트 / 자동 오류 시딩 |
8 | Gretel 자바 테스트 커버리지 모니터링 도구 |
9 | TestCocoon C / C ++ 또는 C #-중복 테스트를 찾아 테스트 양을 줄이고 데드 코드를 찾습니다. |
10 | JAZZ Java-분기, 노드 및 해체 커버리지 및 GUI, 테스트 플래너, 동적 계측 및 테스트 분석기 구현 |
11 | Ant 자바 – 자동화 빌드 |
12 | Nant .Net-자동화 빌드 |
13 | Bonfire JIRA 용 애자일 테스팅 애드온 |
애자일 테스트 자동화 도구
효과적인 애자일 테스트 자동화 도구 지원 −
테스트 우선 접근 방식을 사용한 초기 테스트 자동화.
실제 언어, 도메인 특정 언어를 사용하여 테스트 자동화 코드 작성.
시스템의 예상되는 동작에 중점을 둡니다.
구현 세부 사항에서 테스트의 본질을 분리하여 기술 독립적으로 만듭니다.
협업 촉진.
자동화 된 단위 테스트 (Junit 또는 NUnit 사용)는 코딩을위한 테스트 우선 접근 방식을 지원합니다. 이는 화이트 박스 테스트이며 설계가 건전하고 결함이 없는지 확인합니다. 이러한 테스트는 테스터의 지원을 받아 개발자가 빌드하며 필요한 기능과 독립적 일 수 있습니다. 이로 인해 고객 요구 사항을 충족하지 않아 비즈니스 가치가없는 제품이 제공됩니다.
이 문제는 고객, 기타 이해 관계자, 테스터 및 개발자의 공동 작업으로 작성된 수락 테스트를 자동화하여 해결됩니다. 자동화 된 수락 테스트는 제품의 예상되는 동작을 반영하여 고객 또는 제품 소유자 / 비즈니스 분석가가 작성합니다. 개발자의 참여는 요구 사항에 따라 코드 생성을 보장합니다. 그러나 테스트가 승인에만 초점을 맞추는 경우 결과 코드는 확장 불가능한 상태로 남아있을 수 있습니다.
따라서 자동화 된 단위 테스트와 자동화 된 수락 테스트는 무료이며 둘 다 애자일 개발에 필요합니다.
자동화 된 수락 테스트를 지원하는 애자일 도구 및 프레임 워크는 다음과 같습니다.
- Fit
- Fitnesse
- Concordion
- Ruby
- Cucumber
적당한
Ward Cunningham은 수락 테스트 자동화에 사용할 수있는 도구 Fit을 개발했습니다. 맞춤 허용-
고객 또는 제품 소유자는 Microsoft Word 및 Microsoft Excel을 사용하여 제품 동작의 예를 제공합니다.
프로그래머는 이러한 예제를 자동화 된 테스트로 쉽게 전환 할 수 있습니다.
Fit 1.1은 Java와 .NET을 모두 지원합니다.
FitNesse
FitNesse는 방문자가 기존 페이지 변경 및 새 페이지 생성을 포함하여 모든 편집을 수행 할 수있는 웹 서버 스타일 인 wiki입니다. 간단한 마크 업 언어를 사용하면 쉽게 제목을 만들고 텍스트를 굵게, 밑줄 및 기울임 꼴로 만들고 글 머리 기호 목록을 만들고 다른 종류의 간단한 서식을 지정할 수 있습니다.
FitNesse에서 수락 테스트 자동화는 다음과 같습니다.
입력 데이터 및 예상 출력 데이터 테이블로 테스트를 표현합니다.
FitNesse를 사용하여 편집 할 수있는 페이지에 테스트 테이블을 배치합니다.
또는 테스트 테이블을 Microsoft Excel에 넣고 클립 보드에 복사 한 다음 Spreadsheet to FitNesse FitNesse가 테이블 형식을 올바르게 지정하도록 명령
테스트 실행
테스트 테이블에있는 셀의 색상 코딩으로 테스트 결과를 얻습니다.
녹색 셀은 예상 값을 얻었음을 나타냅니다.
적혈구는 기대했던 것과 다른 값을 얻었음을 나타냅니다.
노란색 셀은 예외가 발생했음을 나타냅니다.
오이
Cucumber는 BDD (Behavior Driven Development) 프레임 워크를 기반으로하는 도구입니다. 주요 기능은-
웹 애플리케이션에 대한 승인 테스트를 작성하는 데 사용됩니다.
일반 영어와 같이 쉽게 읽고 이해할 수있는 형식으로 기능 검증을 자동화 할 수 있습니다.
Ruby로 구현 된 후 Java 프레임 워크로 확장되었습니다. 둘 다 Junit을 지원합니다.
Perl, PHP, Python, .Net 등과 같은 다른 언어를 지원합니다.
Selenium, Watir, Capybara 등과 함께 사용할 수 있습니다.