티스토리 뷰
Lv4 : 팀 프로젝트
-> https://github.com/eattogether/hey-together
-> 팀 위키
요구사항
- 지속적 통합 (모든 테스트 통과할때만 배포, 테스트 커버리지 80%, 품질 기준 통과(정적 분석 도구 이용))을 적용해 일정 기준이 넘는 환경으로 배포
- Spring Rest Docs를 이용해 API 문서화
- 프론트는 프레임워크를 사용하기보다 바닐라 JS 기반으로 개발하는게 어떨까?
- 인증은 OAuth2를 기반으로 하면 어떨까? 단 Spring Security 사용X
- 인증을 제외하고 최소 하나 이상의 외부 API와 연동
- 성능을 높이기 위해 자주 사용하지(변하지) 않는 데이터에 대해 (백엔드 부분에) Cache를 적용
- REST 원칙을 지키며 개발 (참고링크)
- Docker 경험
- 기능 구현보다 전체적인 프로세스를 경험해보자. 팀끼리 규칙을 정하고. CI 경험 등
팀 문화
- 이전 레벨2 프로젝트 때와 다른건, 모닝 데일리 미팅 뿐만 아니라 이브닝 데일리도 진행해봤다. 안그래도 기능구현만으로 부족한 시간이라 걱정이 되긴했지만, 지나고보니 꽤 괜찮았다. 모닝 데일리는 가볍게 오늘 뭐할지 계획 정도, 이브닝은 각종 코드와 설계 관련 논의 등 실질적인 기능을 했다.
개발 문화
- 이슈번호를 커밋 메시지 앞에 작성해, 이슈 추적을 좀더 쉽게 할 수 있었다.
- 레벨2때 못써봐서 아쉬웠던 ZenHub을 이번엔 써봤고, 이슈들을 에픽 단위로 묶으니 관리하기 더 좋았다 :)
- 세부 개발 컨벤션 : 다들 레벨2때 나와 비슷한 점을 느꼈는지, 최대한 컨벤션을 세부적으로 정하려 다들 노력했다.
팀 목표
다들 계속 해왔던 스프링 서버 기능 구현 외에, 부가적으로 경험해보고 싶은 목표들로 위와 같이 리스팅했다.
하지만 프로젝트 진척이 더뎌지며 이들 중 실제로 사용해본 것은 절반정도, 그것도 제대로 써봤다고 하려면 목표의 20%도 안되는 것 같아 아쉬움이 있다.
프로젝트에서 개인적인 목표
-
인프라 기술 경험해보기 (실패)
- 프로젝트를 맨 처음 시작할 때, 내 욕심은 그저 도커와 젠킨스를 경험해보는 것이었다. 코스동안 이제까진 인프라보다 거의 코드쪽을 만져왔기 때문에.
- 결과적으로 이번에도 인프라 기술을 경험해보진 못했다. 표면적인 이유는 당시 개인 역할 분배할 때, 내가 페어와 함께 도메인쪽을 한창 하고있어서 다른 팀원이 인프라 역할을 가져갔다.
- 좀더 원론적으론, 프로젝트 전반적으로 계획 수립과 진행을 제대로 하지 못했고, 때문에 필수 기능을 구현하는 것만으로 시간이 지연되어 인프라 등의 부가 기술을 적용할 시간이 부족했다. 이와 관련해선 뒤에서 다시 기술.
-
기술 문서 공유 활발히 하기 (성공)
- 이 부분은 레벨2 프로젝트때에 비해 좀더 만족스럽다. 초반부터 적극적으로 기술 문서를 작성하자고 어필했고, 먼저 작성해서 위키에 공유하니 다들 감사하게도 따라주시더라.
- 결국 기술 문서를 공유하는 이유는, 남이 긴 시간을 들여 학습한 내용을 다른 사람은 좀더 빠른 시간에 흡수하기 위함이다. 프로젝트 기간이 좀더 충분했다면, 기술 문서 공유 뿐 아니라 '매일 코드리뷰 or Merge'하며 서로 구두로 이야기하는 시간이 더 많았으면 하는 아쉬움이 있긴하다.
그래서 경험한건?
구현하며 인상깊었던 부분들 + 삽질
인수테스트 디렉토리 분리 위키
foo
(커스텀 테스트 디렉토리)를 생성했다면gradle.build
에서fooImplementation
으로 dependency 추가 가능하다. <- 처음알았을때 컬쳐쇼크였다, testImplementation의 test가 그 test였다니..- 의존성 주입을 깔끔하게 못했다. gradle 문법도 알아야하는듯..
Spring Rest Docs 위키 블로그
- 인수테스트 디렉토리 분리와 함께, 첫 주차에 다른 조들 사이에서 가장 먼저 적용하고 이를 기술문서로 공유해, 다른 팀들에게 도움을 줄 수 있어 좋았다.
- Spring MVC + WebTestClient 조합에서
bindToApplicationContext()
orbindToServer()
의 이슈가 발생했다.- 여전히 의문.
bindToApplicationContext()
가 안되야하는데 왜 됬던 걸까 ?_?
- 여전히 의문.
ATDD와 섣부른 관계 매핑 & 복잡한 도메인 블로그
- 문제점 1. 가장 크고 복잡한 도메인 Article을 가장 먼저 구현하려 했던 점
- 문제점 2. Article과 관련한 엔티티들을 너무 빨리 관계매핑하려했던 점
@OneToMany List<?> 상황에서 LazyInitializationException 예외와 해결방안 블로그
- OSIV 설정을 꺼놔서 터진것이었다. 다시 스프링부트 기본값인 true로 바꿔 해결할수있었고, 추가로 OSIV를 꺼도 문제가 발생하지않도록 DTO를 사용해 노출하기로 결정했다.
JPA 양방향 순환참조 문제 블로그
- 당시엔 Json관련 어노테이션을 붙여 순환참조를 끊어 문제를 해결했다가, 이후 DTO를 사용하는 방식으로 변경해 애초의 원인 해결.
OneToMany와 양방향 남용 블로그
- 도메인 관계매핑의 복잡성과 함께 프로젝트를 지연시켰던 주된 이슈들 중 다수는 일대다 관계와 양방향에서 비롯된 경우가 많았다. 프로젝트 중반을 넘긴 시점에 이들을 모두 해제하고 구조를 변경했더니, 이후로 이슈가 줄어들었고 코드도 깔끔해질 수 있었다.
- 쓰지말라는건 왜 쓰지말아야하는지, best practice가 왜 존재하는지 몸으로 느낄 수 있었다.;;
정리 : 그래서 우리는 왜 실패했는가?
- 팀원들의 개인사정으로 인한 초반 부재
- 초반에 각자 개인사로 너무 많이 (돌아가며) 빠졌다. (사실상 5주중에서 2주가 날아가버렸다) 아쉽지만 어쩔수없었던 것 같다.
- 특정 기능에 대해 한 사람이 담당했던 것
- 프론트를 한사람에게 맡겼더니, 그 사람에게 일이 생겨 작업이 지연될 때 다른사람이 대체하기 어려웠다.
- 다음엔 한 부분에 최소한 2명이상 분배해, 백업 멤버를 두자.
- 핵심 도메인 모델 구축의 지연
- ATDD와 익숙하지 않은 점 + JPA 관계매핑의 복잡도로, 가장 핵심이 되는 도메인 모델들이 삽질과 변경을 계속하다 뒤늦게 정착됬다.
- 핵심이 되는 부분인 만큼, 다들 각자 역할이 있어도 이를 우선순위로 올리고 초반에 다함께 해결했어야 했다.
- 불분명한 요구사항 확립 + 마일스톤을 적절히 세우지 못했다
- 처음에 개발주제와 세부 요구사항에 대한 이야기를 충분히 하지 못했다. 이를 문서화하지도 못했다. -> 레벨2 프로젝트때와 비교해, 애초에 주제가 불분명해 충분한 이야기를 나눠야 했었음
- 초반에 팀원들이 모이지 못한것과 관련
- 그리고 애초에 짧은 기간에 과한 목표를 잡았다. 기본 서비스 기능 구현 외에, 팀원들의 목표였던 비기능 기술들까지 다루려면, 처음써보는 뷰는 포기해야했음. 차라리 슬랙봇 프로젝트처럼.
- 의욕 불충분
- 취업과 프로젝트 지속성X으로 팀원들의 사기 저하
- 개인에게 있어서 프로젝트의 우선순위가 밀렸다 -> 규율 위의 자율이 필요했음, 리더의 부재로 각자의 책임이 불분명
기타 : 사소한 것들
- 인텔리제이 문제로 커스텀 테스트 디렉토리를 인식하지못해, mark as로 명시적으로 테스트 폴더로 바꿔줘야 했다.
- 공식 Docs가 시키는대로 하자. 다른 경로가 아닌
src/docs/asciidoc/example.adoc
의 경로에 adoc 파일을 생성해야한다. - 블로그 : TIL - JPA 'GenerationType.AUTO'와 Mockito 등
- 회고의 중요성 : 프로젝트가 끝날 즈음, 최종 회고를 했다. 서로 마음을 털어놓고 감정을 공유하며, 서로를 좀더 이해할 수 있었다. 속도 시원했다.
팀 차원에서 새롭게 도입해본 기술들
- 인수테스트 디렉토리 분리
- Spring Rest Docs
- JWT 인증
- Vue.js
우리도 도입해볼만했던 다른 팀의 기술 및 정책
- AOP 로깅
- 프로젝트 모듈화
- SonarQube
- 로젠트리, https://docs.sentry.io/
- DbUnit
'우아한 테크코스' 카테고리의 다른 글
우아한 테크코스) Lv3 - 7~9주차 [DI 구현] 미션 후기, 코드 리뷰 (0) | 2019.11.16 |
---|---|
우아한 테크코스) Lv3 - 5~6주차 [JDBC 구현, 대용량 데이터 처리] 미션 후기, 코드 리뷰 (0) | 2019.10.20 |
우아한 테크코스) Lv3 - 남은 학습주제, 회고 (0) | 2019.10.13 |
우아한 테크코스) Lv3 - 3~4주차 [MVC 구현] 미션 후기, 코드 리뷰 (0) | 2019.10.13 |
우아한 테크코스) Lv1, 2 - 나에 대한 피드백 정리, 회고 (from 미니프로젝트, 페어프로그래밍) (0) | 2019.10.03 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
TAG
- dfs
- JPA
- graph
- 리버싱
- 회고
- 우아한 테크코스
- Android Studio
- Data Structure
- Java
- queue
- FRAGMENT
- git
- 웹해킹
- 프로그래머스
- reversing
- brute-force
- webhacking.kr
- bfs
- javascript
- socket
- Stack
- Android
- Algorithm
- mysql
- sort
- C
- 개발자
- OneToMany
- 해외여행
- Vo
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
글 보관함