JUnit4 - 参数化测试扩展了参数化基类 - 需要它们的笛卡尔积

问题描述

MyBaseIntegrationTestCase一个类,它是大约 150 个测试类的父类。 现在,我想让 MyBaseIntegrationTestCase 参数化(参数是外部软件的版本)

所以,我把它改成这样

@RunWith(Parameterized.class)
public abstract class MyBaseIntegrationTestCase extends MyBaseTestCase{

 @Parameterized.Parameters(name = "with ExternalSoftware-v{0}")
  public static List<String[]> allVersions() {
    return Arrays.asList( ...);
  }

  @Parameterized.Parameter
  public String externalSoftwareversion;
  
}

MyBaseIntegrationTestCase 的所有子代都被参数化并成功运行,除了 MyTestClass,声明为

@RunWith(Parameterized::class)
class MyTestClass(override var myType: ParameterType) : MyBaseIntegrationTestCase() {
  companion object {
    @Parameterized.Parameters(name = "with {0}")
    @JvmStatic
    fun allTypes(): Collection<Array<ParameterType>> = ...
}

它失败了

java.lang.Exception: 测试类应该只有一个公共零参数构造函数

我想让 MyBaseIntegrationTestCase 的所有子项按照父类中的定义运行参数化,并使 MyTestClass 在 allType 和 allVersions 的笛卡尔积上参数化

MyTestClass不扩展MyBaseIntegrationTestCase是不可能的,这需要大量的东西来复制粘贴。

你能建议任何想法如何在 JUnit4 中做到这一点吗?

解决方法

如果有人感兴趣 类应声明为:

@RunWith(Parameterized.class)
public abstract class MyBaseIntegrationTestCase extends MyBaseTestCase{

 @Parameterized.Parameters(name = "with ExternalSoftware-v{0}")
  public static List<String[]> allVersions() {
    return Arrays.asList( ...);
  }

  @Parameterized.Parameter(0) // important to set index explicitly
  public String externalSoftwareVersion;
  
}

@RunWith(Parameterized::class)
class MyTestClass : MyBaseIntegrationTestCase() {
  @Parameterized.Parameter(1) // important to set index explicitly
  var myType: ParameterType
  companion object {
    @Parameterized.Parameters(name = "with {1} on version {0}")
    @JvmStatic
    fun allTypes(): Collection<Array<Any>> = ... //cartesian product should be here
}

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...