본문 바로가기
웹개발/스프링

[Inflearn] 주문과 할인 도메인 설계

by dustnn 2025. 1. 30.
<주문과 할인 정책>
- 회원은 상품을 주문할 수 있다.
- 회원 등급에 따라 할인 정책을 적용할 수 있다.
- 할인 정책은 모든 VIP는 1000원을 할인해주는 고정 금액 할인을 적용해달라.(나중에 변경될 수 있다.)
- 할인 정책은 변경 가능성이 높다. 회사의 기본 할인 정책을 아직 정하지 못했고, 오픈 직전까지 고민을 미루고 싶다. 최악의 경우 할인을 적용하지 않을 수도 있다.(미확정)

 

다음과 같은 주문 구조를 가지고 있다.

1. 주문 생성: 클라이언트는 주문 서비스에 주문 생성을 요청한다.

2. 회원 조회: 할인을 위해서는 회원 등급이 필요하다. 그래서 주문 서비스는 회원 저장소에서 회원을 조회한다.

3. 할인 적용: 주문 서비스는 회원 등급에 따른 할인 여부를 할인 정책에 위임한다.

4. 주문 결과 반환: 주문 서비스는 할인 결과를 포함한 주문 결과를 반환한다.

 

 

구현 부분까지 더해서 표현하면 다음과 같다.

 

 

<주문 도메인 클래스 다이어그램>

 

<주문 도메인 객체 다이어그램>

 

 

이렇게 역할과 구현을 분리함으로써 협력 관계를 유지할 수 있다.

여기서 협력 관계를 유지한다는 것은 어떤 구현체를 사용할 것인지에 따라 주문 서비스 변경이 없어도 된다는 뜻이다.