개발한 기능을 실행해서 테스트 할 때 자바의 main 메서드를 통해서 실행하거나, 웹 애플리케이션의 컨트롤러를 통해서 해당 기능을 실행합니다. 그러나 이러한 방법은 준비하고 실행하는데 오래 걸리고, 반복 실행하기 어렵고 여러 테스트를 한번에 실행하기 어렵다는 단점이 있습니다.
자바는 JUnit이라는 프레임워크로 테스트를 실행해서 이러한 문제를 해결합니다.
src/test/java 하위 폴더에 repository 패키지를 만들고 MemoryMemberRepositoryTest를 만듭니다.
package hello.hellospring.repository;
import hello.hellospring.domain.Member;
import org.junit.jupiter.api.Test;
import static org.assertj.core.api.Assertions.*;
class MemoryMemberRepositoryTest {
MemberRepository repository = new MemoryMemberRepository();
@Test
public void save() {
Member member = new Member();
member.setName("spring");
repository.save(member);
Member result = repository.findById(member.getId()).get();
//System.out.println("(result = " + (result == member));
//Assertions.assertEquals(null, member);
assertThat(member).isEqualTo(result);
}
}
Member result = repository.findById(member.getId()).get();
검증
new해서 저장한 값과 디비(MemoryMemberRepository의 해쉬맵에 저장한 것을 의미)에서 꺼낸 값과 똑같다면 참입니다.
System.out.println("(result = " + (result == member));
라고 해도 됩니다.
출력하면 true라고 뜹니다. 하지만 이렇게 글자로 계속 볼 수는 없습니다.
그렇기에 org.junit.jupiter.api.Assertions에 있는 assertEquals로 테스트를 합니다.
기대하는 값(expected) result가 현재의 값(actual) member와 같아야합니다.
실행하면 성공합니다.
만약 result 대신에 null이 들어가면 어떻게 될까요?
기대하는 값과 다르다고 에러를 뿜습니다.
하지만 요즘에는 org.assertj.core.api.Assertions를 많이 사용합니다. 좀 더 편하게 사용할 수 있게 해주는 것 입니다. 여기서 assertThat과 isEqualTo을 사용합니다. 이렇게 하면 좀 더 가독성이 좋습니다.
→ 자세히
Assertions는 static import 하는게 좋습니다.
→ 자세히
실행하면 성공합니다.
마찬가지로 isEqualTo(null)이라고 하면 에러를 뿜습니다.
<aside> ❗ 실무에서는 빌드 툴과 엮어서 빌드 툴에서 빌드할 때 테스트 케이스를 통과하지 않으면 다음단계를 못가게 막아버립니다.
</aside>
테스트를 하나 더 추가합니다.
...
@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);
}
...
실행을 해봅니다.
만일 spring2라고 바꾼다면 에러를 뿜을 것 입니다.
<aside> 🌟 [TIP]
Shift + F6
: 이름 일괄 변경
변경 전)
변경 후)
</aside>