ResponseDto 위치 질문
175
작성한 질문수 13
ResponseDto 위치 질문이 있습니다.
왜 이건 컨트롤러 reponse 패키지에 넣지 않고, service 패키지에 reponse 객체를 두는건가요 ?
답변 2
0
안녕하세요, bamho 님!
이전 강의 중에 request DTO에 대해, Controller Request에서 Service Request로 변환해준 내용 기억나시나요?
Service 레이어가 Controller 레이어에 의존하지 않도록 DTO 간 변환 처리를 해준 것이었는데요.
마찬가지 이유로 현재 강의 예제의 Response 객체는 Service에서 만들어지기 때문에, Service 레이어 쪽 패키지에 두고 Controller가 이를 자연스럽게 의존하도록 둔 것이라 이해해주시면 됩니다.
레이어 간 의존성의 방향이 한 곳으로만 흐르도록 설계해 준 것이죠.
도움이 되셨기를 바랍니다.
감사합니다. 🙂
0
안녕하세요, 인프런 AI 인턴입니다. bamho님 질문 감사합니다.
ResponseDto의 위치는 프로젝트의 구조와 팀의 컨벤션에 따라 달라질 수 있습니다. 일반적으로 ResponseDto는 각 계층 간의 데이터 전송을 담당하고, 주로 서비스 레이어에서 생성되어 컨트롤러를 통해 클라이언트에게 전달됩니다. 그 이유는 다음과 같습니다:
단일 책임 원칙: 서비스 레이어는 비즈니스 로직을 담고 있으며, 이 로직 처리 결과를 응답 객체로 생성합니다. 이때 ResponseDto는 비즈니스 로직의 출력 형태를 정의하기 때문에, 서비스 패키지 내에 두는 것이 일반적입니다.
계층 간의 결합도 관리: ResponseDto는 서비스 레이어에서 주로 사용되지만, 컨트롤러 레이어 뿐만 아니라 다른 레이어에서도 사용될 수 있습니다. 따라서 특정 레이어에 의존성을 과도하게 만들지 않도록 서비스 패키지에 두는 것이 계층 간의 결합도를 낮추는 데 도움이 됩니다.
재사용성: 프로젝트의 요구사항에 따라 다양한 서비스나 컨트롤러에서 동일한 응답 구조를 필요로 할 수 있습니다. 이 경우, 공통된 응답 객체를 서비스 패키지에서 관리하면 재사용성이 증가합니다.
관련해서 기존에 유사한 논의가 포함된 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
계층 관련 질문이 있습니다.
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





