요구사항과 설계
회원 도메인 요구사항
- 회원가입 및 조회
- 회원은 일반, VIP 두가지 유형이 존재
- 회원 데이터는 자체 DB를 구축할 수 있거나 외부 시스템과 연동될수도 있음(미확정)
회원 도메인 협력 관계
회원 클래스 다이어그램
회원 객체 다이어그램
회원 도메인 설계의 문제점
- 다른 저장소로 변경할떄 OCP 를 준수하는지?
- DIP 가 잘 준수되고 있는지?
- 의존관게가 인터페이스 뿐만 아니라 구현까지 모두 의존하는 문제점이 있음
주문과 할인 도메인 설계
주문과 할인 정책
- 회원은 상품주문 가능
- 회원 등급에 따라 할인 정책 적용
- 할인 정책은 모든 VIP는 1000원을 할인해주는 고정 금액 할인 적용(추후 변경가능)
- 할인 정책은 변경가능성이 높음
주문 도메인 협력, 역할, 책임
- 주문 생성 : 클라이언트는 주문 서비스에 주문 생성을 요청
- 회원 조회 : 할인을 위해선 회원 등급이 필요. 그러므로 주문서비스는 회원 저장소에서 회원을 조회
- 할인 적용 : 주문 서비스는 회원등급에 따라 할인 여부를 할인 정책에 위임
- 주문 결과 반환 : 주문 서비스는 할인 결과를 포함한 주문결과를 반환
실제로는 주문을 DB에 저장하지만 예제이므로 결과 반환만 함
주문 도메인 전체
주문 도메인 클래스 다이어그램
주문 도메인 객체 다이어그램
1번 유형
- 회원을 메모리에서 조회
2번 유형
- 회원을 DB에서 조회
참고
- 스프링 핵심 원리 - 기본편(김영한)