[Spring Boot] 스프링부트 (IntelliJ)/Spring boot

[Spring Boot] Junit 사용해보기

류도토리 2024. 2. 26. 17:39

테스트를 하다가 이런 에러가 발생했다.

 

 

package hello.hellospring.repository;

import hello.hellospring.domain.Member;
import org.assertj.core.api.Assertions;
import org.junit.jupiter.api.Test;

import java.util.List;

import static org.assertj.core.api.Assertions.*;

class MemoryMemberRepositoryTest {
    MemoryMemberRepository repository = new MemoryMemberRepository();

    @Test
    public void save(){
        Member member = new Member();
        member.setName("string");

        repository.save(member);

        Member result = repository.findById(member.getId()).get();
        // System.out.println("result = " + (result == member));

        // Assertions.assertEquals(member, result);

        // Assertions.assertThat의 Assertions는 static import로 생략 가능
        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);
    }
}

 

위 처럼 작성하여 클래스를 전체 실행을 해보면 findByName 메서드가 에러가 뜬다

이유 - findAll()메서드에서 member1과 member2가 만들어져 있기 때문

 

Junit은 각각 메서드가 독립적으로 돌아갈 수 있게 만들어야 한다.

메서드가 하나하나 끝날 때마다 클리어를 해줘야 한다.

 

store를 클리어 시켜주는 메서드를 만들어주고,

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

 

 

테스트 클래스에 아래 메서드를 추가해준다.

@AfterEach // 메서드가 끝날때마다 동작시켜주는 메서드라고 알려주는 어노테이션
public void afterEach(){
    repository.clearStore();
}

 

이렇게 하면 같은 변수를 만들더라도 메서드가 끝날 때마다 공용 데이터를 지워주기 때문에 중복 에러가 뜨지 않는다.