inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

Business Layer 테스트 (1)

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

137

압구정 자발개

작성한 질문수 2

0

개인적인 생각으로는 요청을 받는 부분은 최상단 Presentation Layer 이고 궁극적으로 어떠한 결과를 return 해주는 것 또한 Presentation Layer 이라고 생각합니다.

 

그렇기에 requestDto 는 controller 쪽에 있는게 맞고 responseDto 또한 controller 쪽에 있어야 하는게 맞지 않을까 하는 생각이 듭니다!

혹시 위 부분 어떻게 생각하시는지 궁금합니다.

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

답변 3

0

시안

소스코드 어디서 볼 수 있나요 ?

0

박우빈

안녕하세요, 압구정 자발개 님!

네, 맞습니다. 강의 예제는 간단한 프로젝트이기 때문에 Service에서 반환하는 Response를 그대로 사용했는데, 이대로도 사실 의존 관계 상 큰 문제는 없습니다.
만약 실제 최종 응답에 사용되는 형태와 Service에서 반환하는 데이터의 형태가 달라야 한다면, 각 레이어에 DTO를 별개로 두고 변환 과정을 거쳐야 할 거예요. (강의 중에 Request가 계층을 넘어오면서 변환 과정을 갖도록 했던 것 처럼요.)

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

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 압구정 자발개님, 질문 주셔서 감사합니다.

DTO(Data Transfer Object)의 위치에 대한 논의는 소프트웨어 아키텍처에서 빈번한 주제 중 하나입니다. DTO를 어떻게 배치하느냐에 따라 계층 간 의존성과 응집도가 서로 영향을 미칠 수 있기 때문인데요. 간단한 설명과 함께 기존에 관련된 토론에서 유사한 질문 사례를 추천 드리겠습니다.

  1. Presentation Layer와 의존성: Presentation Layer는 사용자 인터페이스와 직접 연결되어 있으며, 이곳에서 Request와 Response를 처리합니다. 그럼에도 불구하고 Response DTO를 Service Layer에 두는 경우는 종종 있습니다. 이는 비즈니스 로직에서 직접 생성한 데이터를 저장하거나 조작할 DTO를 관리하기 위해서인데요, 비즈니스 로직의 결과물을 한 곳에서 통합 관리함으로써 응답의 일관성을 유지하고, 코드의 재사용성도 높일 수 있습니다.

  2. Controller의 책임 고려: 요청과 응답을 다루는 것이 Controller의 주된 역할이라고 할 수 있지만, 이런 구조만 생각할 경우 Controller가 비대해질 위험이 있습니다. 이 경우 단일 책임 원칙(Single Responsibility Principle)을 위반할 수 있게 되죠. 따라서 각 레이어의 역할을 명확히 하고, Service Layer에서 응답 객체를 만들어 Controller가 이를 사용하는 구조는 유지보수성이나 코드 재사용성에서 유리한 점이 많습니다.

기존에 유사한 논의가 포함된 controller, service용 dto를 분리시키는 것에 대한 질문에서 두 계층 간의 의존성을 어떻게 설정하고 관리할지에 대해 좋은 인사이트를 얻으실 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

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

'코틀린'에서는 빌더를 따로 쓰지 않는데, 이 때는 어떻게 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

36:40 초 부근에 tearDown 없어도 통과하는 이유가 궁금해요

0

180

2