inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

테스트 환경의 독립성을 보장하자

팩토리메서드를 지양하고 생성자 혹은 Builder 패턴을 쓰라는 말씀에 관하여

1412

fpg123

작성한 질문수 6

0

팩토리메서드를 지양하고 생성자 혹은 Builder 패턴을 쓰라는 말씀에 관한 질문입니다.

강의 테스트 환경의 독립성을 보장하자 에 6분대 가량에서 나온 설명입니다. OrderServiceTest.java 에서 createOrderWithNoStock() 메서드입니다

하나의 로직을 가지고 있는 팩토리메서드 보다는 생성자 혹은 빌더패턴을 이용하여 다른 로직의 개입으로부터 격리하여 테스트 환경의 독립성을 보장하자라는 말씀으로 이해했는데요

하지만 처음 강의를 해주실 때 Builder패턴이 가독성을 방해해서 테스트 코드 안에 팩토리메서드를 만드셨는데요. 이번에는 다시 독립성을 위해 Builder 패턴을 쓰는게 좋다고 하시니 헷갈립니다. 결국 가독성 vs 독립성의 트레이드오프 관계로 이해해야하나요? 아니면 여기서 슬기롭게 풀어나갈 수 있는 방법이 있나요?

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

답변 2

3

박우빈

안녕하세요, fpg123님! :)

일단 팩토리 메서드라는 것 자체가, 어떤 의도를 가지고 만들었다는 가정이 있기 때문인데요.
단순히 가독성만 일수도 있지만, 특정 필드는 기본값을 지정한다던지, 혹은 어떤 필수값에 대한 검증을 수행한다던지 하는 추가적인 Rule이 포함될 수 있습니다.
단순히 빌더로 인스턴스를 생성하는 것과는 대비되는 행위인 것이죠.

이런 관점에서 보자면, 테스트 코드를 작성하면서 특정 인스턴스를 생성할 때, 이러한 의도(Rule)가 포함되어 있는 팩토리 메서드를 사용할 경우 테스트에 영향을 주거나, 방해가 될 수 있는 추가 로직이 적용될 수 있습니다.
그렇기 때문에 최대한 테스트 케이스의 오염(환경 구성에 대한 오염)을 방지하고자 테스트 픽스처를 생성할 때에는 순수한 빌더를 사용하자는 의미였습니다.

즉, 프로덕션 코드에서는 가독성 & 의도를 충분히 담아낸 팩토리 메서드를 주로 사용하고, 테스트 시에는 순수한 빌더를 사용하는 형태가 되겠습니다.

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

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴이에요.

팩토리 메서드, 생성자, 빌더 패턴은 객체 생성을 추상화하고 독립성과 가독성을 보장하기 위한 방법입니다. 강의에서는 OrderServiceTest.java의 createOrderWithNoStock() 메서드를 예시로 들어서 설명을 했는데요, 해당 메서드를 팩토리 메서드로 구현하면 독립성을 확보하기 어려울 수 있습니다. 반면에 생성자나 빌더 패턴을 사용하면 다른 로직의 개입을 방지하여 테스트 환경의 독립성을 보장할 수 있습니다.

강의에서는 처음에는 팩토리 메서드가 가독성을 방해할 수 있다고 언급하셨는데, 이 부분이 혼란을 주셨을 것 같아요. 일반적으로 팩토리 메서드는 객체 생성을 캡슐화한 방식으로, 가독성을 향상시킬 수 있습니다. 그렇지만 테스트 환경의 독립성을 보장하기 위해서는 독립성과 가독성 사이의 트레이드오프를 고려해야 합니다.

결국 여기서는 가독성과 독립성 사이에서 적절한 균형을 찾아야 합니다. 가독성을 높이기 위해 팩토리 메서드를 사용하더라도, 테스트 환경의 독립성을 보장하기 위해서는 생성자나 빌더 패턴을 사용하는 것이 좋습니다.

만약 더 슬기롭게 풀어나가려면, 해당 객체의 생성에 따라 테스트 환경의 독립성을 명확하게 분리하는 방법을 사용할 수 있습니다. 예를 들어, 테스트에서 사용하는 객체를 별도의 클래스로 분리하고, 해당 클래스에서 객체를 생성하는 방식을 사용할 수 있습니다. 이렇게 하면 테스트 코드의 가독성과 독립성을 함께 보장할 수 있습니다.

그러나 어떤 방법을 선택하든 결국 가독성과 독립성은 상호 보완적인 요소이기 때문에 완전히 상충해선 안 됩니다. 상황에 따라 적절한 방법을 선택하고, 가독성과 독립성 사이의 균형을 유지하면서 테스트 환경을 구성해주시면 됩니다.

더 궁금한 점이 있다면 언제든지 질문해주세요!

private 상수 테스트 관련 질문

0

83

1

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

0

126

2

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

0

161

2

테스트 문서화 질문입니다

0

106

2

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

0

96

2

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

0

103

2

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

0

90

2

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

0

135

2

OrderCreateRequest DTO에 대해서 궁금한점

0

102

2

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

0

157

2

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

0

139

3

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

1

124

2

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

0

135

2

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

0

230

2

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

0

150

2

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

0

185

2

test 용 .yml

0

91

2

throws Exception

0

80

2

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

0

89

2

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

0

174

2

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

0

138

1

tearDown 순서

0

116

2

@Builder 생성자 private

0

136

2

@DisplayName gradle / intellJ

0

93

2