- 회원 도메인 설계
- 회원 도메인 요구사항
1. 회원을 가입하고 조회할 수 있다.
2. 회원은 일반과 VIP 두 가지 등급이 있다.
3. 회원 데이터는 자체 DB를 구축할 수 있고, 외부 시스템과 연동할 수 있다. (미확정)
- 항상 역할과 구현을 분리하여 작성해야 한다.
- 모든 클래스는 인터페이스를 바라보게 코드를 작성해야 한다.
- 위의 그림에서와 같이 회원 저장소의 역할을 생성하고, 구현 클래스가 해당 인터페이스를 바라보도록 설정한다.
1. 주문 생성: 클라이언트는 주문 서비스에 주문 생성을 요청한다.
2. 회원 조회: 할인을 위해서는 회원 등급이 필요하다. 그래서 주문 서비스는 회원 저장소에서 회원을 조회한다.
3. 할인 적용: 주문 서비스는 회원 등급에 따른 할인 여부를 할인 정책에 위임한다.
4. 주문 결과 반환: 주문 서비스는 할인 결과를 포함한 주문 결과를 반환한다.
- 역할과 구현을 분리해서 자유롭게 구현 객체를 조립할 수 있게 설계했다. 회원 저장소는 물론이고, 할인 정책도 유연하게 변경할 수 있다.
- 실제 코드의 경우 위와 같이 구현되어 있다.
- 주문 서비스 구현체에서 객체만 생성해주면 메모리 회원 저장소, DB 회원 저장소 부분과 같이 객체를 변경만 해주면 된다.
- 항상 테스트 코드 작성을 통해 실행에 문제가 없는지 확인하는 것이 중요하다.
출처 : 인프런 - 우아한 형제들 기술이사 김영한의 스프링 완전 정복 (스프링 핵심원리 - 기본 편)
728x90
'Programming > Spring' 카테고리의 다른 글
Spring - 스프링 컨테이너와 스프링 빈 (1) | 2023.06.10 |
---|---|
Spring - 스프링 핵심 원리 이해2 - 객체 지향 원리 적용 (0) | 2023.06.09 |
Spring - Data JPA (0) | 2023.06.07 |
Spring - 객체지향 설계 5원칙 SOLID (SRP, OCP, LSP, ISP, DIP) (0) | 2023.06.07 |
Spring - MVC 기본 동작 원리 (0) | 2023.06.05 |