考虑如下方法签名:
public String myFunction(String abc);
Mockito可以帮助返回与方法接收到的字符串相同的字符串吗?
考虑如下方法签名:
public String myFunction(String abc);
Mockito可以帮助返回与方法接收到的字符串相同的字符串吗?
当前回答
自Mockito 1.9.5+和Java 8以来+
可以使用lambda表达式,例如:
when(myMock.myFunction(anyString())).thenAnswer(i -> i.getArguments()[0]);
其中i是InvocationOnMock的实例。
对于旧版本
您可以在Mockito中创建答案。让我们假设,我们有一个名为MyInterface的接口,其方法为myFunction。
public interface MyInterface {
public String myFunction(String abc);
}
以下是带有Mockito答案的测试方法:
public void testMyFunction() throws Exception {
MyInterface mock = mock(MyInterface.class);
when(mock.myFunction(anyString())).thenAnswer(new Answer<String>() {
@Override
public String answer(InvocationOnMock invocation) throws Throwable {
Object[] args = invocation.getArguments();
return (String) args[0];
}
});
assertEquals("someString",mock.myFunction("someString"));
assertEquals("anotherString",mock.myFunction("anotherString"));
}
其他回答
如果您有Mockito 1.9.5或更高版本,有一种新的静态方法可以为您创建Answer对象。你需要写一些像
import static org.mockito.Mockito.when;
import static org.mockito.AdditionalAnswers.returnsFirstArg;
when(myMock.myFunction(anyString())).then(returnsFirstArg());
或替代地
doAnswer(returnsFirstArg()).when(myMock).myFunction(anyString());
注意,returnsFirstArg()方法在AdditionalAnswers类中是静态的,这是Mockito 1.9.5的新特性;所以您需要正确的静态导入。
我使用了类似的方法(基本上是相同的方法)。有时,让模拟对象返回某些输入的预定义输出是有用的。这是这样的:
private Hashtable<InputObject, OutputObject> table = new Hashtable<InputObject, OutputObject>();
table.put(input1, ouput1);
table.put(input2, ouput2);
...
when(mockObject.method(any(InputObject.class))).thenAnswer(
new Answer<OutputObject>()
{
@Override
public OutputObject answer(final InvocationOnMock invocation) throws Throwable
{
InputObject input = (InputObject) invocation.getArguments()[0];
if (table.containsKey(input))
{
return table.get(input);
}
else
{
return null; // alternatively, you could throw an exception
}
}
}
);
这是一个很老的问题,但我认为仍然相关。此外,接受的答案仅适用于字符串。同时还有Mockito 2.1,一些进口已经改变,所以我想分享我目前的答案:
import static org.mockito.AdditionalAnswers.returnsFirstArg;
import static org.mockito.ArgumentMatchers.any;
import static org.mockito.Mockito.when;
@Mock
private MyClass myClass;
// this will return anything you pass, but it's pretty unrealistic
when(myClass.myFunction(any())).then(returnsFirstArg());
// it is more "life-like" to accept only the right type
when(myClass.myFunction(any(ClassOfArgument.class))).then(returnsFirstArg());
myClass.myFunction如下所示:
public class MyClass {
public ClassOfArgument myFunction(ClassOfArgument argument){
return argument;
}
}
自Mockito 1.9.5+和Java 8以来+
可以使用lambda表达式,例如:
when(myMock.myFunction(anyString())).thenAnswer(i -> i.getArguments()[0]);
其中i是InvocationOnMock的实例。
对于旧版本
您可以在Mockito中创建答案。让我们假设,我们有一个名为MyInterface的接口,其方法为myFunction。
public interface MyInterface {
public String myFunction(String abc);
}
以下是带有Mockito答案的测试方法:
public void testMyFunction() throws Exception {
MyInterface mock = mock(MyInterface.class);
when(mock.myFunction(anyString())).thenAnswer(new Answer<String>() {
@Override
public String answer(InvocationOnMock invocation) throws Throwable {
Object[] args = invocation.getArguments();
return (String) args[0];
}
});
assertEquals("someString",mock.myFunction("someString"));
assertEquals("anotherString",mock.myFunction("anotherString"));
}
使用Java 8,即使使用旧版本的Mockito,也可以创建一个单行答案:
when(myMock.myFunction(anyString()).then(i -> i.getArgumentAt(0, String.class));
当然,这并不像大卫·华莱士(David Wallace)建议的使用AdditionalAnswers那样有用,但如果您想“动态”转换论点,这可能会有用。