我想对要使用EasyMock
模拟的类进行多次内部调用的方法进行单元测试。
测试方法实际上运行5次并调用模拟方法。
在每个循环中,我将创建一些对象,它们都属于同一类(比方说A类)。 私有方法将调用采用类A的实例的模拟对象方法,对其进行评估并返回结果。
最后,公共方法将返回结果列表。
我尝试了标准EasyMock.expect(MockClass.method(A)).andReturn()
,但是由于类equals()
没有A
的实现而无法使用:
// this is the method example I am trying to test
public methodToTest(){
// some logic
privateMethodToTest(x);
// some logic
}
private List<B> privateMethodToTest(int x){
List<B> list = new ArrayList<>();
List<A> all = getObjects(x); //getObjects private method
for (A a:all){
list.add(objectToMock.methodToMock(a));
return list;
}
这就是我想要的工作方式:
EasyMock.createMock(ObjectToMock.class);
EasyMock.expect(ObjectToMock.methodToMock(A)/* when A.getValue() == 1 */.andReturn("B object number 1")
EasyMock.expect(ObjectToMock.methodToMock(A)/* when A.getValue() == 2 */.andReturn("B object number 2")
//... and so on
//object of class A does not implement equals()
我不确定该怎么做,也找不到任何类似的例子或我的问题的答案。
答案 0 :(得分:1)
您需要另一个匹配器。默认情况下,EasyMock实际上将使用equals
进行匹配。但是你不能那样做。您的基本选择是:
对于您来说似乎最简单。这意味着要这样做:
expect(objectToMock.methodToMock(anyObject()).andReturn("B object number 1");
expect(objectToMock.methodToMock(anyObject()).andReturn("B object number 2");
根据您的评论,您实际上可能更喜欢
expect(mock.methodToTest(EasyMock.cmp(new A(1), Comparator.comparingInt(A::getValue), LogicalOperator.EQUAL))).andReturn(1);
唯一的问题是您需要一个具有正确值的A
进行比较。
使用下面的自定义匹配器的期望。
expect(mock.methodToTest(cmp(0))).andReturn(3);
public static <T> T cmp(int value) {
reportMatcher(new IArgumentMatcher() {
@Override
public boolean matches(Object argument) {
return value == ((A) argument).getValue();
}
@Override
public void appendTo(StringBuffer buffer) {
buffer.append("A.value=").append(value);
}
});
return null;
}
答案 1 :(得分:0)
在进行单元测试时,我们将验证被测代码的可观察到的行为,即返回值和与依赖项的通信。
还有什么是实施细节,我们不会对其进行测试。原因是您可能想重构您的代码。这意味着您想改善代码的结构而无需更改其行为。您的单元测试应该确认您没有意外更改行为。但是,只有在您也不必更改它们的情况下,它们才可以这样做。