기본 콘텐츠로 건너뛰기

테스트 케이스와 체크리스트의 차이가 뭐여?

테스트 실무에서 가장 혼돈되어 사용되는 용어 중 하나가 테스트 케이스와 체크리스트입니다.

많은 경우 체크리스트를 테스트 케이스로 사용하는 경우가 많습니다.

실제로 인터넷 커뮤니티나 블로그, ISO, IEEE, ISTQB 등등을 검색해보시면 테스트 케이스와 체크리스트에 대한 구분이 다 제각각입니다.

각각에 대한 정의가 다 제각각입니다.

사정이 이러하다보니 많은 사람들이 테스트 케이스와 체크리스트를 잘 구분하지 못하고 혼동해서 사용하는 경우가 많습니다.

물과 기름처럼 테스트 케이스와 체크리스트를 정확하게 구분할 수는 없겠지만..

ISTQB를 기준으로 말씀드리면 설계 기법을 통해 도출된 것은 테스트 케이스 그렇지 않은 것은 체크리스트라고 생각하시면 쉽습니다.

예를 들면 아래는 결정 테이블 테스팅 기법을 통해 도출된 테스트 케이스의 예제입니다.



실제 테스트 케이스는 위보다 복잡하겠지만 어쨌든 얘기하고 싶은 것은 위와 같이 설계 기법을 통해서 도출된 것은 테스트 케이스라고 합니다.

그런데 딱 보시면 아시겠지만 실제 테스트에서는 저 정도로는 테스트 커버리지를 충분히 만족했다고 얘기하기 힘듭니다.

그렇습니다.

어떤 분들은 테스트 케이스가 전가의 보도, 은 총알 쯤으로 생각하시는데..

테스트 케이스는 일종의 마지노 선이라고 보시면 됩니다.

최소한 제품을 테스트 할때 이정도는 해줘야 한다는 최후의 방어선 정도라고 보시면 됩니다.

전쟁에서 최후의 방어선은 물러설 수 없는 마지막 보루입니다.

하지만 최후의 방어선만 지킨다고 전쟁에서 승리할 수는 없습니다.

프랑스는 마지노 요새만 믿고 있다가 독일에게 깔끔하게 발렸던 과거가 있지요.

전쟁에서 승리하려면 앞으로 나가야하고 치밀한 전략과 전술이 뒷받침 되어야 합니다.

더 높은 커버리지를 도달하고, 충분히 좋은 테스트가 수행되려면 테스트 케이스는 기본이 되어야 하고 거기에 더해서 체크리스트가 따라와 줘야 합니다.

이러한 체크리스트는 팀의 경험과 과거 프로젝트의 데이터를 통해서 도출되어야 합니다.

위와 같은 테스트 케이스에 추가적으로 체크리스트를 붙인다면 어떤것이 있을 수 있을까요?

예를 들면, 이런것이 있겠죠.

1. 캐릭터가 정확히 표현되고 이펙트가 정확히 출력되는지 확인한다.
2. 맵이 깨지는 곳이 있는지 확인한다.
3. 이동할 수 없는 곳에 캐릭터가 이동하는지 확인한다.

등등등..

이러한 체크리스트의 범위는 테스트의 목적 및 목표, 범위에 따라서 적절하게 조정할 수 있을 겁니다.

실제 실무에서는 이러한 많은 고민들에 따라 테스트 계획이 수립되어야겠지요.

이제, 테스트 케이스와 체크리스트가 조금은 구분이 되시나요?

제 경험상 아직도 많은 곳에서는 체크리스트를 테스트 케이스로 부르는 경우가 많습니다.

하지만 체크리스트는 커버리지를 보장하는 측면에서 매우 취약합니다.

그나마 상태가 좋은 체크리스트는 제대로 된 사용자 설명서가 있다는 가정에서 사용자 설명서를 기반으로 만들어진 체크리스트라고 할 수 있지만 그것도 그다지 썩 뛰어나지는 않습니다.

더 좋은 테스트를 위해서 테스터 여러분들이 결함이 집중되는 곳을 논리적으로 탐구하고 더 나은 설계기법을 개발하는 노력을 아낌없이 경주하셨으면 하는 바램입니다.

저 같은 경우는 실무에서 체크리스트를 작성할 때 간단한 설계기법을 적용하는 경우가 많습니다.

