我试图用Mockito / JUnit为这样的函数编写单元测试:
class1 {
method {
object1 = class2.method // method that I want to fake the return value
// some code that I still want to run
}
}
Mockito中有没有办法存根class2.method的结果?我试图改进class1的代码覆盖率,所以我需要调用它真正的生产方法。
我在其间谍方法中查看了Mockito API,但这会覆盖整个方法而不是我想要的部分。
答案 0 :(得分:5)
我想我理解你的问题。让我重新说一下,你有一个函数,你试图测试并想要模拟在该函数内调用的函数的结果,但是在另一个类中。我已经按照以下方式处理了这个问题。
public MyUnitTest {
private static final MyClass2 class2 = mock(MyClass2.class);
@Begin
public void setupTests() {
when(class2.get(1000)).thenReturn(new User(1000, "John"));
when(class2.validateObject(anyObj()).thenReturn(true);
}
@Test
public void testFunctionCall() {
String out = myClass.functionCall();
assertThat(out).isEqualTo("Output");
}
}
这是在用@Before注释包装的函数中,我正在设置我希望class2中的函数如何响应给定的特定输入。然后,从实际测试中,我只是调用我想要在我要测试的类中测试的函数。在这种情况下,myClass.functionCall()正常运行,你不会覆盖它的任何方法,但你只是模拟从MyClass2中的方法(或方法)获得的输出。
答案 1 :(得分:3)
这适用于我:
public class Class1Test {
Class1 class1;
@Before
public void setUp() {
MockitoAnnotations.initMocks(this);
class1 = new Class1();
}
@Test
public void testClass1Method() {
Class2 class2 = Mockito.mock(Class2.class);
class1.setClass2(class2);
Mockito.when(
class2.class2Method(Mockito.anyString(), Mockito.anyString(), Mockito.anyString())).thenReturn("some response");
String actualResponse = class1
.class1Method("12345", "3333", "4444");
assertEquals("some response", actualResponse);
}
}
答案 2 :(得分:0)
我写了一个简单的示例,效果很好,希望对您有所帮助:
Class1中的method1()调用Class2中的method2():
public class Class1 {
private Class2 class2 = new Class2();
public int method1() {
return class2.method2();
}
}
Class2和method2():
public class Class2 {
public int method2() {
return 5;
}
}
测试:
import org.junit.Rule;
import org.junit.Test;
import org.mockito.InjectMocks;
import org.mockito.Mock;
import org.mockito.junit.MockitoJUnit;
import org.mockito.junit.MockitoRule;
import static org.junit.Assert.assertEquals;
import static org.mockito.Mockito.when;
public class TestClass1 {
@Mock
Class2 class2;
@InjectMocks
Class1 class1;
@Rule
public MockitoRule mockitoRule = MockitoJUnit.rule();
@Test
public void testMethod1(){
when(class2.method2()).thenReturn(29);
assertEquals(29,class1.method1());
}
}