我试图测试一个接受使用者
函数的方法,我想用Mockito验证我的lambda表达式只调用了一次。我现在使用的是在最终的单元素数组上使用标志的笨拙方法:
final boolean[] handlerExecuted = {false};
instance.conditionalRun(item -> {
handlerExecuted[0] = true;
item.foo();
});
Assert.assertTrue(
"Handler should be executed.",
handlerExecuted[0]);
似乎应该有一个更好的方法(也许是用Mockito间谍)来验证这个lambda表达式被准确地调用过一次。
其他一些答案提供了替代方法,而不是完全按照我在这里想要的那样做,但这可以通过监视使用者
类本身并让间谍调用您真正想要执行的方法来实现。包装lambda以创建间谍的帮助器方法在这里帮助:
/** Get a spied version of the given Consumer. */
private Consumer<Item> itemHandlerSpy(Consumer<Item> itemHandler) {
// Create a spy of the Consumer functional interface itself.
@SuppressWarnings("unchecked")
Consumer<Item> spy = (Consumer<Item>) Mockito.spy(Consumer.class);
// Tell the spy to run the given consumer when the Consumer is given something to consume.
Mockito.doAnswer(it -> {
// Get the first (and only) argument passed to the Consumer.
Item item = (Item) it.getArguments()[0];
// Pass it to the real consumer so it gets processed.
itemHandler.accept(item);
return null;
}).when(spy).accept(Mockito.any(Item.class));
return spy;
}
然后测试方法变得非常简单:
Consumer<Item> itemHandler = itemHandlerSpy(Item::foo);
instance.conditionalRun(itemHandler);
// This verifies conditionalRun called the Consumer exactly once.
Mockito.verify(itemHandler).accept(Mockito.any(Item.class));
问题内容: 假设我有一个带有两个我不在乎的方法的类,这称为… 下面的两个(仍然来自我的应用程序中的另一个类)都应该通过我的测试: 我不在乎哪个被调用,我只想调用两个变体之一。 在Mockito中,我通常可以执行以下操作: 要么: 是否有一种本地方式说“验证 一个或另一个 至少发生一次”? 还是我必须做一些粗略的事情: 问题答案: 您可以结合使用:
问题内容: 我想模拟存储库中提供的查询,如下所示: 我的方法如下所示: 可悲的是,当我运行测试时,我收到错误消息: java.util.NoSuchElementException:没有值 当我双击错误时,它指向第一个lambda 的方法。 你们中有谁成功嘲笑过lambda表达式并知道我该如何解决我的问题? 问题答案: 无需嘲笑此类深层调用。简单地模拟并让Streaming API正常工作: 然后
但这将返回以下错误: org.mockito.exceptions.misusing.NotaMockException: 传递给verify()的参数类型为$proxy4,不是mock!
问题内容: 我正在使用以下内容。 这是我的utils课 这是被测课程的要点: 这是测试: 以上测试失败。给出的验证模式为空,但根据代码,如果订购成功,则必须发送电子邮件。 问题答案: 如果您要嘲笑行为(类似),则实际上无需调用。也就是说,这是我重写测试方法的动力: 我分为四个部分,以更好地突出显示正在发生的事情: 1.变量 我选择在此处声明任何实例变量/方法参数/模拟协作者。如果它在多个测试中使用
在我的项目中,我使用Guava谓词和函数来使用和筛选和转换一些集合。 在这次迁移中,我需要将guava代码更改为Java8更改。所以,我所做的改变是这样的: 到... 由于,使用方法引用的方法还允许我调试转换过程: 多亏了answer,我注意到我的Eclipse没有显示它应该显示的内容,而peek()的使用有助于显示结果。
在我们的项目中,我们将迁移到Java8,并测试它的新特性。 在我的项目中,我使用Guava谓词和函数,使用和过滤和转换一些集合。 在这次迁移中,我需要更改例如guava代码到Java8的更改。所以,我正在做的改变是: 到... 使用guava调试代码非常符合要求,因为我可以调试每个转换过程,但我关心的是如何调试,例如。 由于,使用方法引用的方法还允许我调试转换过程: 由于回答,我注意到我的Ecli
问题内容: 我正在寻找一种与Mockito进行验证的方法,即在测试过程中与给定的模拟没有任何交互。对于具有验证模式的给定方法,很容易实现这一点,但是我还没有找到完整模拟的解决方案。 我真正想要实现的是:在测试中验证,没有任何内容打印到控制台上。jUnit的总体思路如下: A 有很多方法,我真的不想用单独的验证方法来验证每个方法,而… 因此,我希望,如果有一个简单的解决方案,鉴于我具有良好的测试覆盖
我正在寻找一种方法来验证Mockito,在测试期间没有与给定的模拟进行任何交互。对于具有验证模式的给定方法,很容易实现这一点,但是我还没有找到完整模拟的解决方案。 我真正想要实现的是:在测试中验证,控制台上没有打印任何get。jUnit的总体思路如下: 一个有很多方法,我真的不想用单独的verify来验证每一个方法,对于。。。 所以我希望,如果有一个简单的解决方案,鉴于我有一个良好的测试覆盖率,我