본문 바로가기
Spring

[스프링 입문] 회원 리포지토리 테스트 케이스 작성

by 박성민 2021. 8. 29.

개발한 기능을 실행해서 테스트 할 때 자바의 main 메서드를 통해서 실행하거나, 웹 애플리케이션의 컨트롤러를 통해서 해당 기능을 실행합니다. 이러한 방법은 준비하고 실행하는데 오래 걸리고, 반복 실행하기 어렵고 여러 테스트를 한번에 실행하기 어렵다는 단점이 있습니다. 자바는 JUnit이라는 프레임워크로 테스트를 실행해서 이러한 문제를 해결합니다.

회원 리포지토리 메모리 구현체 테스트

package hello.hellospring.repository;

import hello.hellospring.domain.Member;
import java.util.*;

public class MemoryMemberRepository implements MemberRepository {

    ...

    public void clearStore() {
        store.clear();
    }

}

(MemoryMemberRepository.java)

src/test/java 하위 폴더에 생성합니다.

package hello.hellospring.repository;

import hello.hellospring.domain.Member;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.Test;
import java.util.List;
import static org.assertj.core.api.Assertions.assertThat;

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);
    }

}

(MemoryMemberRepositoryTest.java)

  • Optional은 get()으로 해당 객체를 가져올 수 있습니다.
  • 실무에서는 junit의 Assertions보다 assertj의 Assertions를 더 많이 사용합니다.
  • @AfterEach: 한번에 여러 테스트를 실행하면 메모리 DB에 직전 테스트의 결과가 남을 수 있습니다. 이렇게 되면 이전 테스트 때문에 다음 테스트가 실패할 가능성이 있습니다. @AfterEach를 사용하면 각 테스트가 종료될 때 마다 이 기능을 실행합니다.
  • 테스트는 각각 독립적으로 실행되어야 합니다. 테스트 순서에 의존관계가 있는 것은 좋은 테스트가 아닙니다.
  • 실무에서는 모든 테스트 코드가 통과하지 않으면 빌드 자체가 실패하게 됩니다.

테스트 코드를 먼저 작성하고 이후에 구현 코드를 작성하는 것을 테스트 주도 개발(TDD)이라고 합니다. 위에서 작업한 것은 TDD가 아닙니다.

참조

댓글