我正在使用 junit 4 的“参数化”功能,我注意到 @parameters 方法在 @beforeclass 方法之前执行。这给我带来了一个问题,因为我通过@parameters 传递给测试用例的参数取决于@beforeclass 方法中的代码初始化。例如
@RunWith(Parameterized.class)
public class TestOtherClass {
String argument;
private static boolean initializeThis;
public TestOtherClass(String parameter) throws Exception {
argument=parameter;
}
@BeforeClass
public static void doSetup() {
System.out.println("Doing setup before class...");
initializeThis=true; // true or false, based on some condition
}
@Test
public void otherTest() {
System.out.println("Other test: " + argument);
}
@Parameters
public static Collection<Object[]> getData(){
System.out.println("Inside parameter");
String addThis;
if(initializeThis)
addThis="adding true";
else
addThis="adding false";
Object[] para1 = new Object[]{"First parameter :: " + addThis};
Object[] para2 = new Object[]{"Second parameter :: " + addThis};
Collection<Object[]> classNames = new ArrayList<Object[]>();
classNames.add(para1);
classNames.add(para2);
return classNames;
}
}
现在,我在@beforeclass 方法中将变量“initializeThis”初始化为true,但是(令人惊讶的是)当我执行它打印的测试用例时
Other test: First parameter :: adding false
Other test: Second parameter :: adding false
这是意料之外的事情。
我的问题是;有没有办法在@parameters 之前执行@beforeclass 方法,我们可以在junit 4 中执行此操作吗?