본문 바로가기

junit5

[TestCode] @TestMethodOrder 테스트 순서 (JUnit5) - 테스트 코드는 내부적으로 정해져있는 순서에 맞춰 실행되기때문에 여러번 실행을 해도 동일한 순서로 동작한다. (junit 내부 로직 변화에 따라 변할 수 있다) @TestMethodOrder : 테스트 메소드를 원하는 순서에 따라 실행하도록 해준다. @TestMethodOrder(MethodOrderer.OrderAnnotation.class) class LunchTest { ``` @Order(1) @custom @DisplayName("테스트 순서 1") void order1_ex() { System.out.println("첫번째 테스트"); } @Order(3) @custom @DisplayName("테스트 순서 3") void order3_ex() { System.out.println("세번째 .. 더보기
[TestCode] @RepeatedTest, @ParameterizedTest 테스트 반복하기 (JUnit5) @RepeatedTest : 반복 횟수와 반복 테스트 이름을 설정할 수 있다. @RepeatedTest(10) // 10번의 테스트 반복 void repeatTest(RepetitionInfo repetitionInfo) { // 매개변수 통하여 현재 테스트 정보를 얻어옴 System.out.println("현재 " + repetitionInfo.getTotalRepetitions() + " 개의 테스트중 " + // 총 테스트 수 repetitionInfo.getCurrentRepetition() + " 번 실행중"); // 현재 진행중인 테스트 번호 } - 테스트 반복 횟수를 설정하고 매개변수를 통하여 테스트의 정보를 받아올 수 있다. - @RepeatedTest 어노테이션엔 2개의 매개변수를 넣어줄.. 더보기
[TestCode] @interface 커스텀 태그 (JUnit5) Junit5 애노테이션을 조합하여 커스텀 태그를 만들 수 있다. @Target(ElementType.METHOD) // 메서드에 사용이 가능하다. @Retention(RetentionPolicy.RUNTIME) // 애노테이션 정보를 런타임 까지 유지되도록 @Tag("local") // 태그가 local 환경이다. @Test public @interface custom { } - 커스텀태그를 위와 같이 생성하였다. - 위처럼 태그생성 후 테스트 코드 메서드에 이 애노테이션을 사용할 수 있다. @custom // @Test , Tag("local") 어노테이션 생략가능 @DisplayName("커스텀 태그") void custom_tag_ex() { Lunch lunch = new Lunch(); asse.. 더보기
[TestCode] assume 조건에 따라 테스트 실행 (JUnit5) assumeTrue : 조건 - 조건을 정해주고 해당조건에 적합한지 체크한다. @Test @DisplayName("조건에 맞춰 실행") void assume_ex() { Lunch lunch = new Lunch(); String test_env = "LOCAL"; assumeTrue("LOCAL".equals(test_env)); assertTrue(lunch.getLunch("test").equals("Complete"), () -> "실패시 메시지"); } - 현재 테스트 하는 환경을 예로 들어 LOCAL환경인지 개발환경인지 실서버 환경인지 여부를 체크하여 다음에 실행될 테스트 코드를 실행할지 여부를 정할 수 있다. 만일 위 코드에서 LOCAL 환경이 아니라면 다음 테스트는 실행되지 않을것이다. -.. 더보기
[TestCode] assertion 기대값, 참 거짓 확인 (JUnit5) aseertEquals : 실제 값이 기대한 값과 같은지 확인 - 특정 기능을 실행했을경우 반환되는 값이 기대하는 값과 일치하는지 확인할 수 있는 메서드 이다. @Test @DisplayName("점심추천 만들기") void create_lunch() { Lunch lunch = new Lunch(); assertNotNull(lunch); // lunch 가 null이 아닌지 체크 assertEquals("Complete", lunch.getLunch(), "점심 만들기 성공시 Complete 여야한다."); // getLunch라는 메서드 실행시 Complete 가 반환되는지 체크 } - 위와같이 활용할 수 있으며, aseertEquals 사용시에 기대값, 실행함수 두 매개변수 위치가 서로 바뀌어도 .. 더보기
[TestCode] @DisplayName 테스트 이름표시법 (JUnit5) 기본표기 : 실행되는 메서드의 명칭이 출력됨 @MockMvcTest public class HomeControllerTest { @Autowired private MockMvc mockMvc; @Test public void home_view() throws Exception{ mockMvc.perform(get("/")) .andDo(print()) .andExpect(status().isOk()) .andExpect(view().name("index.html")); } } - 보통 위처럼 메서드는 가독성을 위해서 언더스코어 규칙에 따라 주로 작성한다 @DisplayNameGeneration : 언더스코어를 공백으로 치환시켜 출력시켜줌 @MockMvcTest @DisplayNameGeneration(D.. 더보기
[TestCode] Test, Before, After, Disabled (JUnit5) JUnit 5 : 단위 테스트를 하는 자바개발자의 93%가 사용하는 자바 테스팅 프레임워크 - Java 8 버전 이상을 지원함 - Junifer : TestEngine Api 구현체, JUnit 5를 지원함 - Vintage : TestEngine Api 구현체, JUnit 4, 3를 지원함 @Test : 테스트 할 메소드를 지정하는 어노테이션 @Test void create() { Study study = new Study(); System.out.println("create"); } @BeforeAll : 모든 테스트가 실행되기 전 실행될 메소드를 지정 ( static으로 선언되어야 한다 ) @BeforeAll static void beforeAll() { System.out.println("befo.. 더보기