0

我正在尝试验证记录器是否被调用。问题是它返回 void,因此建议我使用 spy 而不是 stub。不幸的是,间谍的行为很古怪(不工作)。理想情况下,我还想删除“味精”并使用匹配器。

代码如下。我也尝试过https://stackoverflow.com/a/24150445/555493给出的方法,但我仍然遇到类似的错误。

//setup spy
val logger = spy(new Logger)
logger.debug(msg)

//call code

//verify
there was one(logger).debug(msg)

我收到此错误:

The mock was not called as expected: 
Argument(s) are different! Wanted:
logger.debug(
 ($anonfun$apply$mcV$sp$1) <function0>
);
-> at HttpHealthCheckSpec$$anonfun$35$$anon$11$$anonfun$11.apply$mcV$sp(HttpHealthCheckSpec.scala:176)
Actual invocation has different arguments:
logger.debug(
 ($anonfun$setupMock$1) <function0>
);
-> at HttpHealthCheckSpec.setupMock(HttpHealthCheckSpec.scala:58)
4

1 回答 1

0

似乎问题在于记录器接受了一个按名称调用参数的字符串。根据https://stackoverflow.com/a/2158709/555493,该解决方案相当难看。不幸的是,Mockito 不能模拟字符串。因此,另一种解决方案是使用 specs2,其中已修复 Mockito 以正确匹配按名称调用的参数。

于 2015-03-09T18:49:37.083 回答