使用 JUnit @Rule 使用 Mockito 进行参数化测试?



这是从这个问题开始的:我被要求开始一个新问题。

问题是我对JUnitRuleRunners之类的事情了解不够,无法以Jeff Bowman所暗示的方式解决问题。

在您后来的评论中,我发现了差距:您需要使用 Mockito 作为规则并将参数化为运行器,而不是相反。

原因是 Runner 负责报告测试数量,而参数化根据测试方法的数量和参数化输入的数量来操纵测试数量,因此参数化成为 Runner 过程的一部分非常重要。相比之下,使用 Mockito 运行器或规则只是封装初始化 Mockito 注释并验证 Mockito 用法的@Before@After方法,这可以非常容易地作为与其他@Rule实例相邻工作的@Rule来完成 - 以至于 MockitoJUnitRunner 几乎被弃用。

要直接从 JUnit4 参数化测试文档页面和 MockitoRule 文档页面获取婴儿床:

@RunWith(Parameterized.class)
public class YourComponentTest {
@Rule public MockitoRule rule = MockitoJUnit.rule();
@Mock YourDep mockYourDep;
@Parameters
public static Collection<Object[]> data() {
return Arrays.asList(new Object[][] {     
{ 0, 0 }, { 1, 1 }, { 2, 1 }, { 3, 2 }, { 4, 3 }, { 5, 5 }, { 6, 8 }  
});
}
private int fInput;
private int fExpected;
public YourComponentTest(int input, int expected) {
fInput = input;
fExpected = expected;
}
@Test
public void test() {
// As you may surmise, this is not a very realistic example of Mockito's use.
when(mockYourDep.calculate(fInput)).thenReturn(fExpected);
YourComponent yourComponent = new YourComponent(mockYourDep);
assertEquals(fExpected, yourComponent.compute(fInput));
}
}

最新更新