Mockito로 최종 클래스 모의
Java 테스트 영역에서 최종이 아닌 클래스를 모의하는 것은 종속성을 분리하고 테스트하기 위한 일반적인 관행입니다. 통제된 환경에서 코드를 작성합니다. 그러나 최종 클래스는 조롱과 관련하여 뚜렷한 문제를 제기합니다.
예를 들어 다음 예를 고려해 보겠습니다.
public final class RainOnTrees { public void startRain() {} } public class Seasons { RainOnTrees rain = new RainOnTrees(); public void findSeasonAndRain() {rain.startRain();} }
이 시나리오에는 RainOnTrees라는 최종 클래스가 있고 그것에 의존하는 클래스 시즌. Seasons를 효과적으로 테스트하려면 RainOnTrees를 모의해야 합니다. 그러나 Mockito 버전 1에서는 최종 클래스 모의가 본질적으로 불가능합니다.
Mockito Inline to the Rescue
이러한 한계를 극복하기 위해 Mockito 버전 2에서는 mockito-inline을 도입했습니다. 생성자를 포함하여 정적 및 최종 클래스를 모의할 수 있는 패키지입니다. 이 기능을 활용하려면 Gradle 파일에 다음 종속성을 추가하세요.
testImplementation 'org.mockito:mockito-inline:2.13.0'
Mockito Inline으로 Mocking
mockito-inline 패키지가 추가되면 Mocking final 수업이 간단해집니다:
@ExtendWith(MockitoExtension.class) public class SeasonsTest { @Mock RainOnTrees rainMock; @BeforeEach public void setUp() { MockitoAnnotations.initMocks(this); } @Test public void testFindSeasonAndRain() { Seasons seasons = new Seasons(); // Inject the mock into the Seasons class ReflectionTestUtils.setField(seasons, "rain", rainMock); seasons.findSeasonAndRain(); // Verify that the mocked method was called Mockito.verify(rainMock).startRain(); } }
최종 참고
최종 클래스 구현이 변경되면 실패할 수 있는 취약한 테스트로 이어질 수 있으므로 모의 최종 클래스를 신중하게 사용해야 한다는 점에 유의하는 것이 중요합니다. 가능하다면 종속성 주입을 위한 비최종 클래스를 생성하는 것이 테스트에 선호되는 접근 방식입니다.
위 내용은 Mockito를 사용하여 Java에서 최종 클래스를 어떻게 모의할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!