问题描述
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
}