想要但未被调用:Mockito和Powermock



我继承了一个 Junit 测试,它不再有效。它使用的是PowerMock 1.4.12,Mockito 1.9.0和Junit 4.8.2。 它工作了一段时间,但停止了,我正试图让它再次工作。

Wanted but not invoked:
clerkReviewPackageHelper.addSubmissionQueue(
    <any>,
    <any>,
    <any>,
    <any>
);
-> at icis.cr.approvefilingdetail.CRFilingToQueuesActionTest.test_post_handled_add_submission_queue(CRFilingToQueuesActionTest.java:47)
Actually, there were zero interactions with this mock.
    at icis.cr.approvefilingdetail.CRFilingToQueuesActionTest.test_post_handled_add_submission_queue(CRFilingToQueuesActionTest.java:47)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:592)
    at org.junit.internal.runners.TestMethod.invoke(TestMethod.java:66)
    at org.powermock.modules.junit4.internal.impl.PowerMockJUnit44RunnerDelegateImpl$PowerMockJUnit44MethodRunner.runTestMethod(PowerMockJUnit44RunnerDelegateImpl.java:312)
    at org.junit.internal.runners.MethodRoadie$2.run(MethodRoadie.java:86)
    at org.junit.internal.runners.MethodRoadie.runBeforesThenTestThenAfters(MethodRoadie.java:94)
    at org.powermock.modules.junit4.internal.impl.PowerMockJUnit44RunnerDelegateImpl$PowerMockJUnit44MethodRunner.executeTest(PowerMockJUnit44RunnerDelegateImpl.java:296)
    at org.powermock.modules.junit4.internal.impl.PowerMockJUnit44RunnerDelegateImpl$PowerMockJUnit44MethodRunner.runBeforesThenTestThenAfters(PowerMockJUnit44RunnerDelegateImpl.java:284)
    at org.junit.internal.runners.MethodRoadie.runTest(MethodRoadie.java:84)
    at org.junit.internal.runners.MethodRoadie.run(MethodRoadie.java:49)
    at org.powermock.modules.junit4.internal.impl.PowerMockJUnit44RunnerDelegateImpl.invokeTestMethod(PowerMockJUnit44RunnerDelegateImpl.java:209)
    at org.powermock.modules.junit4.internal.impl.PowerMockJUnit44RunnerDelegateImpl.runMethods(PowerMockJUnit44RunnerDelegateImpl.java:148)
    at org.powermock.modules.junit4.internal.impl.PowerMockJUnit44RunnerDelegateImpl$1.run(PowerMockJUnit44RunnerDelegateImpl.java:122)
    at org.junit.internal.runners.ClassRoadie.runUnprotected(ClassRoadie.java:34)
    at org.junit.internal.runners.ClassRoadie.runProtected(ClassRoadie.java:44)
    at org.powermock.modules.junit4.internal.impl.PowerMockJUnit44RunnerDelegateImpl.run(PowerMockJUnit44RunnerDelegateImpl.java:120)
    at org.powermock.modules.junit4.common.internal.impl.JUnit4TestSuiteChunkerImpl.run(JUnit4TestSuiteChunkerImpl.java:102)
    at org.powermock.modules.junit4.common.internal.impl.AbstractCommonPowerMockRunner.run(AbstractCommonPowerMockRunner.java:53)
    at org.powermock.modules.junit4.PowerMockRunner.run(PowerMockRunner.java:42)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:49)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)

以下是此测试的代码:

@Test
public void test_post_handled_add_submission_queue() throws Exception {
    when(request.getMethod()).thenReturn(BaseCRAction.POST);
    when(sessionInfo.getSubmissionId()).thenReturn(SUBMISSION_ID);
    when(crFilingToQueuesForm.getAction()).thenReturn(null);
    crFilingToQueuesAction.executeProcess(actionMapping, crFilingToQueuesForm, request, response);
    verify(clerkReviewPackageHelper, times(0)).removeSubmissionQueue(null);
    **verify(clerkReviewPackageHelper).addSubmissionQueue(any(String.class), any(String.class), any(String.class), any(String.class));**
    verify(actionMapping).findForward(eq(BaseCRAction.FORWARD_SUCCESS_REDIRECT));
}

这是它从异常中的行调用的方法:

public void addSubmissionQueue(String submissionId, String queueId, String reviewOn, String employeeId) throws BadDBConnection {
Session session = injector.inject();
session.executeNonSelectingCall(clerkReviewPackage.addQueue(submissionId, queueId, reviewOn, employeeId));
session.release();
}

任何帮助将不胜感激!

谢谢

汤姆

看起来executeProcess曾经调用过addSubmissionQueue,但现在不再调用了,但是如果没有executeProcess的代码,很难确定。

如果不适合不调用addSubmissionQueue,您可以简单地删除对该验证行的引用。如果调用它很重要,或者在特定情况下调用它,请编辑测试,以便verify行仅在需要调用该方法的测试用例中发生。

请注意,由于涉及 Mockito,因此您的测试不会调用 addSubmissionQueue 的实际代码,而是调用模拟。在Mockito主页上的示例中阅读有关Mockito如何工作的更多信息。

尝试:

import org.mockito.Mockito;
// ...
Mockito.verify(clerkReviewPackageHelper, Mockito.times(0)).addSubmissionQueue();

您的clerkReviewPackageHelper模拟似乎与您对executeProcess的调用没有任何关联。 它没有传入,并且似乎不会直接或间接地从传递给executeProcess的任何模拟的任何方法调用返回。 因此,期望它的方法之一被executeProcess调用似乎不合理。

您需要做的是查看对executeProcess的调用,并找到调用addSubmissionQueue的对象(如果有)。 没有看到executeProcess的代码,我真的无法提供帮助。 可能是,但没有这样的方法调用,正如@JeffBowman在他的回答中推测的那样。 但也有其他可能性。

  • 如果调用addSubmissionQueue的对象是要executeProcess的参数之一,则应使用clerkReviewPackageHelper作为测试中的相应参数。
  • 如果调用addSubmissionQueue的对象是executeProcess参数之一中的字段,则注入clerkReviewPackageHelper,要么在crFilingToQueuesAction的构造函数中,要么在setter中,要么使用@InjectMocks
  • 如果调用addSubmissionQueue的对象是从对要executeProcess的其他参数之一的方法调用中获得的,则需要使该调用返回clerkReviewPackageHelper。 这可能意味着将该值注入到某个对象中,或者可能意味着在模拟上存根方法调用。 例如,如果您要测试的方法通过调用类似 crFilingToQueuesForm.getHelper() 的行来获取clerkReviewPackageHelper,则需要编写when(crFilingToQueuesForm.getHelper()).thenReturn(clerkReviewPackageHelper);或类似的东西。 当然,结果可能比这更复杂。 没有看到你的代码我就无法分辨。

如果您需要更多帮助,请发布您的executeProcess方法的代码。

我在为控制器方法编写测试用例时也遇到了这个问题,我错过的是将参数传递给我的测试方法,这些参数在设置方法中声明但未初始化,所以我在设置方法中做了它们并修复了问题。

最新更新