本示例演示了如何使用Mockito的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
的影响。我们可以使用间谍仅模拟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);
的间谍。 然后,使用internalMethod
,我们将add
存根返回10,将其行为从add
>方法的测试中隔离。然后,主张验证了internalMethod
方法的行为是否正确,给定模拟的
spy
创建间谍。 然后,您使用Mockito的 spy
Mockito.spy(yourObject)
这将创建一个间谍对象when()
。打电话给
MyClass myClass = new MyClass(); MyClass myClassSpy = spy(myClass); when(myClassSpy.internalMethod()).thenReturn(10); // Mock only internalMethod
来定义要模拟的方法的行为;否则,它将称为实际实施。myClassSpy
>internalMethod
在同一类中测试方法时,使用Mockito Spies的潜在陷阱是什么?
internalMethod
修改对象的状态,即使您嘲笑了其返回值。>您通常应该偏爱模拟嘲笑而不是间谍,除非您有一个有力的理由使用Spy。 选择一个间谍时:
有限的控制:
>您对班级的内部方法的控制有限,例如处理具有复杂依赖关系的最终方法或方法时。>>但是,即使在这些情况下,也要仔细考虑上面提到的潜在陷阱。 如果可能的话,与依靠间谍一起解决复杂的依赖性或副作用的工作通常是更好的长期解决方案。 通常,结构良好的设计具有明确的关注点,可以使用模拟进行更简单,更可靠的测试。以上是Mockito间谍:在同一类示例中嘲笑一种方法的详细内容。更多信息请关注PHP中文网其他相关文章!