我正在尝试将我的一个项目转换为groovy,并希望在Mockito中继续使用JUnit4。我有一个测试,它验证当我调用不同的方法时,是否调用了spring-aop-around advice。
这是我的代码:
@Test
void testPointCut() {
//Given
def target = new MainController();
def factory = new AspectJProxyFactory(target);
def aspect = mock(LoggingAspect.class);
factory.addAspect(aspect);
def proxy = factory.getProxy();
when(aspect.log(any(ProceedingJoinPoint))).thenReturn(null);
//When
proxy.index();
//Then
verify(aspect).log(any(ProceedingJoinPoint));
}
当我运行这个时,我得到一个异常:
testPointCut(com.meetupinthemiddle.LoggingAspectTest) Time elapsed: 0.277 sec <<< ERROR!
org.mockito.exceptions.misusing.InvalidUseOfMatchersException:
Invalid use of argument matchers!
0 matchers expected, 1 recorded:
-> at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCallStatic(CallSiteArray.java:56)
This exception may occur if matchers are combined with raw values:
//incorrect:
someMethod(anyObject(), "raw String");
When using matchers, all arguments have to be provided by matchers.
For example:
//correct:
someMethod(anyObject(), eq("String by matcher"));
For more info see javadoc for Matchers class.
at org.codehaus.groovy.runtime.callsite.CallSiteArray.createPogoSite(CallSiteArray.java:147)
at org.codehaus.groovy.runtime.callsite.CallSiteArray.createCallSite(CallSiteArray.java:164)
at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteArray.java:48)
at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:113)
at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:125)
at com.meetupinthemiddle.LoggingAspectTest.testPointCut(LoggingAspectTest.groovy:20)
但是Java中的等效代码工作起来没有问题——有什么想法吗?我认为问题可能与此相同?Grails/Groovy在Mockito中出现错误,但它没有答案!
我认为Mockito在模拟具体的groovy类时遇到了困难。当我模拟一个简单的具体类时,我会遇到同样类型的错误,但当我添加一个接口并模拟该接口时,它就可以工作了。
我认为(正如您链接到的问题的答案中所述)groovy正在拦截该调用,并将其替换为对getMetaClass()的调用。
这方面的可能证据是,当您的方法上显然有匹配项时,错误会显示"期望0个匹配项"。