Spring Boot

TDD - 1

pows1011 2023. 2. 28. 16:33

TDD = 테스트 주도 개발이라는 의미를 가지고 있다.

단순하게 표현하면 테스트를 먼저 설계 및 구축 후 테스트를 통과 할 수 있는 코드를 짜는것,

코드 작성 후 테스트를 진행하는 지금 까지 사용된 일반적인 방식과 다소 차이가 있음.

 

 

애자일 개발 방식 중 하나

  • 코드 설계시 원하는 단계적 목표에 대해 설정하여 진행하고자 하는 것에 대한 결정 방향의 갭을 줄이고자 함
  • 최초 목표에 맞춘 테스트를 구축하여 그에 맞게 코드를 설계하기 때문에 보다 적은 의견충돌을 기대할 수 있다. (방향 일치로 인한 피드백과 진행 방향의 충돌 방지)

 

테스트 코드 작성의 목적

  • 코드의 안정성을 높일 수 있다.
  • 기능을 추가하거나 변경하는 과정에서 발생할 수 있는 Side-Effect를 줄일 수 있다
  • 해당 코드가 작성된 목적을 명화하게 표현 할 수 있다.
    •  코드에 불필요한 내용이 들어가는 것을 비교적 줄일 수 있음

 

JUnit 

JAVA 진영의 대표적인 Test Framework

  • 단위테스트 ( Unit Test )를 위한 도구를 제공
    1. 모든 함수와 메소드에 대한 각각의 테스트 케이스를 작성하는 것
    2. 코드의 특정 모듈이 의도된 대로 동작하는지 테스트하는 절차를 의미
  • 어노테이션 (Annotation)을 기반으로 테스트를 지원
  • 단정문 (Assert)으로 테스트 케이스의 기대값에 대해 수행 결과를 확인 할 수 있음
  • Spring Boot 2.2버전부터 Junit 5버전을 사용
  • Junit 5는 크게 Jupiter,Platform,Vintage모듈로 구성
  1.  

 JUnit LifeCycle Annotation

  1. @Test = 테스트용 메소드를 표현
  2. @BeforEach = 각 테스트 메소드가 시작되기 전에 실행되어야 하는 메소드
  3. @AfterEach = 각 테스트 메소드가 시작된 후 실행되어야 하는 메소드
  4. @BeforeAll = 테스트 시작전에 실행되어야 하는 메소드 ( Static 처리가 필요 )
  5. @AfterAll = 테스트 종료 후에 실행되어야 하는 메소드 ( Static 처리가 필요 )

 

 

 

JUnit Main Annotation

@SpringBootTest

  • 통합 테스트의 용도로 사용됨
  • @SpringBootApplication을 찾아가 하위의 모든 Bean을 스캔하여 로드함
  • 그 후 Test용 Application Context를 만들어 Bean을 추가하고 , MockBean을 찾아 교체

 

@ExtendWith

  • JUnit4에서 @RunWith로 사용되던 어노테이션이 ExtendWith으로 변경됨
  • @ExtendWith는 매인으로 실행될 Class를 지정 할 수 있음
  • @SpringBootTest는 기본적으로 @ExtendWith가 추가되어 있다.

 

 

@WebMvcTest(Class명.class)

  • ()에 작성된 클래스만 실제로 로드하여 테스트를 진행
  • 매개 변수를 지정해주지 않으면 @Controller,@RestController,RestControllerAdivce등 컨트롤러와 연관된 Bean 모두 로드
  • 스프링의 모든 Bean을 로드하는 @SpringBootTest 대신 컨트롤러 관련 코드만 테스트 할 경우 사용

@Autowired about Mockbean

  • Controller의 API를 테스트하는 용도인 MockMvc객체를 주입받음
  • perform() 메소드를 활용하여 컨트롤러의 동작을 확인 할 수 있음 ,andExpect(),andDo(),andReturn()등 메소드를 같이활용

 

@MockBean

  • 테스트할 클래스에서 주입 받고 있는 객체에 대해 가짜 객체를 생성해주는 어노테이션
  • 해당 객체는 실제 행위를 하지 않음
  • given() 메소드를 활용하여 가짜 객체의 동작에 대해 정의하여 사용 할 수 있음

@AutoConfigureMockMvc

  • spring.test.mockmvc 의 설정을 로드하면서 MockMvc의 의존성을 자동으로 주입
  • MockMvc 클래스는 REST API 테스트를 할 수 있는 클래스

@Import

  • 필요한 Class들을 Configuration 으로 만들어서 사용할 수 있음
  • Configuration Component 클래스도 의존성 설정할 수 있음
  • Import된 클래스는 주입으로 사용가능

 

 

통합 테스트

  • 여러기능을 조합하여 전체 비즈니스 로직이 제대로 동작하는지 확인하는 것을 의미
  • @SpringBootTest를 사용하여 진행
  • @SpringBootTest는 @SpringBootApplication을 찾아가서 모든 Bean을 로드하게 됨
  • 이 방법을 대규모 프로젝트에서 사용할 경우, 테스트를 실행할 때마다 모든 빈을 스캔하고 로드하는 작업이 반복되어 매번 무거운 작업을 수행해야 한다.

 

단위 테스트

  • 프로젝트에 필요한 모든 기능에 대한 테스트를 각각 진행하는 것을 의미
  • 일반적으로 스프링 부트에서는 org.springframework.boot:spring-boot-starte-test 디펜던시 만으로 의존성을 모두 가질 수 있음

F.I.R.S.T 원칙

  • Fast : 테스트 코드의 실행은 빠르게 진행되어야 함
  • Independent : 독립적인 테스트가 가능해야 함
  • Repeatable : 테스트는 매번 같은 결과를 만들어야 함
  • Self-Validating : 테스트는 그 자체로 실행하여 결과를 확인 할 수 있어야 함
  • Timely : 단위 테스트는 비즈니스 코드가 완성되기 전에 구성하고 테스트가 가능해야 함
    • 코드가 완성되기 전부터 테스트가 따라와야 한다는 TDD의 원칙을 담고 있음