[Spring] Junit5 Assertions, assertThat()
이 글은 공부를 하면서 알게 된 내용들을 기록하는 글 입니다. 오류나 고쳐야 할 사항들이 있다면 지적 부탁드립니다!
⛅️ Assertions
이전 포스트에서 Junit5를 통해 단위 테스트를 작성해보았다.
단위테스트에서 많이 사용되는 것이 assert(단정) 메서드이다. 이 단정 메서드를 통해 테스트의 결과를 판별할 수 있다.
Assertions.~로 시작하는 메서드를 사용하는데 두 가지 버전 junit와 assertj가 있다.
org.assertj.core.api.Assertions
org.junit.jupiter.api.Assertions
이전에는 junit을 많이 사용했지만, assertj가 등장한 이후에는 assertj 버전을 많이 사용한다.
그 이유는 assertj 버전이 가독성이 더 좋기 때문이다.
assertj는 메서드 체이닝을 지원하기 때문에 문자와 숫자를 비교 할 때에도 가독성을 높일 수 있다.
예를 들어 인스턴스A와 인스턴스B가 같은 인스턴스인지 확인하려는 상황이라고 가정하자.
1. assertEquals(expected, actual); // junit 사용
2. assertThat(actual).isEqualTo(expected); // assertj 사용
이 때, junit을 사용하면 1번을, assertj를 사용하면 2번을 사용할 것이다.
junit을 사용하면 어떤 인자가 검사 대상이고, 어떤 인자가 기댓값인지 알기 어렵다.
반면에 assertj를 사용하면 검사 대상과 기댓값을 쉽게 알 수 있다. 즉, 가독성이 더 좋다.
이번 포스팅에서는 자주 사용했던 단정 메서드들을 정리해보려고 한다.
⛅️ assertj - Assertions.assertThat()
1. .isEqualTo() & .isNotEqualTo()
assertThat(a).isEqualTo(b)는 대상 a가 기댓값 b과 값이 같은지 확인하는 메서드이다.
isEqualTo()는 java의 == 연산과 같은 방식으로 이루어지며, 기댓값이 상수일 때 isEqualTo()를 사용한다.
@Test
void test(){
Member member1 = new Member(1L, "a", Grade.VIP);
Member member2 = new Member(1L, "a", Grade.VIP);
// isEqualTo는 ==, isSameAs는 ref 비교
Assertions.assertThat(member1).isEqualTo(member2);
}
반대로 assertThat(a).isNotEqualTo(b)는 대상 a가 기댓값 b와 값이 같지 않은지 확인하는 메서드이다.
@Test
void test(){
Member member1 = new Member(1L, "a", Grade.VIP);
Member member2 = new Member(2L, "b", Grade.VIP);
// isEqualTo는 ==, isSameAs는 ref 비교
Assertions.assertThat(member1).isNotEqualTo(member2);
}
isEqualTo()와 isNotEqualTo()는 value(값)을 통해 확인하는 단정 메서드이다.
2. .isSameAs() & .isNotSameAs()
assertThat(a).isSameAs(b)는 대상 a가 기댓값 b와 같은 대상인지 주소값을 통해 확인하는 메서드이다.
@Test
void test(){
Member member1 = new Member(1L, "a", Grade.VIP);
Member clone = member1;
// isEqualTo는 ==, isSameAs는 ref 비교
Assertions.assertThat(member1).isSameAs(clone);
}
assertThat(a).isNotSameAs(b)는 대상 a와 기댓값 b의 주소값이 다른지 확인하는 메서드이다.
isEqualTo()에서는 먹혔던 상황이, isNotSameAs()에서는 서로 다르다고 단정하고 있다.
그 이유는 member1과 member2의 값은 같지만, 주소값이 다르기 때문이다.
@Test
void test(){
Member member1 = new Member(1L, "a", Grade.VIP);
Member member2 = new Member(1L, "a", Grade.VIP);
// isEqualTo는 ==, isSameAs는 ref 비교
Assertions.assertThat(member1).isNotSameAs(member2);
}
3. isEqualTo()와 isSameAs()의 차이점
밑은 stackoverflow에서 찾은 isEqualTo()와 isSameAs()의 차이점 질문에 대한 답변이다.
isSameAs()는 두 오브젝트가 same한지 확인 (두 오브젝트가 같은 reference를 가지고 있는지 확인)
isEqualTo()는 두 오브젝트가 equal한지 확인 (두 오브젝트가 같은 value를 가지고 있는지 확인)
따라서 1과 2와 같은 테스트 결과가 나오는 것이다.
4. .isInstanceOf()
assertThat(a).isInstanceOf(B.class)는 대상 a가 클래스 B의 인스턴스인지 확인하는 메서드이다.
@Test
void test(){
Member member1 = new Member(1L, "a", Grade.VIP);
Assertions.assertThat(member1).isInstanceOf(Member.class);
}
5. .isNull() & .isNotNull()
assertThat(a).isNull()은 대상 a가 null인지 확인하는 메서드이다.
@Test
void test(){
Member member1 = null;
Assertions.assertThat(member1).isNull();
}
assertThat(a).isNotNull()은 대상 a가 null이 아닌지 확인하는 메서드이다.
@Test
void test(){
Member member1 = new Member(1L, "a", Grade.VIP);
Assertions.assertThat(member1).isNotNull();
}
⛅️ junit - Assertions.assertThorws()
assertThrows()는 람다식을 실행했을 때, 특정 exception이 발생하는지 확인하는 단정 메서드이다.
예를 들어 빈으로 등록하지 않은 객체에 접근하려고 할 때에 NoUniqueBeanDefinitionException이 발생한다.
이런 로직을 검증하고 싶다면 junit의 assertThrows()를 사용할 수 있다.
// assertThrows(예외.class, () -> 예외가 발생하는 식);
assertThrows(NoUniqueBeanDefinitionException.class, () -> ac.getBean(Member.class));
@Test
void test(){
ApplicationContext ac = new AnnotationConfigApplicationContext(AutoAppConfig.class);
// Member는 스프링 컨테이너에 빈으로 등록되어 있지 않으므로 예외 발생
assertThrows(
NoSuchBeanDefinitionException.class,
() -> ac.getBean(Member.class)
);
}