사실 테스트 케이스가 무엇이냐? 체크리스가 무엇이냐? 는 중요하지 않다고 생각합니다. 실제로 ISTQB에서는 체크리스트를 경험기반 기법의 하나로 다루고 있습니다.

정작 중요한 것은 테스트 커버리지에 대하여 고민하고 충분히 좋은 테스트를 수행하기 위해 노력하는 것이라고 생각합니다. 체크리스트와 테스트 케이스는 그러한 노력에 대한 하나의 도구일 뿐입니다.

댓글

  1. 감사합니다. 테스트 케이스와 체크리스트의 차이점에 대해 명쾌하게 알게 되었습니다!

    답글삭제

댓글 쓰기

이 블로그의 인기 게시물

스위치봇 & 스위치봇 허브 미니 간단 사용기

제 블로그에 예전부터 오셨던 분들은 제가 사브작 사브작 홈 오토메이션을 어설프게 해온 것을 아실겁니다. 작년부터 너무 하고 싶었던 도어락 자동화에 도전해봤습니다. 우리 나라에 자체 서비스로 앱을 통해 도어락을 제어하는 제품은 꽤 있습니다. 게이트맨도 있고, 키위도 있고, 삼성도 있죠.. 그런데.. 전 그것보다 구글 어시스턴트를 지원하는 도어락이 필요했는데... 그런건 안만들더라구요.. 꼭 필요한건 아니지만 웬지 해보고 싶은데... 언제 제품이 출시될지도 몰라서.. 가능한 방법을 찾아보다가.. 스위치봇이라는 제품으로 도어락을 버튼을 꾹 누르는 방법을 찾아서 스위치봇이 직구가 아닌 국내에 출시되었길래 낼름 구매해서 도전해봤습니다. 스위치봇 제품에 대한 내용이나 구매는  https://www.wakers.shop/  에서 하시면 됩니다. 저는 스위치봇에 스위치봇을 구글 홈에 연결시키기 위해 스위치봇 허브 미니까지 구매했습니다. 스위치봇 허브 미니가 없으면 스위치봇을 외부에서 제어하거나 구글 홈에 연결할 수 없습니다. 그리고 제가 스위치봇 허브 미니를 구매한 이유 중 다른 하나는 이 제품이 RF 리모컨 기능이 지원됩니다. 집에 있는 모니터를 제어할 필요가 있어서 이참 저참으로 같이 구매했습니다. 제품 등록은 어렵지 않습니다. 여기서는 스위치봇 허브 미니에 RF 리모컨을 등록해서 구글 어시스턴트로 제어하는 방법을 소개해드릴까 합니다. 제가 스위치봇 허브 미니로 모니터를 제어하고 싶었던 부분은 컴퓨터에서 크롬캐스트로 외부 입력을 때에 따라 바꿔야 하는데.. 그때마다 리모컨을 찾는게 너무 불편해서였습니다.  어차피 리모컨은 외부 입력 바꿀 때 빼고는 쓸 일도 없는지라.. 매번 어디로 사라지면 정말 불편해서 이걸 자동화 하고 싶었습니다. 그런데, 처음에 스위치봇 허브 미니를 등록하고 여기에 리모컨을 등록하니.. 구글 홈에 등록된 리모컨이 자동으로 등록이 됩니다. 그런데, 등록된걸 확인해보니 전원 On/Off만 제어되는 것이고, 나머지 버튼은 구글 홈...

테슬라 구매 과정 후기

