티스토리 뷰
import static org.assertj.core.api.Assertions.assertThat;
import com.bdid.bdid.domain.Member;
import java.util.List;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.Test;
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);
}
}
SpringBoot에서는 기본적으로 AssertJ와 JUnit5이라는 테스트용 프레임워크(라이브러리)를 제공한다.
main이 아닌 test에서 할 수 있으며, 만들고싶은 클래스에서 Alt+Shift+T -> Create New Test를 쓰면 된다.
@Test는 이 메서드가 테스트용 메서드라는 것을 표시하는 어노테이션이다.
@AfterEach는 각 테스트가 끝날때마다 자동으로 실행되는 메서드에 쓰이는 어노테이션이다. 예를들어 위 코드에서 클래스 전체를 실행하면 모든 테스트코드가 한번씩 실행되는데, 이때 메모리(Map)을 비우기 위해서 사용한다.
assertThat은 AssertJ에서 제공되는 메서드로, 체이닝 방식으로 구어체 방식으로 편하게 작성할 수 있다.
서비스
import com.bdid.bdid.repository.MemoryMemberRepository;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.Assertions;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
class MemberServiceTest {
// MemberService memberService = new MemberService();
// MemoryMemberRepository repository = new MemoryMemberRepository();
MemberService memberService;
MemoryMemberRepository memberRepository;
@BeforeEach
public void beforeEach(){
memberRepository = new MemoryMemberRepository();
memberService = new MemberService(memberRepository);
}
@AfterEach
public void afterEach(){
memberRepository.clearStore();
}
@Test
void join() {
//given
Member member = new Member();
member.setName("hello");
//when
Long saveId = memberService.join(member);
//then
Member findMember = memberService.findOne(saveId).get();
assertThat(member.getName()).isEqualTo(findMember.getName());
}
@Test
public void duplicateTest(){
//given
Member member1 = new Member();
member1.setName("spring");
Member member2 = new Member();
member2.setName("spring");
//when
memberService.join(member1);
// try{
// memberService.join(member2);
// fail();
// } catch (IllegalStateException e){
// assertThat(e.getMessage()).isEqualTo("이미 존재하는 회원입니다.");
// }
// assertThrows(IllegalStateException.class, () -> memberService.join(member2));
IllegalStateException e = assertThrows(IllegalStateException.class,
() -> memberService.join(member2));
assertThat(e.getMessage()).isEqualTo("이미 존재하는 회원입니다.");
//then
}
@BeforeEach는 비슷하게 매 테스트 전에 실행되어서 의존관계등을 새로 맺을 수 있다.
assertThrows는 JUnit에서 사용하는 검증메서드로, 람다식을 이용하여 예외를 반환하며, 예외의 타입이 일치하는지도 확인할 수 있다.try catch방식보다 훨씬 간결하다.
//given, //when, //then은 test 코드를 작성하기 편하게 하는 일종의 패턴이다. 테스트 시나리오를 명확하게 표현할 수 있다.
테스트 환경설정, 테스트 코드, 검증을 순서대로 작성하면 된다.
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- SQL이란
- 자료구조
- 테이블
- DBMS
- 배열
- 알고리즘
- db오브젝트
- 필드
- DB
- Java
- 레코드
- oracle
- Scanner
- 데이터베이스
- dialect
- APS
- BufferedWriter
- 입출력
- SQL
- db의 역사
- BufferedReader
- StringBuilder
| 일 | 월 | 화 | 수 | 목 | 금 | 토 |
|---|---|---|---|---|---|---|
| 1 | 2 | 3 | 4 | 5 | 6 | |
| 7 | 8 | 9 | 10 | 11 | 12 | 13 |
| 14 | 15 | 16 | 17 | 18 | 19 | 20 |
| 21 | 22 | 23 | 24 | 25 | 26 | 27 |
| 28 | 29 | 30 | 31 |
글 보관함