공부 기록
[NEXTSTEP] ATDD 과정 4주차 피드백, 5주차 시작[끝]
타태
2023. 8. 19. 00:14
2023.07.29 - [공부 기록] - [NEXTSTEP] ATDD 과정 3주차 피드백, 4주차 시작
3, 4주차 다시 보기
- Favorite과 Member, Favorite과 Station
- Favorite과 관련 있는 객체
- Member
- Station
- 모든 의존성을 객체 참조로 구현하면?
- 객체간 결합도가 높아짐
- 다른 객체로 탐색이 가능해짐
- DB에서 조회하거나 ORM 사용시 복잡도 증가
- 객체 참조를 피하는 방법
- 간접 참조 (Repository를 통한 탐색)
- 모든 의존성을 간접 참조로 구현하면?
- 객체간 결합도가 낮아짐
- DB에서 조회하기 위해 서비스 레이어 로직 복잡도 증가
- 어떤 상황에 객체 잠조를 할까?
- 함께 생성되고 함께 삭제되는 객체들을 묶어라
- 도메인 제약사항(비즈니스 로직)을 공유하는 객체들을 묶어라
- 가능하면 분리하라
- Favorite과 관련 있는 객체
4주차 다시 보기
- UserDetails가 null이면?
- LoginMember - @AuthenticationPrincipal UserDetails userDetails
- 할인 정책 때문에 경로 조회시 UserDetails가 필요해짐
- @AuthenticationPrincipal(required = false) UserDetails userDetails로 두어서 nullable 처리
- 익명 사용자 객체(extends UserDetails) 를 만들어서 UserDetails이 null이면 반환하도록
- Null Object Pattern
- 요금 정책 설계
- 요구사항
- 요금 계산 기능 구현
- 거리 기준 요금 정책
- 요금 계산 기능 구현
- 단위 테스트
- 거리 기준 요금 정책 단위 테스트 작성
- 경계값 검증을 중점적으로 수행
- 미만, 초과
- 요금 계산 추가 가이드
- 10~ 50km : 900
- 50km > 100원
- 첫번째 계산이 맞음.
- 요구사항
- 요금 계산 기능 구현
- 거리 기준 요금 정책
- 노선 추가 요금 정책 +
- 요금 할인 정책 +
- Chain of Responsibility (책임 연쇄 패턴)
- 서블릿 필터, 인터셉터 등에서 활용 됨
- 문서화 테스트
- 스텝 메서드
- 인수 조건 확인을 위한 각 조건과 단계를 메서드로 분리해서 재활용
- ReqeustSpecification given을 넘겨 받아 처리하면 문서화 테스트에서도 재사용이 가능하여 중복 제거 가능
- 스텝 메서드
- Spring Rest Docs 팁
- 기본적으로 6개의 스니펫이 생성 됨
- Snippet Template 재정의
- request-fileds 기본 템플릿은 패스, 타입, 설명 세가지
- 기본 template 파일을 찾아 기본 골조를 가져와 src/test/resoureces/org/springframework/restdocs/templates/asciidoctor/ 위치에 커스텀하여 추가 가능
- .attribute(key(”optional”).value(”false”))
- 필드 메서드 분리
- anchor를 추가하여 문서 수준에서의 중복 제거 가능
- Snippet Template 재정의
-
- bootJar task 재정의
- 배포 후 문서 접근을 위해 static 디렉토리를 옮겨야 함
- task 재정의를 통해 문서를 static/docs로 옮기도록 설정
- 로컬에서 확인하고 싶을 때 별도의 task를 만들어서 문서를 확인 할 수 있음
- 문서화 테스트만 수행하고 싶을 때 패키지를 분리하여 filter를 통해 documentation 테스트만 수행하도록 설정 할 수 있음
- bootJar task 재정의
ATDD 적용 과정 및 사례
- 사람은 기본적으로 변화를 거부하는 성향
- 팀은 변화를 거부하는 성향이 더 강함
- 대부분의 사람들은 변화에 실패한 경험을 가지고 있음
- 나 혼자 시작하기
- 내가 맡은 기능 구현에 TDD, 리팩터링 적용
- 묵묵히 혼자 진행
- 관심 있는 사람이 생기면 전파
- 리더가 하지 말라고 하면
- 그만둔다
- 나는 많이 성장했기 때문에 절대 손해 보는 장사가 아니다. (ㅋㅋ)
- 나혼자 ATDD
- 토이 프로젝트로 경험 쌓기
- 간단한 기능부터 적용해보기
- 경험해보면서 상황에 맞는 방법 찾기
- 다함께 ATDD( in 개발팀)
- ATDD 개발 프로세스 룰 정하기 (인수조건, 포맷 등)
- 팀 회의와 회고를 통한 피드백
- 살아있는 규칙 정하기
- 기획 & QA와 함께하는 ATDD
- 기획, QA 설득하기(장점 소개)
- 다같이 만드는 요구 사항
- ATDD 적용 전과 후, 장점과 단점
- 테스트가 없는 레거시 환경
- 인수 테스트 먼저 작성하기
- 기존 기능을 검증하는 인수 테스트 먼저 만들기
- 기존 코드를 변경하는 것이 아니기에 팀의 동의 없이 가능
- 인수 테스트 작성의 걸림돌
- 모든 기능에 대해 하려는 마음 버리기
- 쉬운 기능부터 적용하기
- 사전 작업이 많이 없는 기능 (Given 구문이 적은 기능)
- 외부 영향이 없는 기능 (외부 API or 서드 파티 로그인 등)
- 인수 테스트 보호 속에 단위 테스트
- 단위 테스트를 작성하다 보면 테스트하기 어려운 코드를 만나게 됨
- 이 때 리팩터링을 함께 진행해야하는데 이 때 인수 테스트로 기존 기능이 영 향을 받지 않는지 확인하면서 진행
- 성공적인 ATDD 적용을 위해
- 아주 쉽게 시작할 수 있는 부분부터 도입
- 조금씩 상황에 맞게 조정
- 가벼운 프로세스부터 시작, 문제점 발견 시 민첩하게 대응
- 인수 테스트 먼저 작성하기
- 함께하는 ATDD
- 왜 좋은지 설득하기
- 개발 친화적인 용어는 제외하고 설명하기
- 기존 방식과 비교하여 장점 이야기하기
- 함께 만드는 인수 조건 - Discuss 회의
- 기획/개발/QA 함께 인수 조건 회의 참여
- 화면 기반으로 작성할 경우 이해도가 높음
- 모든 인수 조건을 다같이 만드는건 비효율적
- ATDD 적용 전과 후, 장점과 단점
- Common Understaning
- 다른 포지션의 관점은 물론 업무 프로세스도 간접적으로 익힐 수 있음
- 다른 포지션의 진행 상황에 대한 인지와 이해도가 높아짐
- 인수 조건 정의의 어려움
- 문서를 어떻게 관리해야 할 지에 대한 고민이 필요
- 리소스
- (기획/개발) 두번 작업하는 느낌을 받음
- 왜 좋은지 설득하기
728x90
자주 듣는 질문
- 인수 조건은 어떻게 도출하나요?
- 어떤 기준으로 인수 테스트를 작성하면 좋나요?
- 답변 : 팀원 모두의 공통의 이해를 통해 작성되기 때문에 작성 전에 사용자 스토리든 기능이든 요구사항이 있기 마련이다. 스토리부터 작성해가보자.
스토리 맵핑과 함께하는 ATDD
- 어떤 기능들이 먼저 배포 되어야 하는지 우선순위를 정할때 도움이 된다.
- 스토리 맵핑 워크샵
- 작업 나열하기
- 주제 : 오늘 아침에 일어난 일
- 오늘 아침 일어나서 가장 먼저 무엇을 했는지 생각
- 그 다음 무엇을 했는지 포스트잇에 적고 붙인다.
- 반복
- 회사에 들어오기 전까지 했던 일을 적는다.
- 주제 : 오늘 아침에 일어난 일
- 활동(Activity) 구성하기
- 함께 움직여야 하는 작업 묶음 발견
- 큰 목표를 달성하기 위해 함께 움직여야 하는 것으로 보인다면 묶음
- 각각의 Task가 어떤 목적을 갖는지 보여서 세부적인 단위를 조정하기 쉬워 짐
- 스토리 나열하기
- 작업(Task)별로 스토리 형태로 작성하기
- 욕실에서 해야하는 일들
- 아침을 만들기 위해 주방에서 해야하는 일들
- 작업별 세부 사항 및 대안 스토리 고려하기
- 따뜻한 물이 나오지 않는다면?
- 우유나 시리얼이 다 떨어졌다면?
- 세부사항, 대안, 변화 그리고 예외를 스토리맵 본체에 추가
- 작업(Task)별로 스토리 형태로 작성하기
- 우선순위에 따라 그룹 나누기
- 우선순위 기준으로 그룹 나누기
- MVP(성과 기준)를 가장 상단으로 나누기
- 다음 우선순위 기준으로 나누기
- 그룹에 따라 배포 라인을 만들 수 있음
- 작업 나열하기
인수 조건 도출
- 스토리 맵을 통해 구성한 스토리로 시나리오를 생성
- 시나리오를 기반으로 인수조건 작성
마지막 미션 하나를 남겨두고 회사에서 핵심 도메인 리팩토링 및 배포를 진행하는 바람에 끝내지 못했다.
그리고 곧 유스콘 발표가 예정되어 있어서 그 내용이 끝나야 마지막 미션을 할 수 있지 않을까 싶다.
솔직히 핑계이긴 하다. 이 글 적을 시간에 해도 되고 피곤하다고 누워있을 시간 10분씩만 썼어도 했겠지..
과정을 마무리하며 다시금 되새긴다.
과정을 슬기롭게 임하는 방법 - 주변 환경을 정리해 꾸준히 연습할 시간 확보
- 환경 바꾸기
- TV를 보지 않는다
- 스마트폰을 보는 시간을 줄인다.
- 시간을 확보하기
- 퇴근 후 카페로 출근한다
- 야근을 하지 않는다
- 여러분의 의지력을 믿지 마세요. 환경을 바꾸세요.
매일 1~2시간씩 미션 진행하기
- 한번에 모두 구현하기 보다 매일 일정한 시간 투자하는 것이 정말 중요함
- 일주일에 최소 4회 이상 코드리뷰 요청을 보내 코드 리뷰 받기
- 최소 하루에 2시간 이상 투자해야 미션을 완료할 수 있었음
리뷰어 피드백이 상반되는 경우
- 상반되는 의견에 혼란스러워하지 말고 즐기기
- 상반되는 의견에 대해 생각할 수 있는 계기로 생각하기
- 마음껏 생각하고 자신만의 프로그래밍 색깔을 만들기
- 앞선 피드백과 다음 피드백이 상반 될 경우에는 바로 받아들이기 보다는 리뷰어에게 DM을 보내 경험과 의견을 공유하며 피드백을 추가로 얻고 생각의 확장을 하자
지우고 다시 해보기
- 미션의 목적은 기능 구현이 아니라 TDD Cycle 실습 및 경험
- 같은 기능이라 하더라도 두번째 구현할 때는 다른 Cycle을 경험 할 수 있음
- 도메인과 기능에 대한 이해도에 따라 달라지기 때문
정답을 찾기 위해 집착하지 말자
- 미션을 진행하는데 정답은 없다
- 정답을 찾으려는 노력이 오히려 학습을 방해한다
- 현재 상황에서 최선의 답을 끊임없이 찾으려고 노력한다
강의에서 배운 그대로 하지 마세요
- 강의를 통해 여러분의 지평을 넓혔으면 넓힌 그 영역은 질문으로 채우기
- 강의를 듣고 질문이 생겨서 그 질문의 답을 유추해 가는 과정이 필요
P.S.
5주 동안 정리한 내용은 아래에서 복제 가능
https://www.notion.so/NEXTSTEP-ATDD-d090a6795e1c4d3383fda12b9c3c02b6
반응형