개발한 기능을 실행해서 테스트 할 때 자바의 main 메서드를 통해서 실행하거나, 웹 애플리케이션의 컨트롤러를 통해서 해당 기능을 실행한다.
이러한 방법은 준비하고 실행하는데 오래 걸리고, 반복 실행하기 어렵고 여러 테스트를 한번에 실행하기 어렵다는 단점이 있다.
그래서, 자바는 JUnit이라는 프레임워크로 테스트를 실행해서 이러한 문제를 해결한다.
hello-spring/src/main/test/java/hello/hellospring/repository/MemoryMemberRepositoryTest.java
package hello.hellospring.repository;
import hello.hellospring.domain.Member;
import org.assertj.core.api.Assertions;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.Test;
import java.util.List;
import static org.assertj.core.api.Assertions.*;
public class MemoryMemberRepositoryTest {
MemoryMemberRepository repository = new MemoryMemberRepository();
@AfterEach
public void afterEach() {
repository.clearStore();
} //각 테스트가 끝날때마다 해당 테스트를 지워줌.
@Test
public void save() {
Member member = new Member();
member.setName("spring");
repository.save(member);
Member result = repository.findById(member.getId()).get();
assertThat(member).isEqualTo(result);
}
@Test
public void findByName() {
Member member1 = new Member();
member1.setName("spring1");
repository.save(member1);
Member member2 = new Member();
member2.setName("spring2");
repository.save(member2);
Member result = repository.findByName("spring1").get();
assertThat(result).isEqualTo(member1);
} //저장된 것과 꺼낸 값이 같아야 됨.
@Test
public void findAll() {
Member member1 = new Member();
member1.setName("spring1");
repository.save(member1);
Member member2 = new Member();
member2.setName("spring2");
repository.save(member2);
List<Member> result = repository.findAll();
assertThat(result.size()).isEqualTo(2);
}
}
테스트 클래스는 public일 필요가 없음.
테스트 메소드 이름은 좀 더 직관적이기 위해서 한글로도 작성 가능함.
*@AfterEach : 각 테스트가 끝날 때 마다 실행되는 메서드를 정의함.
import org.junit.jupiter.api.Test; 을 설정 후, 테스트를 원하는 객체를 생성하고, 메서드 위에 @Test 어노테이션을 붙이면 해당 메서드를 테스트할 수 있음.
@Test의 순서는 보장되지 않음.
테스트는 서로 의존관계 없이(순서에 관계없이) 결과가 보장되어야 함.
import static org.assertj.core.api.Assertions.*; 를 설정하면 Assertions 없이 assertThat으로 호출되는 값이 저장되어 있는 값과 같은지 확인 가능함.
*테스트 주도 개발(TDD: Test Driven Development) : 테스트 케이스를 먼저 만들고 그 테스트에 맞는 기능을 만듬.