假设我有一个这样的模拟设置:
JUnit4Mockery context = new JUnit4Mockery();
MyInterface mock = context.mock(MyInterface.class);
后来我想检查我的模拟对象以找出它正在模拟的类:
Class mockedClass = mock.??? //would return MyInterface.class
我在 JMock (2.5.1) javadocs 中没有看到任何关于如何执行此操作的明显内容 - 该mock
方法的签名是
<T> T mock (Class<T> typeToMock)
在以前的版本中(我查看了 1.2.0),您将Mock
直接创建一个对象,其方法之一是
Class getMockedType()
我想要实现的是一个单元测试框架,用于在我的单元测试中使用 DI。(我使用的是 Guice 3.0。)在测试中使用 DI 是对我正在使用的应用程序服务器/平台的限制——我正在测试的对象是具有自己的 multiton 的子类Injector
,这就是我的我试图填充。
我不想在每次测试中都创建一个匿名的 AbstractModule 实例,所以我正在尝试构建这样的东西(这似乎在 1.2 中可以工作):
public class MockModule extends AbstractModule {
private Iterable<Mock> mocks;
public MockModule(Iterable<Mock> mocks) {
this.mocks = mocks;
}
protected void configure() {
for (Mock mock : mocks) {
bind(mock.getMockedType()).toInstance(mock);
}
}
}
唯一缺少的是这个问题的答案(如果有的话)。
对已接受答案的回应
这是我最终为此用例创建的内容:
import java.lang.reflect.Proxy;
import com.google.common.collect.Lists;
import com.google.inject.AbstractModule;
@SuppressWarnings({ "rawtypes", "unchecked" })
public class MockModule extends AbstractModule {
private final Iterable mocks;
public MockModule(Object mock) {
mocks = Lists.newArrayList(mock);
}
public MockModule(Iterable mocks) {
this.mocks = mocks;
}
protected void configure() {
for (Object mock : mocks) {
Class superclass = mock.getClass().getSuperclass();
if (superclass != Object.class && superclass != Proxy.class) {
bind(superclass).toInstance(mock);
continue;
}
Class[] interfaces = mock.getClass().getInterfaces();
if (interfaces.length > 0) {
bind(interfaces[0]).toInstance(mock);
}
}
}
}