给定以下类:
class Logger {
public void log(String someInfo,
String someOtherInfo,
VssNotificationStatus status,
Supplier<String> message)
{}
}
class Asset {
private String name;
private String alias;
Asset(String name, String alias) {
this.name = name;
this.alias = alias;
}
public String getName() {
return name;
}
public String getAlias() {
return alias;
}
}
class ClassUnderTest {
private Logger logger;
ClassUnderTest(Logger logger) {
this.logger = logger;
}
public void methodUnderTest(Asset asset) {
logger.log(asset.getName(), asset.getAlias(), VssNotificationStatus.ASSET_PREPARED, () -> String.format("%s is running", "methodUnderTest"));
}
}
和下面的测试代码:
@RunWith(MockitoJUnitRunner.class)
public class TestA {
private ClassUnderTest clazz;
@Mock
private Logger logger;
@Before
public void setup() {
clazz = new ClassUnderTest(logger);
}
@Test
public void test() {
// given
String info1 = "info1";
String info2 = "info2";
Asset asset = mock(Asset.class);
given(asset.getName()).willReturn(info1);
given(asset.getAlias()).willReturn(info2);
// when
clazz.methodUnderTest(asset);
// then
verify(logger).log(eq(asset.getName()), eq(asset.getAlias()), eq(VssNotificationStatus.ASSET_PREPARED), any());
}
}
在 verify
处失败符合
org.mockito.exceptions.misusing.InvalidUseOfMatchersException:
Invalid use of argument matchers!
0 matchers expected, 1 recorded
我尝试使用 isA(Supplier.class)
, 指定 Supplier.class
在any
方法,但仍然是同样的错误。感觉 Mockito 没有正确地模拟这个方法。
在从简单 String
重构最后一个参数之前,那些失败的测试正确通过了Supplier<String>
的参数.
我正在使用 mockito-core 2.13.0
最佳答案
看起来 Matchers 不喜欢你传入模拟方法而不是使用直接模拟此方法时使用的值。下面的 verify
工作得很好。
verify(logger).log(eq(info1), eq(info2), eq(VssNotificationStatus.ASSET_PREPARED), any());
因此匹配器应该使用真实值而不是从模拟对象中获取它们。
关于java - 采用 Supplier<String> 方法的模拟方法不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47888647/