【问题标题】:JUnit5 tapestry messages NoSuchMethodErrorJUnit5挂毯消息NoSuchMethodError
【发布时间】:2019-03-29 11:29:28
【问题描述】:

我使用 Tapestry 消息和 Mockito 进行了一些测试:

@Test
void messageTest(@Mock Messages msg1) { 
    Set<String> res = new HashSet<>();
    res.add("1");
    res.add("2");
    Mockito.lenient().when(msg1.getKeys()).thenReturn(res);
    // ...

这在单独运行测试时工作正常,但是在 IntelliJ 中运行包(或整个项目)的所有测试时,我得到以下异常:

java.lang.NoSuchMethodError: org.apache.tapestry5.ioc.Messages.getKeys()Ljava/util/Set;

测试失败。我很确定这不是因为 Mockito,因为我之前没有使用过它并且遇到了同样的问题。


我知道我提供的示例不足以复制问题(我目前无法复制问题)。这个问题在我的项目中无处不在(即即使我在另一个模块中创建了一个测试类),但不在它之外。此外,Messages 的其他方法(例如lenient().when(messages.format("")).thenReturn(null);)不会出现此问题。

另请注意,问题以较短的方式持续存在:

when(messages.getKeys());

(我用import static org.mockito.Mockito.when;)。

但是,整个例外情况可能对您有所帮助:

java.lang.NoSuchMethodError: org.apache.tapestry5.ioc.Messages.getKeys()Ljava/util/Set;

    at de.....MessagesUtilImplTest.getKeyToMessage(MessagesUtilImplTest.java:31)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.junit.platform.commons.util.ReflectionUtils.invokeMethod(ReflectionUtils.java:532)
    at org.junit.jupiter.engine.execution.ExecutableInvoker.invoke(ExecutableInvoker.java:115)
    at org.junit.jupiter.engine.descriptor.TestMethodTestDescriptor.lambda$invokeTestMethod$6(TestMethodTestDescriptor.java:171)
    at org.junit.platform.engine.support.hierarchical.ThrowableCollector.execute(ThrowableCollector.java:72)
    at org.junit.jupiter.engine.descriptor.TestMethodTestDescriptor.invokeTestMethod(TestMethodTestDescriptor.java:167)
    at org.junit.jupiter.engine.descriptor.TestMethodTestDescriptor.execute(TestMethodTestDescriptor.java:114)
    at org.junit.jupiter.engine.descriptor.TestMethodTestDescriptor.execute(TestMethodTestDescriptor.java:59)
    at org.junit.platform.engine.support.hierarchical.NodeTestTask.lambda$executeRecursively$4(NodeTestTask.java:108)
    at org.junit.platform.engine.support.hierarchical.ThrowableCollector.execute(ThrowableCollector.java:72)
    at org.junit.platform.engine.support.hierarchical.NodeTestTask.executeRecursively(NodeTestTask.java:98)
    at org.junit.platform.engine.support.hierarchical.NodeTestTask.execute(NodeTestTask.java:74)
    at java.util.ArrayList.forEach(ArrayList.java:1257)
    at org.junit.platform.engine.support.hierarchical.SameThreadHierarchicalTestExecutorService.invokeAll(SameThreadHierarchicalTestExecutorService.java:38)
    at org.junit.platform.engine.support.hierarchical.NodeTestTask.lambda$executeRecursively$4(NodeTestTask.java:112)
    at org.junit.platform.engine.support.hierarchical.ThrowableCollector.execute(ThrowableCollector.java:72)
    at org.junit.platform.engine.support.hierarchical.NodeTestTask.executeRecursively(NodeTestTask.java:98)
    at org.junit.platform.engine.support.hierarchical.NodeTestTask.execute(NodeTestTask.java:74)
    at java.util.ArrayList.forEach(ArrayList.java:1257)
    at org.junit.platform.engine.support.hierarchical.SameThreadHierarchicalTestExecutorService.invokeAll(SameThreadHierarchicalTestExecutorService.java:38)
    at org.junit.platform.engine.support.hierarchical.NodeTestTask.lambda$executeRecursively$4(NodeTestTask.java:112)
    at org.junit.platform.engine.support.hierarchical.ThrowableCollector.execute(ThrowableCollector.java:72)
    at org.junit.platform.engine.support.hierarchical.NodeTestTask.executeRecursively(NodeTestTask.java:98)
    at org.junit.platform.engine.support.hierarchical.NodeTestTask.execute(NodeTestTask.java:74)
    at org.junit.platform.engine.support.hierarchical.SameThreadHierarchicalTestExecutorService.submit(SameThreadHierarchicalTestExecutorService.java:32)
    at org.junit.platform.engine.support.hierarchical.HierarchicalTestExecutor.execute(HierarchicalTestExecutor.java:57)
    at org.junit.platform.engine.support.hierarchical.HierarchicalTestEngine.execute(HierarchicalTestEngine.java:51)
    at org.junit.platform.launcher.core.DefaultLauncher.execute(DefaultLauncher.java:220)
    at org.junit.platform.launcher.core.DefaultLauncher.lambda$execute$6(DefaultLauncher.java:188)
    at org.junit.platform.launcher.core.DefaultLauncher.withInterceptedStreams(DefaultLauncher.java:202)
    at org.junit.platform.launcher.core.DefaultLauncher.execute(DefaultLauncher.java:181)
    at org.junit.platform.launcher.core.DefaultLauncher.execute(DefaultLauncher.java:128)
    at com.intellij.junit5.JUnit5IdeaTestRunner.startRunnerWithArgs(JUnit5IdeaTestRunner.java:74)
    at com.intellij.rt.execution.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:47)
    at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:242)
    at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:70)

【问题讨论】:

    标签: java intellij-idea junit tapestry junit5


    【解决方案1】:

    似乎是一个依赖问题。请注意,org.apache.tapestry5.ioc.Messages.getKeys() 方法从 5.4 版开始存在。如果您加载旧版本,则该方法不存在。您的项目配置(例如 gradle 依赖项设置)或测试套件的设置 (@Before) 可能存在问题。

    【讨论】:

    • 我应该提到我使用 maven,但这不相关。我会查看我的依赖项,但我没有为我的测试套件使用设置 - 那里应该有什么?
    • 我检查了所有依赖项并确保所有 Tapestry 依赖项都在同一版本 (5.4.4) 上。我还检查了另一个依赖项是否依赖于挂毯(事实并非如此)。我想不出项目配置中可能有其他问题。
    • 好的,消除了更明显的错误。我猜你的代码 sn-p 可能不足以评估会发生什么。
    • 你还需要什么?
    • @MetaColon 可能是 minimal reproducible example 证明了问题。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2017-07-07
    • 1970-01-01
    • 1970-01-01
    • 2012-01-29
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多