我们有一个测试在 Maven 中执行时失败,但在 Eclipse 中成功。
基本上问题是,当使用 Maven Mockito 执行时,无法模拟来自另一个具有包私有修饰符的 Maven 模块的超类的方法。
问题
- 为什么会这样?
- 这是一个已知的错误?如果没有在哪里归档?万无一失,模仿...?
- 如何解决?
我发现了一个类似问题的描述,建议修复使用surefire-2.7.1而不是2.7.0,但我们已经在2.10上(也可以在2.16中看到问题)
显然,最简单的解决方案是将 BaseClass 公开,但我们不能这样做,因为它不在我们的控制之下。
另一种选择是在 MockedClass 中覆盖 close,这很丑陋但可能。
错误信息是
failsCallingOriginalMethod(ModifierTest) Time elapsed: 0.156 sec <<< ERROR!
java.lang.RuntimeException: must not have called me
相关代码
真正的代码不在默认包中,而是所有代码都在同一个包中;为简洁起见,删除了 import 语句。
Maven 模块 1
public class ModifierTest
{
@Test
public void failsCallingOriginalMethod()
{
MockedClass mock = Mockito.mock(MockedClass.class);
doNothing().when(mock).close();
}
}
Maven 模块 2
public class MockedClass extends BaseClass
{
}
class BaseClass
{
public void close()
{
throw new RuntimeException("must not have called me");
}
}
涉及的东西的版本
Maven 版本 3.0.5(由于其他错误无法更改)
Oracle JDK 1.6.0_20(可使用 IBM JDK 1.5 重现)
模拟1.95
Surefire 插件 2.10(可在 2.16 中重现)