Law*_*man 32 java unit-testing mocking mockito
我遇到了我认为可能是Mockito的错误,但是想知道是否有其他人可以解释为什么这个测试不起作用.
基本上,我有两个对象,如下所示:
public class FirstObject {
private SecondObject secondObject;
public SecondObject getSecondObject() { return secondObject; }
}
public class SecondObject {
private String name;
public String getName() { return name; }
}
Run Code Online (Sandbox Code Playgroud)
第一个对象通过注释和before方法进行模拟:
@Mock
FirstObject mockedFirstObject;
@Before
public void setup() {
MockitoAnnotations.initMocks(this);
}
Run Code Online (Sandbox Code Playgroud)
第二个对象在一个方法中被模拟:
public SecondObject setupMockedSecondObject() {
SecondObject secondObject = Mockito.mock(SecondObject.class);
Mockito.when(secondObject.getName()).thenReturn("MockObject");
return secondObject;
}
Run Code Online (Sandbox Code Playgroud)
当thenReturn
包含对此方法的直接调用以设置并获取第二个对象的模拟时,它将失败:
@Test
public void notWorkingTest() {
Mockito.when(mockedFirstObject.getSecondObject()).thenReturn(setupMockedSecondObject());
Assert.assertEquals(mockedFirstObject.getSecondObject().getName(), "MockObject");
}
Run Code Online (Sandbox Code Playgroud)
但是,当同一方法返回的模拟被分配给一个局部变量时thenReturn
,它会起作用:
@Test
public void workingTest() {
SecondObject mockedSecondObject = setupMockedSecondObject();
Mockito.when(mockedFirstObject.getSecondObject()).thenReturn(mockedSecondObject);
Assert.assertEquals(mockedFirstObject.getSecondObject().getName(), "MockObject");
}
Run Code Online (Sandbox Code Playgroud)
我们做错了什么,或者这确实是Mockito的错误/限制?有没有故意这样做不起作用?
Tun*_*aki 39
这确实是Mockito的限制,并在其常见问题解答中引用:
我
thenReturn()
可以内联mock()
吗?不幸的是你不能这样做:
Run Code Online (Sandbox Code Playgroud)when(m.foo()).thenReturn(mock(Foo.class)); // ^
原因是如果我们允许上面的构造,检测未完成的存根将不起作用.我们认为这是框架验证的"权衡"(参见前面的FAQ条目).但是,您可以稍微更改代码以使其正常工作:
Run Code Online (Sandbox Code Playgroud)//extract local variable and start smiling: Foo foo = mock(Foo.class); when(m.foo()).thenReturn(foo);
如上所述,解决方法是将所需的返回值存储在局部变量中,就像您所做的那样.
我理解的方式是,每当你调用它的方法时,Mockito会验证你使用它的用法.在正在进行的存根过程中调用另一个方法时,您将破坏其验证过程.
归档时间: |
|
查看次数: |
34653 次 |
最近记录: |