28

我有一个相当复杂的测试用例,我正在尝试将以下 verify() 添加到:

verify(userService).getUserById(anyLong()).setPasswordChangeRequired(eq(Boolean.TRUE));

这失败并出现此错误:

org.mockito.exceptions.verification.TooManyActualInvocations: 
userService.getUserById(<any>);
Wanted 1 time:
-> at     test.controllers.AuthenticationControllerMockTest.testLookupsExceeded(AuthenticationControllerMockTest.java:404)
But was 4 times. Undesired invocation:

所以我把它改成这样:

verify(userService, atLeastOnce()).getUserById(anyLong()).setPasswordChangeRequired(eq(Boolean.TRUE));

现在它失败了:

java.lang.NullPointerException
    at test.controllers.AuthenticationControllerMockTest.testLookupsExceeded(AuthenticationControllerMockTest.java:404)

因为这是返回null:

verify(userService, atLeastOnce()).getUserById(anyLong())

这似乎令人费解 - 如果我使用默认值(仅一次调用),它会失败,因为它被多次调用,但如果我告诉它多次调用没问题,它会失败,因为它找不到任何调用!

有人能帮忙吗?

4

3 回答 3

26

看起来你们都想模拟userService.getUserById()被调用时发生的事情,并验证setPasswordChangeRequired(true)在返回的对象上被调用。

您可以通过以下方式完成此操作:

UserService userService = mock(UserService.class);
User user = mock(User.class);
when(userService.getUserById(anyLong())).thenReturn(user);

...

// invoke the method being tested

...

verify(user).setPasswordChangeRequired(true);
于 2012-09-26T20:46:28.503 回答
3

添加调用该方法的次数也应该可以解决问题。

verify(aclient, times(2)).someMethod();

于 2021-12-14T20:34:38.760 回答
2

间歇性地得到同样的错误。我们发现我们@Mock错误地在类中添加了两个相同类型的s。


@Mock
SomeClient aClient;

@Mock
SomeClient bClient;


@Test
void test(){
  verify(aClient).someMethod(any());  //passes and fails intermittently
}

删除第二个模拟固定片状。

于 2021-01-07T17:24:41.377 回答