inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

Q. private 메서드의 테스트는 어떻게 하나요?

서비스단 private 메서드의 책임을 새로운 객체로 분리 시, repository 의존성 이슈에 대해

212

joon1754

작성한 질문수 1

0

 안녕하세요 우빈님! 강의 너무 잘 듣고 있는 컴공과 대학생입니다!!

이번 목차에서 말씀해주신 내용을 바탕으로 개발한 프로젝트에 테스트코드를 작성하기 위해 리펙토링을 하던 도중, 의문점이 생겨서 질문 드립니다.

강의에서 말씀해 주신 것처럼, 서비스단의 private 메서드가 가지는 책임을 서비스단이 아닌 다른 객체로 책임을 위임하는 것이 더 객체지향적이라 생각해서 저도 똑같은 방식으로 리펙토링을 진행중입니다.

그런데, Layered architecture 에서 서비스단이 레포지토리단에 의존하고 있고, 강의에서와 마찬가지로 레포지토리단에 의존하고 있는 private 메서드인 경우에도 이 메서드의 책임을 서비스가 아닌 다른 객체로 위임하는 것이 과연 괜찮은 건지에 대한 의문이 들었습니다.

Layered architecture 를 따른다면, 서비스단만이 레포지토리에 대한 의존성을 가게끔 하는 것이 맞지않나 라는 생각이고, 또 레포지토리의 변경이 발생했을때, 변경이 확산되는 범위를 서비스단으로 국한시키는 것이 더 좋은 게 아닐까라고 생각합니다.
강사님의 생각이 궁금합니다!! 답변 달아주시면 감사하겠습니다!

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

답변 2

1

박우빈

안녕하세요, joon1754 님!

제가 질문을 이해한 내용은 다음과 같습니다.
Repository에서 private 메서드가 생겼을 때, 이를 다른 객체로 분리하는 것에 대한 이야기 맞을까요?

일단 private 메서드를 객체로 분리하는 것 이전에 고려되어야 할 것은, 해당 private 메서드를 사용하는 public 메서드를 통해 충분히 테스팅을 시도하는 것입니다.

만약 그렇게 하더라도 충분치 않고 뭔가 과도한 책임을 가지고 있는 것 같다면, 그 때 객체 분리를 고려하는 것이죠.

Repository에서 객체(이하 객체 A)를 분리한다고 했을 때, 사실 Service가 그 새로운 객체 A를 알도록 하는 것이 아니라, Repository만 해당 객체를 알고 있도록 구성하면 되지 않을까 싶어요.
즉, Service가 Repository와 A 모두를 의존하는 것이 아니라, Service - Repository - A 와 같은 형태면 될 것 같아요.

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

0

인프런 AI 인턴

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

joon1754님이 제기한 질문은 소프트웨어 설계 방법론과 객체지향 프로그래밍에서의 책임 분리와 관련된 중요한 주제입니다.

먼저, 서비스 레이어에서 private 메서드의 책임을 새로운 객체로 분리하는 것은 객체지향 설계의 원칙을 잘 따르는 방향일 수 있습니다. 이는 코드의 재사용성과 테스트 가능성을 높이는 데 도움을 줄 수 있기 때문입니다. 특히 이로 인해 코드가 더 이해하기 쉬워지고 유지보수가 용이해집니다.

그러나 이 과정에서 Layered architecture를 지속적으로 고려해야 합니다. 서비스 레이어가 레포지토리 레이어와의 인터페이스를 유지하는 것은 레이어드 아키텍처의 중요한 설계 원칙입니다. 레포지토리에 의존하는 로직을 다른 객체로 분리할 때는 해당 객체 역시 서비스 계층의 일부로 간주하는 것이 일반적입니다. 즉, 새롭게 분리한 객체가 서비스 계층 내에서만 사용되도록 하여 의존성을 관리하고, 변경의 영향을 최소화하는 것이 좋습니다.

레포지토리의 변경이 발생했을 때 영향을 미치는 범위를 최소화하려는 joon1754님의 접근은 유지보수를 용이하게 하는 데 있어 매우 중요한 전략입니다. 따라서, 코드를 리펙토링할 때도 이러한 의존성의 경계를 명확히 하여 변경이 다른 레이어로 확산되는 것을 방지하는 것이 중요합니다.

관련하여, 아래의 게시물이 도움이 될 수 있습니다:

  1. 안녕하세요. 객체의 책임 분리와 관련해서 질문이 있습니다.
  2. 강의를 다 들은 후에 오랜 궁금증에 대해 질문드립니다!

위의 링크된 답변에서도 객체의 책임 분리와 서비스-레포지토리 간의 의존성 관리에 대한 인사이트를 얻으실 수 있습니다.

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

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