我是JUnit5的新手,我注意到发生了一些奇怪的事情。
让我们用一个例子来看,
我有一个名为 A 的源类
class A {
someDownStreamService service;
void printer() {
int getData = service.getIntegerData();
print(getData);
}
}
现在当我写测试用例时,
@TestInstance(TestInstance.Lifecycle.PER_CLASS)
class JUnit5TestCaseForClassA {
@Mock
private someDownStreamService service;
@InjectMocks
private A a;
@BeforeEach
setUp() {
initMocks(this);
Mockito.when(service.getIntegerData()).thenReturn(25);
}
@Test
void test1() {
a.printer();
}
@Test
void test2() {
Mockito.when(service.getIntegerData()).thenReturn(19);
a.printer();
}
}
当我单独触发test2((时,printer((函数正在打印19,因为我认为Mockito.when((语句被覆盖以在test2((函数中返回19,而不是在@BeforeEach中注册的内容以返回25。
当我执行类"JUnit5TestCaseForClassA"下的所有测试类时,我看到 printer(( 函数正在为这两个测试函数打印 25。压倒一切没有发生吗?或者问题出在哪里?
为什么会有这种差异?????
我可以看到制作@TestInstance(TestInstance.Lifecycle.METHOD(将解决这个问题,因为每个测试用例都是由新的测试实例触发的。但我想用Lifecycle.PER_CLASS进行测试。
我稍微修改了您的示例以使其可测试(带有断言(,如下所示。
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.mockito.Mockito.when;
import static org.mockito.MockitoAnnotations.initMocks;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestInstance;
import org.junit.jupiter.api.TestInstance.Lifecycle;
import org.mockito.InjectMocks;
import org.mockito.Mock;
@TestInstance(Lifecycle.PER_CLASS)
public class MockitoJUnitJupiterTestCase {
@Mock
MyService service;
@InjectMocks
A a;
@BeforeEach
void setUp() {
initMocks(this);
when(service.getData()).thenReturn(25);
}
@Test
void test1() {
assertEquals("data: 25", a.printer());
}
@Test
void test2() {
when(service.getData()).thenReturn(19);
assertEquals("data: 19", a.printer());
}
}
interface MyService {
int getData();
}
class A {
MyService service;
String printer() {
return "data: " + service.getData();
}
}
当我使用 Mockito 2.23.4 或 2.28.2 和 JUnit Jupiter 5.5 快照执行时,测试通过了。
您能否尝试测试的这种变体,并在执行整个测试类时让我们知道两个测试是否都通过?