说我有这样的模拟设置:
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是对我正在使用的应用程序服务器/平台的限制 - 我正在测试的对象是具有自己的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);
}
}
}
}
答案 0 :(得分:1)
Class mockedClass = mock.getClass().getInterfaces()[0];
System.out.println("Class is " + mockedClass.getCanonicalName());
将打印:
Interface is MyInterface
可能有更强大的方法可以做到这一点,但至少可以为这个特定的JMock版本完成工作。
答案 1 :(得分:0)
我不确定我理解你这样做的动机。 JMock通常用于对对象或小对象集群进行单元测试,这意味着测试中的所有内容都是新的。当执行看起来更像真实组件的东西时,DI通常会在集成或验收测试的水平上开始。
你想在测试中使用DI来展示什么?