TDD(Test Driven Development)는 애자일 개발 방식 중 하나로, 테스트 주도 개발이라는 의미를 가진다.
즉, 테스트를 먼저 설계 및 구축한 뒤 테스트를 통과할 수 있는 코드를 짜는 것이다. 코드 작성 후 테스트를 진행하는 지금까지 사용된 일반적인 방식과는 차이가 있다.
Java 진영의 대표적인 Test Framework이다.
단위 테스트(Unit Test)를 위한 도구를 제공한다.
💡 단위 테스트
- 코드의 특정 모듈이 의도한대로 동작하는지 테스트 하는 절차
- 모든 함수와 메소드에 대한 각각의 테스트 케이스를 작성하는 것
💡 통합 테스트
단위 테스트보다 좀 더 큰 단위. 비즈니스 로직 자체를 테스트한다.
어노테이션(Annotation)을 기반으로 테스트를 지원하며, 단정문(Assert)으로 테스트 케이스의 기대값에 대해 수행 결과를 확인할 수 있다.
Spring Boot 2.2버전부터 JUnit 5 버전을 사용한다.
JUnit 5는 크게 Jupiter, Platform, Vintage 모듈로 구성된다. Vintage 모듈은 이전 버전인 JUnit 4를 호환하기 위해 포함되었다.
Annotation | Description |
---|---|
@Test | 테스트용 메소드 |
@BeforeEach | 각 테스트 메소드가 시작되기 전에 실행되어야 하는 메소드 |
@AfterEach | 각 테스트 메소드가 시작된 후 실행되어야 하는 메소드 |
@BeforeAll | 테스트 시작 전에 실행되어야 하는 메소드 (static 처리 필요) |
@AfterAll | 테스트 종료 후에 실행되어야 하는 메소드 (static 처리 필요) |
통합 테스트 용도로 사용되며, @SpringBootApplication을 찾아가 하위의 모든 Bean을 스캔하여 로드한다. 그 후 Test용 Application Context를 만들어 Bean을 추가하고, MockBean을 찾아 교체한다. MockBean에 관한 내용은 아래에 곧 나온다.
JUnit 4에서 @RunWith로 사용되던 어노테이션이 ExtendWith으로 변경되었다. 메인으로 실행될 Class를 지정할 때 쓰는 어노테이션으로, @SpringBootTest를 쓸 때 기본적으로 추가되어있다.
괄호 한에 작성된 매개 변수 클래스만 실제로 로드하여 테스트를 진행한다.
이름에서 보다시피 MVC Test를 하기 때문에, 매개변수를 지정해주지 않으면 @Controller, @RestController, @RestControllerAdvice 등 주로 컨트롤러와 연관된 Bean이 모두 로드된다. 스프링의 모든 Bean을 로드하는 @SpringBootTest 대신 컨트롤러 관련 코드만 테스트할 경우 사용된다.
Controller의 API를 테스트하는 용도인 MockMvc 객체를 주입받고, perform() 메소드를 활용하여 컨트롤러의 동작을 확인할 수 있다. andExpect(), andDo(), andReturn() 등의 메소드를 같이 활용한다.
테스트를 할 클래스에서 주입받고 있는 객체에 대해 가짜 객체를 생성해주는 어노테이션으로, 해당 객체는 실제 행위를 하지 않으며 given() 메소드를 활용하여 가짜 객체의 동작에 대해 정의하여 사용할 수 있다.
spring.test.mockmvc의 설정을 로드하면서 MockMvc의 의존성을 자동으로 주입한다. MockMvc 클래스는 REST API 테스트를 할 수 있는 클래스이다.
필요한 class들을 Configuration으로 만들어 사용할 수 있으며, Configuration Component 클래스도 의존성 설정할 수 있다. Import된 클래스는 주입으로 사용가능하다.
여러 기능을 조합하여 전체 비즈니스 로직이 제대로 동작하는지 확인하는 것을 의미한다.
통합 테스트의 경우, @SpringBootTest를 사용하여 진행한다.
프로젝트에 필요한 모든 기능에 대해 각각 테스트를 진행하는 것
일반적으로 스프링 부트에서는 org.springframework.boot:spring-boot-starter-test 디펜던시만 추가해주면 된다.
참고)
어라운드허브 스튜디오