올해 제 인생 최대 지름이 될.. 테슬라 구매를 했습니다. 스파크만 13년을 몰았는데... 내자분이 애들도 컸고.. 이젠 스파크가 좁고 덥고 힘들다면서... 4월 6일 하남 테슬라 전시장에서 새로 나온 업그레이드 된 모델 3를 보고 4월 7일 덜컥 계약을 해버리게 되었습니다. 이후에 4월 11일에 보조금 설문 조사 문자를 받았습니다. 그리고 다시 기다림의 시간이.. 사실, 처음에 하얀색을 계약을 했다가 하얀색은 관리하기가 너무 힘들거 같아 4월 20일에 블루로 변경을 했었는데.. 다른 사람들은 하나 둘 차량을 인도 받는데.. 아무리 기다려도 인도 일정이 배정이 되지 않아서... 혹시나 하고 4월 25일 하얀색으로 변경하자마자 VIN이 배정되고 4월 29일 인도 일정 셀프 예약 문자가 왔습니다. 파란색이 정말 인기가 없었나 봅니다. (그런데, 소문에 듣자하니.. 파란색은 5월 첫주부터 인도 일정 셀프 예약 문자가 왔었다고 합니다.. 크흑.. ㅠㅠ) 덕분에 기다리고 기다리긴 했지만 아무 준비도 없던 와중에 이제부터 정말 실제 차량을 인도받기 위한 질주가 시작되었습니다. 4월 30일 셀프 인도 예약 완료 문자가 왔고 5월 2일 오전 10시 5분에 전기자동차 구매지원 자격 부여 문자가 오고 오후 3시 5분에 전기차 보조금 지원 대상자 확정 문자를 받았습니다. 사실 기다림의 시간이 제일 힘든건.. 보조금을 못받으면 어떻게 하지?라는 초조함이었습니다. 얼마 안되는 보조금이라고 하더라도 한푼이 아쉬운 입장에서는 정말 필요한 돈이었는데.. 다행히 큰 문제 없이 지원 대상자가 될 수 있었습니다. 그리고 5월 2일 오후 4시 12분에 차량 대금을 후다닥 결제를 진행했습니다. 유투브와 네이버 카페 등을 열심히 읽어두었지만 막상 진행해보니 다른 설명과는 좀 다르게 진행되어서 불안했었는데.. 큰 문제 없이 결제가 완려되었습니다. 이미 차량 인도는 5월 14일로 결정되었기 때문에 이제는 차량 등록에 대한 기다림이 시작되었습니다. 드디어 5월 8일 오후 2시 23분에 등록 대행 비용 및...

나만의 날씨 달력 만들기

일정 확인하면서 날씨 정보가 필요할때 날씨 정보를 별도로 찾아보기 귀찮아서 기존에는 해외 날씨 달력 하나 구독해서 썼었는데.. 아무래도 우리 나라 기상청 데이터와는 차이가 생기는건 어쩔 수 없는지라 아쉬웠는데.. AI랑 바이브 코딩 하다가 이것도 가능하겠다 싶어서 구현한 기상청 데이터를 활용한 캘린더 연동 서비스를 공유합니다.  이 가이드는 사용자가 이용하는 아이폰이나 갤럭시 혹은 구글 캘린더 앱 내에서 기상청의 정확한 10일치 날씨 정보를 일정 형태로 확인할 수 있도록 도와줍니다. 제 API로 원하는 분들마다 달력을 만드는건 불가능해서 본인의 깃헙 저장소를 활용해서 본인만의 캘린더 연동 서비스를 구현할 수 있는 가이드를 만들었습니다.  날씨 달력 자동화 제작 가이드 페이지 주소  -  https://murianwind.github.io/weather-calendar/ 이 방법은 기상청 API 허브에서 직접 데이터를 수집하기 때문에 공신력 있는 정보를 바탕으로 합니다. 단순한 날씨 상태뿐만 아니라 기온과 강수확률 그리고 풍속까지 상세한 예보를 제공합니다. 또한 오늘과 내일의 단기 예보를 넘어 최대 10일까지의 중기 예보를 포함하므로 장기적인 일정 계획 수립에 용이합니다. 한 번 설정해두면 깃허브 액션 기능을 통해 3시간마다 최신 정보로 자동 업데이트되는 시스템을 갖추고 있습니다. 저처럼 외부 미팅이나 출장이 잦아 날씨 변화에 민감한 분들은 캘린더 앱 내에서 모든 정보를 한눈에 파악하기에 좋습니다. 위 가이드 페이지에 접속하면 초보자도 쉽게 따라 할 수 있는 단계별 설명이 준비되어 있습니다. 사용자의 동네 주소에 맞는 좌표 값을 자동으로 계산해주는 도구와 함께 각 단계별 상세한 설정법이 안내되어 있습니다. 본인의 캘린더에 기상청 정보를 연동하여 보다 효율적인 일정 관리를 시작해 보시기 바랍니다. 이미 이런 서비스가 있었다면.. 제 검색 실력의 미천함 때문입니다. 그런데, 정말 이젠 상상만 해도 내가 원하는걸 만들 수 있는 시절이...