- 사용이유 : 테스트 코드에서 객체 생성시 Mokito를 활용하여 임의로 생성해주어 번거로움을 줄일 수 있다.
Mockito.mock() 메소드를 활용하여 만드는 법
@Test
void createLunchService() { // mock() 메소드로 만드는 방법
LunchRepository lunchRepository = mock(LunchRepository.class);
LunchService lunchService = new LunchService(lunchRepository);
assertNotNull(lunchService);
}
- Mockito가 없다면 위 객체를 만들어주는데 필요한 구현체를 모두 구현해 줘야하기때문에 장황한 코드가 발생하지만 Mockito를 활용하여 위처럼 짧고 간결하게 구성할 수 있다.
@Mock 애노테이션을 활용하여 만드는 법
@Mock
LunchRepository lunchRepository;
@Test
void createLunchService() {
LunchService lunchService = new LunchService(lunchRepository);
assertNotNull(lunchService);
}
- 위처럼 선언해주면된다. 하지만, 위 코드는 에러가 발생할 것이다.
- 그 이유는 해당 클래스에 익스텐션을 추가해줘야 하기 때문이다.
@ExtendWith(MockitoExtension.class)
class LunchServiceTest {
```
}
- 하지만(?) 나의 경우엔 익스텐션을 추가해주고도 에러가 발생하는걸 확인했다.
- 그이유는 stackoverflow를 통해 확인해보니 버전의 문제였다..ㅎ
- gradle 에서 mockito-core의 버전을 2.1.0으로 설정해 두었는데 버전을 3.7.0으로 올려 해결하였다.
testImplementation group: 'org.mockito', name: 'mockito-core', version: '3.7.0'
- 수정 후에는 정상 동작하였다.
파라미터로 받아서 사용하는 방법
@Test
void createLunchService3(@Mock LunchRepository lunchRepository) {
LunchService lunchService = new LunchService(lunchRepository);
assertNotNull(lunchService);
}
- 위처럼 활용이 가능하여 각 테스트 코드마다 객체를 따로 사용할 수 있다.
'Language > Java(TestCode)' 카테고리의 다른 글
[TestCode] junit-platform.properties 설정파일 (JUnit5) (0) | 2022.08.29 |
---|---|
[TestCode] @TestMethodOrder 테스트 순서 (JUnit5) (0) | 2022.08.28 |
[TestCode] @TransInstance 테스트 인스턴스 (JUnit5) (0) | 2022.08.27 |
[TestCode] @RepeatedTest, @ParameterizedTest 테스트 반복하기 (JUnit5) (0) | 2022.08.26 |
[TestCode] @interface 커스텀 태그 (JUnit5) (0) | 2022.08.25 |