inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

Practical Testing: 실용적인 테스트 가이드

Persistence Layer 테스트 (1)

도메인 레이어 질문

해결된 질문

139

wisehero

작성한 질문수 33

0

 

안녕하세요. 우빈님 두 가지 질문이 있습니다.

 

  1. 도메인 레이어에 Repository를 넣으셨는데 도메인과 Repository를 같이 두신 이유가 있으신가요?

  2. 현재 도메인 모델과 Jpa Entity를 동일하게 가져가고 있는데 이로인해서 겪으신 문제는 없으신가요? 엄격한 DDD를 위해서라면 도메인 모델을 JPA 엔티티로 쓰는 것이 아니라 JPA 엔티티에 Convert 메서드를 만들어서 처리하고 있더라구요. 이에 대한 우빈님의 생각이 듣고 싶습니다.

 

 

spring tdd jpa mockito 소프트웨어-테스트 junit5

답변 1

2

박우빈

안녕하세요, wisehero 님!

 

1. 도메인 레이어에 Repository를 넣으셨는데 도메인과 Repository를 같이 두신 이유가 있으신가요?

2번 질문에서 말씀하신대로 DDD에서 이야기하는 구조입니다.
Repository는 도메인 모델의 CRUD를 담당하기 때문에, 그 추상적 개념은 도메인 레이어에 있어야 한다고 생각해요.
Repository가 인터페이스라, 실제로 CRUD가 동작하도록 구현하는 구현체는 외부 레이어에서 주입되고 있기도 하고요 ㅎㅎ

 

2. 현재 도메인 모델과 Jpa Entity를 동일하게 가져가고 있는데 이로인해서 겪으신 문제는 없으신가요? 엄격한 DDD를 위해서라면 도메인 모델을 JPA 엔티티로 쓰는 것이 아니라 JPA 엔티티에 Convert 메서드를 만들어서 처리하고 있더라구요. 이에 대한 우빈님의 생각이 듣고 싶습니다.

맞습니다. 엄격한 DDD라면 철저하게 분리하는 것이 맞는데요.
실무에서는 JPA를 사용하기로 한 프로젝트에서 JPA를 다른 기술로 변경하고자 하는 사례가 아직까지는 거의 없기 때문에, 편의상 JPA Entity 모델을 도메인 모델로 사용하는 경우가 많습니다.
Entity와 순수 도메인 모델을 매번 변환해주는 컨버팅 로직을 작성하는 것이 품이 많이 들기 때문이죠.

물론 반대로 팀에 따라서 우리는 이를 엄격하게 지켜보자, 하는 팀도 있어요.
팀원 모두가 동의한다면, 시도해볼 수 있는 좋은 형태라 생각해요.

나름의 트레이드오프라 생각해주시면 될 것 같네요 ㅎㅎ

 

도움이 되셨기를 바랍니다.
감사합니다 🙂

private 상수 테스트 관련 질문

0

87

1

void는 어떻게 테스트하나요..? void로 애초에 코딩하면 안되나요??

0

128

2

커버리지는 어떻게 활용하시는지 궁금합니다.

0

163

2

테스트 문서화 질문입니다

0

107

2

단위테스트 질문이 있습니다

0

96

2

컨트롤러는 모킹을 한 이유가 궁금합니다.

0

106

2

ERD 가장자리에 있는 도메인 테스트 질문

0

90

2

DTO 검증 필드에 대한 테스트 코드 작성은 어디까지?

0

136

2

OrderCreateRequest DTO에 대해서 궁금한점

0

104

2

고전파의 테스트 대역 사용 대상, 공유 의존성

0

157

2

계층 관련 질문이 있습니다.

0

140

3

'코틀린'에서는 빌더를 따로 쓰지 않는데, 이 때는 어떻게 test fixture를 만드시는지 궁금합니다

1

124

2

혹시 update 로직은 어떻게 테스트하나요? (@Setter?)

0

135

2

단위테스트와 통합테스트의 경계가 궁금합니다.

0

235

2

Service+Repository 통합테스트 관련 질문입니다.

0

151

2

OrderControllerDocsTest 작성 해봤는데요. 날짜 형식이 이상하게 나와요

0

186

2

test 용 .yml

0

91

2

throws Exception

0

81

2

카페키오스크 클래스 문의 ,,

0

90

2

Rest docs 문서용 테스트코드를 따로 작성해야 되나요?

0

176

2

테스트 코드에서 필요한 생성자

0

139

1

tearDown 순서

0

116

2

@Builder 생성자 private

0

137

2

@DisplayName gradle / intellJ

0

94

2