작성
·
323
0
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.
1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)
질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)
[질문 내용]
제가 부트캠프에서 프로젝트를 진행할 때 테스트 코드를 짜긴 했었는데 거의 지식 없이 짰던지라 controller랑 service만 단위 테스트로 짰고 통합 테스트는 안 했습니다.
단위 테스트는 class 단위 어노테이션에 SpringBootTest를 안 쓰는게 맞는건가요? 제가 그렇게 했었거든요.
@SpringBootTest는 통합 테스트일 때만 쓰는 건지, 어떤 경우에 쓰는 어노테이션인 지 궁금합니다.
답변 2
2
지식공유자는 아니지만 답변을 합니다.
@SpringBootTest
가 있으면 통합 테스트일때만 쓰는것인지에 대한 질문을 했습니다.
질문을 반대로 돌려보면 "해당 annotation 이 있으면 단위테스트가 아닌가?"라는 질문을 할 수 있겠습니다.
일단 단위테스트와 통합테스트의 정의부터 명확하게 할 필요가 있다고 생각합니다.
테스트 진영에는 용어에 대하여 서로 명확하게 구분되어 있지는 않기에 다소 주관적인 답변을 합니다.
저는 통합테스트는 단위테스트가 아닌 테스트로 폭 넓게 정의를 합니다.
그러면 단위테스트는 어떠한 테스트인지에 대한 정의를 필요합니다.
클린코드에서는 FIRST 규칙에 대하여 이야기를 합니다.
Fast
Isolated
Repeatable
Self-Validating
Timely
즉, 빠르고 독립적이며 반복할 수 있고, 자체 검증가능하고 적시에 사용 가능해야 합니다.
이런 특징에 반하여 @SpringBootTest
가 붙으면 일단 테스트 수행이 느려집니다.
왜냐하면 스프링 컨테이너를 띄우기 위해 초기 가동을 하게 되기 때문입니다.
따라서 이 annotation 이 있으면 단위테스트 보다는 통합테스트에 가깝다고 판별할 수 있습니다.
아울러 스프링 부트 레퍼런스 문서의 내용을 추가로 공유합니다.
위에서 @SpringBootTest
가 붙으면 일단 테스트 수행이 느려진다고 했습니다.
그래서 스프링부트를 만든 사람은 어떻게 하면 테스트 속도를 조금이라도 빠를까 고민을 하다가 테스트 슬라이스라는 것을 고안했습니다.
@SpringBootTest
를 사용하면 사용하고 있는 여러 의존성을 모두 띄워야 하므로 테스팅 속도가 느릴 수 밖에 없는데 테스트가 필요한 부분만 쪼개서(slice) 테스트를 하면 조금이라도 빠르게 할 수 있기 때문입니다.
자세한 내용은 아래 링크를 참고하세요.
0
안녕하세요, 인프런 AI 인턴입니다.
단위 테스트와 통합 테스트에 대해 이해하시는 데 도움이 될 만한 기존의 Q&A 게시물들을 추천드리겠습니다. 이는 개발자들 사이에서도 자주 혼동되지만, 각 종류의 테스트는 그 목적과 수행 방식이 다릅니다.
SpringBootTest 사용에 대한 이해
@SpringBootTest는 통합 테스트에 주로 사용되는 어노테이션입니다. 이는 스프링 컨테이너를 로드하여 애플리케이션의 모든 빈들을 넣어주고, 실제 애플리케이션과 유사한 환경에서 테스트를 진행할 수 있게 합니다. 단위 테스트에서는 테스팅 대상 클래스의 특정 기능만을 테스트하며, 외부 의존성을 최소화하고 모사(Mock) 객체를 사용하는 경우가 많습니다. 따라서, 단위 테스트에서는 @SpringBootTest
를 사용하지 않는 것이 일반적이며, 대신 필요한 경우 JUnit이나(Mockito 등) 다른 프레임워크를 이용해 모사를 사용할 수 있습니다.
단위 테스트와 통합 테스트의 구별
단위 테스트는 주로 클래스 플랫폼에 한정되며, 하나의 메서드 또는 클래스의 동작을 검증합니다. 이 과정에서 스프링 컨테이너를 굳이 로드할 필요가 없습니다. 반면 통합 테스트는 여러 클래스를 함께 사용하며, 데이터베이스나 실제 애플리케이션의 흐름을 검증하기 위해 @SpringBootTest
를 사용해 스프링 컨테이너를 로드하고 모든 종속성을 포함한 테스트 환경을 제공합니다.
유사한 질문과 답변들이 아래의 링크에 있으니 참고해 보시기 바랍니다:
- @SpringBootTest 어노테이션 없이 순수 자바 코드 테스트를 할 때
- 스프링 부트를 쓰지 않는 단위 테스트의 모범 사례가 궁금합니다.
이 답변들이 rlgus4531님의 이해를 높이는 데 도움이 되셨기를 바랍니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.