inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

Business Layer 테스트 (2)

Dto 사용에 관하여

498

박준형

작성한 질문수 39

0

 안녕하세요 강사님 강의 코드를 작성중 궁금한 점이 생겨 질문드립니다.

강의 예제 코드에서는 Dto를 예를 들어 OrderResponse 이런 식으로 Response, Requset를 생성해서 작성하셨는데 실무에서도 이런 방법으로 하시는 지 궁금합니다.

예로 프로젝트가 커지게 된다면 Order에 대해서도 많은 Request, Response가 발생하게 되어 저는 OrderDto 클래스를 두고 OrderDto클래스 속 static inner 클래스로 여러 Dto 클래스를 만들어서 사용했습니다. 이와 같은 방법은 추천 안하시는 지 궁금합니다.
또 Dto클래스를 record로 작성하는 경우도 봤는데 record를 사용하는 방법은 어떠한지 궁금합니다.

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

답변 2

1

박우빈

박준형 님, 안녕하세요!

하나의 OrderDto 클래스 내에 모든 케이스의 상세 DTO를 만드신다고 말씀하신 것 같은데, 그리 추천하는 방식은 아닙니다.
Order라는 어찌보면 거대한 도메인 객체가, 그 필요에 따라 수많은 DTO로 파생될 수 있을텐데요.
각각의 DTO는 그 목적에 맞게 독립적으로 존재하는 것이 객체의 책임에 맞게 DTO를 구성하는 것이라 볼 수 있겠습니다. (DTO의 위치도 포함해서요.)

다만, 특정 DTO 내에서 object로 묶여서 관리되는 하위 데이터가 있다면, 그런 객체는 해당 DTO에 종속되는 객체이므로 내부 클래스로 만들어서 같이 관리할 수 있습니다.

예시를 들어보자면,

  • 아래 DTO는 각자의 위치에서 책임을 가지며 각각 관리하는 것이 좋음

    • Order를 생성하기 위한 OrderCreateRequest

    • Order를 수정하기 위한 OrderUpdateRequest

    • Order를 사용자 화면에 보여주기 위한 OrderDisplayResponse

    • Order를 관리자 화면에 보여주기 위한 OrderAdminResponse

  • 아래와 같은 경우는 DTO내에 inner class로 관리할 수 있음

    • OrderCreateRequest 내의 List<ProductDto> (주문을 생성하기 위한 상품 정보)

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

0

박준형

오 상세한 답변 감사합니다!

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

DTO(Data Transfer Object) 사용법에 관해 궁금하신 것 같네요. 실제로 프로젝트의 요구 사항과 크기에 따라 DTO를 설계하는 다양한 방법이 사용됩니다.

  1. Response, Request 별로 DTO 생성: 실무에서는 각각의 요구 사항에 맞추어 Response, Request DTO를 별도로 생성하는 것이 일반적입니다. 이 방식은 각각의 용도에 맞게 DTO를 세분화하여 관리할 수 있다는 장점이 있습니다.

  2. OrderDto 클래스 내에 static inner 클래스 사용: 프로젝트가 커지고, Order와 관련된 다양한 DTO가 필요할 때, 이러한 구조로 관리하는 것은 좋은 방법일 수 있습니다. 이를 통해 관련 DTO들을 한 곳에 모아서 관리함으로써 유지보수성을 높일 수 있습니다. 다만, 각각의 DTO가 서로 다른 목적을 가지고 있다면, 너무 많은 책임을 하나의 클래스에 부여하는 것으로 볼 수 있으므로 상황에 따라 적절히 선택하는 것이 중요합니다.

  3. DTO 클래스를 record로 작성: Java의 record는 불변성을 가지는, 데이터를 전달하는 용도로 유용한 구조입니다. 모든 필드가 private final이며, equals(), hashCode(), toString() 메소드가 자동으로 생성됩니다. 이러한 특징 때문에 DTO를 정의하기에 아주 이상적일 수 있습니다. 복잡한 로직보다는 단순 데이터 전달 목적으로 사용할 때 record 사용을 고려할 수 있습니다.

    • Spring Data JPA에서는 클래스 기반의 프로젝션을 사용하여 DTO를 정의할 수 있으며, Java Records를 사용해 DTO 타입을 정의하는 것이 이상적이라고 설명하고 있습니다. 중요한 점은 class-based 프로젝션은 JPQL에서는 사용할 수 있지만, native 쿼리에서는 사용할 수 없다는 점입니다.

참고 링크: Spring Data JPA - Reference Documentation

각각의 방법은 상황과 프로젝트의 필요에 따라 장단점이 있으므로, 프로젝트의 유지보수성, 확장성 등을 고려하여 적절한 방법을 선택하는 것이 중요합니다.

private 상수 테스트 관련 질문

0

82

1

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

0

124

2

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

0

159

2

테스트 문서화 질문입니다

0

104

2

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

0

94

2

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

0

100

2

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

0

86

2

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

0

131

2

OrderCreateRequest DTO에 대해서 궁금한점

0

101

2

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

0

154

2

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

0

137

3

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

1

122

2

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

0

133

2

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

0

226

2

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

0

149

2

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

0

183

2

test 용 .yml

0

89

2

throws Exception

0

78

2

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

0

87

2

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

0

171

2

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

0

136

1

tearDown 순서

0

114

2

@Builder 생성자 private

0

133

2

@DisplayName gradle / intellJ

0

91

2