inflearn logo
강의

Khóa học

Chia sẻ kiến thức

Giới thiệu Spring - Học các kỹ thuật truy cập Spring Boot, Web MVC, DB thông qua code

Kiểm thử tích hợp Spring

단위테스트, 통합 테스트, 시스템 테스트...

398

rlgus4531

15 câu hỏi đã được viết

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
제가 부트캠프에서 프로젝트를 진행할 때 테스트 코드를 짜긴 했었는데 거의 지식 없이 짰던지라 controller랑 service만 단위 테스트로 짰고 통합 테스트는 안 했습니다.

단위 테스트는 class 단위 어노테이션에 SpringBootTest를 안 쓰는게 맞는건가요? 제가 그렇게 했었거든요.

@SpringBootTest는 통합 테스트일 때만 쓰는 건지, 어떤 경우에 쓰는 어노테이션인 지 궁금합니다.

 

java spring mvc spring-boot

Câu trả lời 2

2

nhkimnamo3826

지식공유자는 아니지만 답변을 합니다.

@SpringBootTest 가 있으면 통합 테스트일때만 쓰는것인지에 대한 질문을 했습니다.

질문을 반대로 돌려보면 "해당 annotation 이 있으면 단위테스트가 아닌가?"라는 질문을 할 수 있겠습니다.

 

일단 단위테스트와 통합테스트의 정의부터 명확하게 할 필요가 있다고 생각합니다.

테스트 진영에는 용어에 대하여 서로 명확하게 구분되어 있지는 않기에 다소 주관적인 답변을 합니다.

 

저는 통합테스트는 단위테스트가 아닌 테스트로 폭 넓게 정의를 합니다.

그러면 단위테스트는 어떠한 테스트인지에 대한 정의를 필요합니다.

클린코드에서는 FIRST 규칙에 대하여 이야기를 합니다.

  • Fast

  • Isolated

  • Repeatable

  • Self-Validating

  • Timely

즉, 빠르고 독립적이며 반복할 수 있고, 자체 검증가능하고 적시에 사용 가능해야 합니다.

 

이런 특징에 반하여 @SpringBootTest 가 붙으면 일단 테스트 수행이 느려집니다.

왜냐하면 스프링 컨테이너를 띄우기 위해 초기 가동을 하게 되기 때문입니다.

따라서 이 annotation 이 있으면 단위테스트 보다는 통합테스트에 가깝다고 판별할 수 있습니다.

 

아울러 스프링 부트 레퍼런스 문서의 내용을 추가로 공유합니다.

위에서 @SpringBootTest 가 붙으면 일단 테스트 수행이 느려진다고 했습니다.

그래서 스프링부트를 만든 사람은 어떻게 하면 테스트 속도를 조금이라도 빠를까 고민을 하다가 테스트 슬라이스라는 것을 고안했습니다.

@SpringBootTest 를 사용하면 사용하고 있는 여러 의존성을 모두 띄워야 하므로 테스팅 속도가 느릴 수 밖에 없는데 테스트가 필요한 부분만 쪼개서(slice) 테스트를 하면 조금이라도 빠르게 할 수 있기 때문입니다.

자세한 내용은 아래 링크를 참고하세요.

 

0

communityai8509

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

단위 테스트와 통합 테스트에 대해 이해하시는 데 도움이 될 만한 기존의 Q&A 게시물들을 추천드리겠습니다. 이는 개발자들 사이에서도 자주 혼동되지만, 각 종류의 테스트는 그 목적과 수행 방식이 다릅니다.

  1. SpringBootTest 사용에 대한 이해
    @SpringBootTest는 통합 테스트에 주로 사용되는 어노테이션입니다. 이는 스프링 컨테이너를 로드하여 애플리케이션의 모든 빈들을 넣어주고, 실제 애플리케이션과 유사한 환경에서 테스트를 진행할 수 있게 합니다. 단위 테스트에서는 테스팅 대상 클래스의 특정 기능만을 테스트하며, 외부 의존성을 최소화하고 모사(Mock) 객체를 사용하는 경우가 많습니다. 따라서, 단위 테스트에서는 @SpringBootTest를 사용하지 않는 것이 일반적이며, 대신 필요한 경우 JUnit이나(Mockito 등) 다른 프레임워크를 이용해 모사를 사용할 수 있습니다.

  2. 단위 테스트와 통합 테스트의 구별
    단위 테스트는 주로 클래스 플랫폼에 한정되며, 하나의 메서드 또는 클래스의 동작을 검증합니다. 이 과정에서 스프링 컨테이너를 굳이 로드할 필요가 없습니다. 반면 통합 테스트는 여러 클래스를 함께 사용하며, 데이터베이스나 실제 애플리케이션의 흐름을 검증하기 위해 @SpringBootTest를 사용해 스프링 컨테이너를 로드하고 모든 종속성을 포함한 테스트 환경을 제공합니다.

유사한 질문과 답변들이 아래의 링크에 있으니 참고해 보시기 바랍니다:
- @SpringBootTest 어노테이션 없이 순수 자바 코드 테스트를 할 때
- 스프링 부트를 쓰지 않는 단위 테스트의 모범 사례가 궁금합니다.

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

인텔리제이 오류

0

49

1

..

0

111

2

Unused property.....

0

121

2

project JDK is misconfigured

0

164

2

외부 API의 ID 타입(String/UUID)과 내부 도메인의 ID 타입(Long)이 불일치할 때의 설계 정석

0

101

2

단위/통합 테스트 버전충돌 문제

0

102

2

❗️springboot 4.0.2 버전 aspectj dependency 설정❗️

0

254

1

왜 컨트롤러는 변한게 없는데 새로 만든 html 파일이 뜨나요?

0

120

2

윈도우 build test오류 질문

1

118

2

테스트 관련 공부에 대한 조언을 얻고 싶습니다

0

111

2

테스트 실행 시 에러 질문

0

311

1

name을 통한 비교와 객체를 통한 비교

0

81

1

빌드 후 libs 없음

1

148

1

윈도우 gradlew.bat 에러

0

186

1

@PostMapping("/members/new")가 동작하지 않습니다

0

98

1

java static class와 kotlin class

0

89

1

스프링 DB연결

0

144

1

소요 시간

0

96

2

ddl.sql에 빨간 밑줄

1

117

2

welcome page 에러

0

199

3

잘 모르겠습니다.

0

172

2

fail을 똑같이 쳤는데 오류가 발생해요

0

173

2

index.html Welcome page

0

137

1

프로젝트 gradle-groovy ?

0

401

1