在 JUnit 中参数化测试方法,而不仅仅是整个类

Kar*_*pka 5 java junit testng data-driven-tests testng-dataprovider

我想在 JUnit 中创建一个数据驱动的参数化方法

我看到的例子对整个进行了参数化。

例如

@RunWith(Parameterized.class)
public class PrimeNumberCheckerTest {
Run Code Online (Sandbox Code Playgroud)

但是,我想参数化单个测试方法,而不是整个

在 TestNG 中,类似的东西看起来像这样:

@DataProvider(name = "test1")
public static Object[][] primeNumbers() {
   return new Object[][] {{2, true}, {6, false}, {19, true}, {22, false}, {23, true}};
}

// This test will run 4 times since we have 5 parameters defined
@Test(dataProvider = "test1")
public void testPrimeNumberChecker(Integer inputNumber, Boolean expectedResult) {
   System.out.println(inputNumber + " " + expectedResult);
   Assert.assertEquals(expectedResult,
   primeNumberChecker.validate(inputNumber));
}
Run Code Online (Sandbox Code Playgroud)

JUnit 中可能有这样的事情吗?

编辑:

  1. 最优雅/干燥的方法是使用单个方法级注释 - 这就是我所希望的。

  2. 我找到了一个图书馆:

https://github.com/Pragmatists/junitparams

例子:

@RunWith(JUnitParamsRunner.class)
public class PersonTest {

  @Test
  @Parameters({"17, false", 
               "22, true" })
  public void personIsAdult(int age, boolean valid) throws Exception {
    assertThat(new Person(age).isAdult(), is(valid));
  }

}
Run Code Online (Sandbox Code Playgroud)

问题仍然存在 - JUnit 中是否内置了类似的东西?

如果不是,那么需要最少样板代码或类级扭曲的最接近的内置东西是什么?

ysh*_*vit 5

您可以使用@RunWith(Suite.class)@Suite.SuiteClasses将外部类转换为套件,然后在内部嵌套类(定义套件的“子测试类”),每个类都有自己的运行程序。

@RunWith(Suite.class)
@Suite.SuiteClasses({MyFooTest.Individual.class, MyFooTest.WithParams.class})
public class MyFooTest {

  @RunWith(Parameterized.class)
  public static class WithParams {
    @Parameterized.Parameters
    public static Collection<Object[]> primeNumbers() {
      ...
    }
    @Test
    public void testPrimeNumberChecker() {
      ...
    }
    ...
  }

  public static class Individual {
    @Test
    public void someOneOffTest() {
      ...
    }
    ...
  }
}
Run Code Online (Sandbox Code Playgroud)

  • 我不知道,但你_也许_能够使用外部类本身作为子套件之一:`@Suite.SuiteClasses({MyFooTest.class, MyFooTest.WithParams.class})`。这样,只有参数化测试需要它们自己的类,这至少减少了一些开销。确实感觉很多,我同意。据我所知,这是使用 junit 的最佳方法。 (2认同)