기능을 사용하여 클래스 내에서 특정 방법을 조롱하는 방법을 보여줍니다. : spy
MyClass
라는 클래스가 있다고 가정 해 봅시다.
public class MyClass { public int add(int a, int b) { return a + b + internalMethod(); } private int internalMethod() { return 5; // This is the method we want to isolate } public int anotherMethod() { return 10; } }
add
를 조롱 할 수 있습니다. 그런 다음 internalMethod
를 사용하여 <🎜 🎜>를 스텁하여 10을 반환하여 internalMethod
메소드의 테스트에서 동작을 분리합니다. 그런 다음 어설 션은 조롱 된 <🎜 🎜>. 즉, 특정 방법을 선택적으로 조롱하면서 대부분의 방법의 실제 구현을 유지할 수 있습니다. 이를 사용하려면
import org.junit.jupiter.api.Test; import org.mockito.Mockito; import static org.junit.jupiter.api.Assertions.assertEquals; import static org.mockito.Mockito.spy; import static org.mockito.Mockito.when; public class MyClassTest { @Test void testAddMethod() { MyClass myClassSpy = spy(MyClass.class); when(myClassSpy.internalMethod()).thenReturn(10); // Mock the internal method int result = myClassSpy.add(2, 3); assertEquals(15, result); // 2 + 3 + 10 = 15 } }
MyClass
스파이 객체 가 생성됩니다. when(myClassSpy.internalMethod()).thenReturn(10);
에 대한 호출은 10을 반환합니다. 다른 모든 방법은 실제 구현을 사용합니다. 이를 통해 나머지 클래스와 분리하여 특정 방법의 동작을 대상 테스트 할 수 있습니다. 조롱하려는 메소드의 동작을 정의하려면 internalMethod
add
동일한 클래스 내에서 방법을 테스트 할 때 모의에 비해 모키토 스파이를 사용하는 잠재적 인 함정은 무엇입니까? add
internalMethod
스파이는 실제 구현과의 상호 작용 테스트의 이점을 제공하지만 몇 가지 잠재적 인 함정을 소개합니다.의도하지 않은 부작용 : 스파이가 원래 구현을 유지하기 때문에, 새롭지 않은 메소드의 부작용은 여전히 발생합니다. 이로 인해 테스트 중에 예기치 않은 동작이 발생하고 테스트중인 장치를 분리하기가 어려워집니다. 가 객체의 상태를 수정하면 반환 값을 조롱하더라도 수정이 여전히 발생합니다.
internalMethod
타이트 커플 링 : 스파이는 테스트와 클래스의 구현 세부 사항간에 더 엄격한 커플 링을 초래할 수 있습니다. 기능이 동일하게 유지 되더라도 구현의 변경 사항은 테스트를 중단 할 수 있습니다.
위 내용은 Mockito Spy : 동일한 클래스 예제에서 메소드 조롱의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!