해결된 질문
작성
·
730
·
수정됨
0
@Test
void 회원가입() {
//given
Member member = new Member();
member.setName("hello");
//when
Long saveId = memberService.join(member);
//then ( 우리가 save한게 repository에 있는 것이랑 같아?를 찾는 로직)
Member findMember = memberService.findOne(saveId).get();
assertThat(member.getName()).isEqualTo(findMember.getName());
//Assertions.assertThat(member.getName()).isEqualTo(findMember.getName());
}
위 회원가입 테스트 코드에서 처음에는 static으로 import 안해서
(1) >>>>
Assertions.assertThat(member.getName()).isEqualTo(findMember.getName());
이렇게썼다가
다시 import static org.assertj.core.api.Assertions.*;하면서 아래 로직으로 바꾸는 이유가 궁금합니다.
(2) >>>>
assertThat(member.getName()).isEqualTo(findMember.getName());굳이 바꾸는 이유가 무엇인지 궁금합니다.
오로지 가독성때문에 그러는것인가요?
그렇다면 처음부터 import static~으로는 import가 불가능한것인지도 궁금합니다!
(1)처럼 쓴다음에 (2)로 다시 바꾸면서 import를 static으로 변경하는 방법만 있는지 궁금해서요.
답변 1
1
안녕하세요, 인프런 AI 인턴이에요.
Assertions 클래스의 assertThat 메서드는 org.assertj.core.api.Assertions.assertThat 메서드입니다. import static을 사용하여 assertThat 메서드를 static으로 선언하면 실제 사용할 때에는 클래스 이름을 붙이지 않고 메서드를 바로 사용할 수 있게 됩니다. 그렇기 때문에 가독성을 높일 수 있습니다.
하지만 import static을 사용하지 않는다면 클래스 이름을 매번 붙여서 메서드를 사용해야 합니다. 이 경우 코드가 길어지고 가독성이 떨어질 수 있습니다.
따라서 import를 static으로 변경한 것은 코드를 간결하게 만들고 가독성을 높이기 위한 것입니다. 그리고 처음부터 import static으로 사용하지 않았던 이유는 개발자나 팀의 컨벤션, 스타일 가이드 등의 이유일 수 있습니다. 개발자나 팀에 따라서 다르게 사용하는 경우도 있을 수 있습니다.
결론적으로, import static을 사용하여 Assertions 클래스의 assertThat 메서드를 static으로 선언하면 가독성을 높일 수 있으며, 처음부터 import static으로 사용하지 않은 이유는 개발자나 팀의 선호나 스타일 가이드에 따른 것입니다.