🔍 TDD 란?
- Test-Driven Development의 약자이다.
- 테스트 주도 개발이라는 의미를 가진다.
- 소프트웨어 개발 방법론 중 하나이다. TDD는 개발자가 코드를 작성하기 전에 테스트를 먼저 작성하고, 그 테스트를 통과하는 코드를 작성하는 개발 접근 방식입니다.
🔍 TDD의 목적
💡 코드 품질 향상
- 테스트를 통해 개발자는 코드의 동작을 명확히 이해하고, 예상치 못한 버그를 사전에 발견할 수 있다. 이는 코드의 품질을 높이고 유지보수를 용이하게 한다.
💡 설계 개선
- TDD는 코드를 작은 단위로 분리하고 모듈화 하여 개발하게 한다. 이는 좋은 설계 원칙을 따르고 유연하고 확장 가능한 소프트웨어를 만드는 데 도움을 준다.
💡 빠른 피드백
- TDD에서는 작은 단위의 테스트 케이스를 실행하여 즉시 피드백을 받을 수 있다. 이는 개발자가 문제를 빠르게 파악하고 수정할 수 있게 할 수 있다.
💡 안정성 확보
- TDD는 작은 단위의 테스트 케이스를 작성하여 코드의 안정성을 확보하고, 테스트를 통과하는 코드는 해당 기능이 제대로 작동함을 보장하며, 추가적인 변경이나 리팩토링이 발생해도 안정성을 유지할 수 있다.
🔍 단위 테스트는 무엇인가?
- 프로그램을 작은 단위로 쪼개서 각 단위가 정확하게 동작하는지 검사하는 테스트
- 코드의 특정 모듈(메서드, 클래스) 이 의도된 대로 동작하는지 테스트하는 절차를 의미한다.
- 모든 함수와 메서드에 대한 각각의 테스트 케이스 (Test Case)를 작성하는 것
🔍 통합 테스트는 무엇인가?
- 통합 테스트는 여러 기능을 조합하여 전체 비즈니스 로직이 제대로 동작하는지 확인하는 것을 의미
- 통합 테스트의 경우, @SpringBootTest를 사용하여 진행
- @SpringBootTest는 @springBootApplication을 찾아가서 모든 Bean을 로드하게 됨
- 이 방법을 대규모 프로젝트에서 사용할 경우, 테스트를 실행할 때마다 모든 빈을 스캔하고 로드하는 작업이 반복되어 매번 무거운 작업을 수행하게 된다.
💡 F.I.R.S.T 원칙
- First 원칙은 ‘클린 코드’라는 유명한 책의 저자인 Bob Martin이 처음 제시한 규칙이다. 유닛 테스트를 구성하기 위해서 F.I.R.S.T 원칙을 따른다.
- Fast : 테스트 코드의 실행은 빠르게 진행되어야 한다.
- Independent : 독립적인 테스트가 가능해야 한다.
- Repeatable : 테스트는 매번 같은 결과를 만들어야 한다.
- Self-Validating : 테스트는 그 자체로 실행하여 결과를 확인할 수 있어야 한다.
- Timely : 단위 테스트는 비즈니스 코드가 완성되기 전에 구성하고 테스트가 가능해야 한다.
🔍 JUnit 이란?
- Java 진영의 대표적인 Test Framework
- 단위 테스트(Unit Test)를 위한 도구를 제공한다.
- 어노테이션을 기반으로 테스트를 지원한다.
- 단정문(Assert)을 통해서 테스트 케이스의 기댓값에 대해 수행 결과를 확인할 수 있다.
- Junit5는 크게 Jupiter, Platform, Vintage 모듈로 구성되어 있다.
💻 JUnit 모듈 설명
💡 JUnit Jupiter
- TestEngine API 구현체로 JUnit 5를 구현
- 테스트의 실제 구현체는 별도 모듈 역할을 수행하는데, 그 모듈 중 하나가 Jupiter-Engine
- 이 모듈은 Jupiter API를 사용하여 작성한 테스트 코드를 발견하고 실행하는 역할을 수행
💡 JUnit Platform
- Test를 실행하기 위한 뼈대
- Test를 발견하고 테스트 계획을 생성하는 TestEngine 인터페이스를 가지고 있다.
- TestEngine을 통해 Test를 발견하고, 수행 및 결과를 보고한다.
- 그리고 각종 IDE 연동을 보조하는 역할을 수행 (콘솔 출력 등)
💡 JUnit Vintage
- TestEngine API 구현체로 JUnit 3, 4를 구현하고 있음
- 기존 JUnit 3, 4 버전으로 작성된 테스트 코드를 실행할 때 사용됨
- Vintage Engine 모듈을 포함하고 있음
💻 JUnit Life Cycle Annotation
- JUnit 5는 아래와 같은 테스트 라이프 사이클을 가지고 있다.
Annotation | Description |
@Test | 테스트용 메서드를 표현하는 어노테이션 |
@BeforEach | 각 테스트 메서드가 시작되기 전에 실행되어야 하는 메서드를 표현 |
@AfterEach | 각 테스트 메서드가 시작된 후 실행되어야 하는 메서드를 표현 |
@BeforAll | 테스트 시작 전에 실행되어야 하는 메서드를 표현 (static 처리 필요) |
@AfterAll | 테스트 종료 후에 실행되어야 하는 메서드를 표현 (static 처리 필요) |
'Spring Boot' 카테고리의 다른 글
[Spring Boot] 스프링 부트 알아보기 (0) | 2023.07.24 |
---|---|
[Spring Boot] @RequestParam & @PathVariable 알아보기 (0) | 2023.06.16 |
[Spring Boot] Controller & RestController 알아보기 (0) | 2023.05.21 |
[Spring Boot] @PathVariable 이란 ? (0) | 2023.05.21 |
[Spring Boot] DTO, DAO, VO 개념 정리 (0) | 2022.08.12 |