我正在使用EasyMock创建mock,它是测试类中的私有参数之一(没有setter)。我尝试使用反射 - 但它无法正常工作。
public class TestedClassTest{
@Test
public void test(){
TestedClass instance = new TestedClass();
MockedClass mocked = EasyMock.createMock(MockedClass.class);
Data data = new Data();
//Void setter
DataType dataType = (myDataType.DataType) EasyMock.anyObject();
mocked.setDataType(dataType);
EasyMock.expectLastCall();
//expect
EasyMock.expect(mocked.getData()).andReturn(data);
EasyMock.replay(mocked);
Field field = instance.getClass().getDeclaredField("mockedClass")
field.setAccessible(true);
field.set(instance, mocked);
//run tested method
instance.someAction();
EasyMock.verify(mocked);
}
}
我收到失败信息:
Unexpected method call MockedClass.setDataType(myData.MyData@104306d75):
MockedClass.getData(): expected: 1, actual: 0
junit.framework.AssertionFailedError:
Unexpected method call MockedClass.setDataType(myData.MyData@132006d75):
MockedClass.getData(): expected: 1, actual: 0
我确定在测试“instance.someAction()”期间,“MockedClass”对象会触发此方法
如何解决此问题?
已编辑 - 答案:
在纠正了加倍replay.mocked()
之后,我发现(如此简单!)应该使用EasyMock.expectLastCall()
声明另一个void方法
答案 0 :(得分:3)
你的反思代码看起来很好。
自从我使用过EasyMock以来已经有很长一段时间了,但是在测试中,每个模拟器只能调用一次replay
。你打电话给它两次。尝试摆脱第一个replay
电话。
在这种情况下,包含模拟的字段是否公开是否有意义?通常,应该通过构造函数或setter设置协作者,根本不需要反射。
编辑 - 基于您的更新 - 错误表明在模拟上调用了setDataType
,但模拟并不期望它被调用。也许你的类正在调用它两次,也许它被调用了,或者用一个你没想到的参数调用它(尽管在这种情况下我希望错误是不同的。)