有几种方法可以实现此目的。最简单,最简单的方法是在套件的开头和结尾运行一个“测试”,以建立数据库,然后设置一个全局标志。在@Before和@After测试中,请检查此标志,并在必要时进行设置/拆卸。
@RunWith(Suite.class)@SuiteClasses({SetupTest.class, RealTest.class, TeardownTest.class});这是最简单的解决方案,但不是很好,因此更简洁的解决方案是使用TestRule。看一下扩展ExternalResource。这实现了围绕您的测试方法的逻辑前后。这将允许您排除@Before和@After方法,以便在各处重用相同的代码。
然后,对于您的套件,您还需要实现之前/之后的逻辑。不幸的是,用@RunWith(Suite.class)注释的类实际上并未实例化,因此您不能使用该类的构造函数,但是可以扩展Suite。根据运行方式的不同,您将需要使用@RunWith作为示例来实现一个构造函数:
public class MySuite extends Suite { public MySuite(Class<?> klass, RunnerBuilder builder) throws InitializationError { this(builder, klass, getAnnotatedClasses(klass)); // put your global setup here // set global variable }}然后运行您的测试套件
@RunWith(MySuite.class)
有几种在不同情况下使用的构造函数,请查看每个构造函数旁边的注释以获取详细信息。您仍然需要使用全局变量,以便您的规则不会重新执行设置代码。如果您只想执行设置代码,则执行上面的命令比较困难,但是可以做到。让我知道您是否需要它:-)
如果您想要更大的灵活性(例如仅针对特定方法执行安装代码),请参阅我的答案如何在套件中定义JUnit方法规则?。



