인프런 커뮤니티 질문&답변

opensesame님의 프로필 이미지

작성한 질문수

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

테스트를 작성하는 마음가짐

환경 통합하기 관련 질문이 있습니다.

23.07.11 21:45 작성

·

298

0

  • WebMvcTest 를 위해 하나의 추상 클래스를 만들고 거기에 필요한 컨트롤러와 모킹한 서비스, 레포지토리들을 추가하셨는데요. 통합 테스트의 관점에서 보면 테스트 컨텍스트가 한번만 뜨기 때문에 좋겠지만 컨트롤러 하나에 대한 단위 테스트를 고려할땐 불필요하게 모킹한 서비스, 레포지토리, 컨트롤러들까지 띄우는데 시간이 더 걸리는데 이건 어떻게 해결 할순 없을까요?

  • 강의 해서 제안 하신 것처럼 현업에서 쓰고 있긴 한데 컨트롤러가 100개가 넘어가니... 하나의 컨트롤러 테스트를 위해 테스트 컨텍스트를 띄우는데 걸리는 시간도 상당히 오래 걸리더라구요. 혹시 좋은 방법이 있다면 알려주시면 감사하겠습니다.

답변 2

1

박우빈님의 프로필 이미지
박우빈
지식공유자

2023. 07. 17. 22:19

안녕하세요, opensesame님! :)

매우 공감하는 문제입니다.
두 가지로 이야기 주셨지만, 결국 하나의 질문 같아서 같이 답변 드리겠습니다.

일단 제가 이런 방법을 선호하는 이유는, 실제로 우리가 테스트를 수행할 때에는 특정 부분의 테스트 1건을 수행하는 경우보다 모든 레이어를 포함한 전체 테스트를 수시로 수행하여 모듈 간 결합 시 문제가 없는지, 추가한 코드가 기존 코드에 영향을 주지 않았는지를 확인하는 일이 많기 때문입니다.
하나의 기능을 개발하는 초기 단계에서는 관련된 일부 테스트만 작성하고 수행하겠지만, 결국 기능을 머지하거나 릴리즈하기 전, CI(지속적 통합) 단계에서는 전체 테스트로 수행하는 경우가 대부분입니다.

그렇기에 어느 정도는 Trade-off가 필요하다고 생각하고, 테스트 1건의 속도와 전체 테스트의 속도를 비교(절대 속도가 아닌 기대값 대비 속도)하였을 때 전체 테스트의 수행 속도를 더 빠르게 구성하는 것이 전체적인 개발 프로세스를 고려했을 때 더 효율적인 방법이라고 생각합니다.

하지만 말씀 주신 문제도 충분히 공감하고 있기에, 한번 생각을 해보자면.. Spring bean validation을 사용하는 대신 POJO 형태로 순수한 validation을 구현하고, ControllerTest를 스프링의 도움 없이 순수한 단위 테스트로만 구성하는 형태도 가능할 것 같습니다.
(하지만 Spring bean validation의 편리함은 또 버리게 될 수밖에 없겠죠..ㅠㅠ)

지금 생각한 방법은 이 정도인데, 또 다른 방법이 있을지는 저도 계속 고민해 보겠습니다.

감사합니다. :)

0

인프런 AI 인턴님의 프로필 이미지

2023. 07. 13. 21:51

안녕하세요, 인프런 AI 인턴이에요. 프로그래밍 관련 질문에 대해 도움을 드릴게요.

테스트 컨텍스트를 한 번만 띄워서 통합 테스트를 하고 싶으시지만, 컨트롤러 단위 테스트에는 불필요하게 모킹한 서비스, 레포지토리, 컨트롤러들이 함께 띄워져 시간이 오래 걸린다고 말씀하셨네요. 이런 경우에는 몇 가지 방법을 고려해볼 수 있습니다.

  1. 테스트 더블(Test Double) 활용: 모킹한 서비스와 레포지토리 대신 가벼운 테스트 더블을 사용하여 테스트를 수행할 수 있습니다. 예를 들어, Mockito 등의 라이브러리를 활용하여 더 가볍고 빠른 모킹을 할 수 있습니다.

  2. 슬라이스 테스트(Slice Test): 통합 테스트 대신 해당 컨트롤러와 관련된 슬라이스(예를 들어, 웹 레이어 슬라이스)만 테스트하는 방법을 고려해볼 수 있습니다. 슬라이스 테스트는 단위 테스트와 통합 테스트 사이의 중간 정도로 구성된 테스트이며, 테스트 컨텍스트의 부하를 상대적으로 줄일 수 있습니다.

  3. 병렬 실행: 대규모 테스트를 수행하는 경우에는 테스트를 병렬로 실행하여 시간을 단축할 수 있습니다. 예를 들어, JUnit의 @TestExecutionListeners를 사용하여 병렬 실행을 설정할 수 있습니다.

  4. 테스트 범위 조정: 단위 테스트의 목적에 따라서는 불필요한 컴포넌트까지 테스트하는 것이 아니라, 해당 컨트롤러와 밀접한 관련이 있는 컴포넌트만 테스트하는 방법을 고려해볼 수 있습니다.

위의 방법들을 적절히 활용하여 테스트 시간을 단축시킬 수 있습니다. 여러 방법 중에서 프로젝트에 맞는 방법을 선택하셔서 사용해보시면 좋겠네요. 추가로 궁금한 점이 있으면 언제든지 물어보세요. 좋은 결과 있기를 바라요. 더 도움이 필요하시다면 다른 질문도 환영합니다. 감사합니다!