使用 Mockito,如何拦截 void 方法上的回调对象?

发布于 2024-09-16 12:23:49 字数 358 浏览 8 评论 0原文

我正在使用mockito 来测试遗留的JAAS/LDAP 登录模块。

javax.security.auth.callback.CallbackHandler 接口定义了该函数:

void handle(javax.security.auth.callback.Callback[] callbacks)

我期望 callbacks 包含一个 NameCallback,它是对象需要对其进行操作才能通过测试。

有没有办法有效地模拟这个,或者我最好使用 CallbackHandler 的存根实现?

I'm using mockito to test a legacy JAAS/LDAP login module.

The javax.security.auth.callback.CallbackHandler interface defines the function:

void handle(javax.security.auth.callback.Callback[] callbacks)

I'm expecting callbacks to contain a NameCallback, which is the object that needs to be manipulated to pass the test.

Is there a way to mock this effectively, or would I be better off with a stubbed implementation of CallbackHandler?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

悲喜皆因你 2024-09-23 12:23:49

对于返回 void 的函数,请使用 doAnswer()

doAnswer(...).when(mockedObject).handle(any(Callback[].class));

并且执行拦截的 Answer 必须作为 doAnswer 的参数传入,例如匿名类:

new Answer() {
  public Object answer(InvocationOnMock invocation) {
      Object[] args = invocation.getArguments();
      Mock mock = invocation.getMock();
      return null;
  }}

在这种情况下,args 将是数组 Callback[]

For functions returning void, use doAnswer()

doAnswer(...).when(mockedObject).handle(any(Callback[].class));

And an Answer that performs the interception must go in as the parameter to doAnswer, e.g. as an anonymous class:

new Answer() {
  public Object answer(InvocationOnMock invocation) {
      Object[] args = invocation.getArguments();
      Mock mock = invocation.getMock();
      return null;
  }}

In this case args will be the array Callback[]!

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文