Study/Spring
[스프링 핵심 원리 - 기본편] 스프링 핵심 원리 이해1 - 예제 만들기(주문과 할인 도메인 설계)
black6765
2022. 12. 3. 17:47
주문과 할인 정책
- 회원은 상품을 주문 가능
- 회원 등급에 따라 할인 정책 적용
- 할인 정책은 모든 VIP는 1,000원을 할인해주는 고정 금액 할인 적용(추후 변경 가능)
- 할인 정책은 변경 가능성이 높음(미확정)
주문 도메인 협력, 역할, 책임
- 주문 생성: 클라이언트는 주문 서비스에 주문 생성을 요청한다.
- 회원 조회: 할인을 위해서는 회원 등급이 필요하다. 그래서 주문 서비스는 회원 저장소에서 회원을 조회한다.
- 할인 적용: 주문 서비스는 회원 등급에 따른 할인 여부를 할인 정책에 위임한다.
- 주문 결과 반환: 주문 서비스는 할인 결과를 포함한 주문 결과를 반환한다.
주문 도메인 전체
- 역할과 구현을 분리해서 자유롭게 구현 객체를 조립할 수 있게 설계했다. 덕분에 회원 저장소는 물론이고, 할인 정책도 유연하게 변경할 수 있다.
주문 도메인 클래스 다이어그램
주문 도메인 객체 다이어그램1
- 클라이언트가 주문 서비스 구현체를 호출하면 MemoryMemberRepository와 FixDiscountPolicy를 구현체로 사용할 것이다.
- 회원을 메모리에서 조회하고, 정액 할인 정책을 지원해도 주문 서비스를 변경하지 않아도 됨
- 역할들의 협력 관계를 그대로 재사용할 수 있음
주문 도메인 객체 다이어그램2
- 클라이언트가 주문 서비스 구현체를 호출하면 DbMemberRepository와 RateDiscountPolicy를 구현체로 사용할 것이다.
- 회원을 메모리가 아닌 DB에서 조회하고, 정률 할인 정책을 지원해도 주문 서비스를 변경하지 않아도 됨
- 역할들의 협력 관계를 그대로 재사용할 수 있음
※ 본 게시글은 인프런의 스프링 핵심 원리 - 기본편(김영한)을 수강하고 정리한 내용입니다.