在用测试夹具替换应用程序之前,我想备份应用程序的数据库。由于Android的限制,我被迫使用Junit3,并且我希望实现@BeforeClass和@AfterClass的等效行为。
更新:现在有一个工具(Junit4Android)可以在Android上获得对Junit4的支持。这有点杂乱无章,但应该行得通。
为了实现@BeforeClass等效,我在第一次运行时使用了一个静态变量并像这样初始化了它,但是在运行所有测试之后,我需要能够恢复数据库。我想不出一种检测最后一次测试何时运行的方法(因为我认为测试执行的顺序没有保证)。
public class MyTest extends ActivityInstrumentationTestCase2<MainActivity> {
private static boolean firstRun = true;
@Override
protected void setUp() {
if(firstRun) {
firstRun = false;
setUpDatabaseFixture();
}
}
...
}发布于 2011-08-26 17:57:48
来自junit网站
如果要运行单个setUp测试用例,则在suite.This中包装suite.This和YourTestClass方法。
public static Test suite() {
return new TestSetup(new TestSuite(YourTestClass.class)) {
protected void setUp() throws Exception {
System.out.println(" Global setUp ");
}
protected void tearDown() throws Exception {
System.out.println(" Global tearDown ");
}
};
}如果您只想为所有测试用例运行一个setUp和tearDown,那么创建一个套件并向它添加testClass,并在TestSetup constructor.But中传递suite对象--我认为这样做没有多大用处,而且在某种程度上违反了JUnit哲学。
发布于 2011-08-26 18:12:54
最近,我也在寻找类似的解决方案。幸运的是,在我的例子中,JVM在最后一个测试运行后退出。因此,我可以通过添加JVM关闭挂钩来实现这一点。
// Restore database after running all tests
Runtime.getRuntime().addShutdownHook(new Thread() {
public void run() {
restoreDatabase();
}
});希望这能有所帮助。
发布于 2011-08-29 03:01:14
在需要知道运行测试的顺序时,我建议避免这种依赖关系。如果您所需要的只是还原一个被setUpDatabaseFixture()替换的真正的数据库,那么您的解决方案可能来自RenamingDelegatingContext的使用。无论如何,如果您无法避免知道上一次测试是什么时候运行的,您可以使用如下所示:
...
private static final int NUMBER_OF_TESTS = 5; // count your tests here
private static int sTestsRun = 0;
...
protected void tearDown() throws Exception {
super.tearDown();
sTestsRun += countTestCases();
if ( sTestsRun >= NUMBER_OF_TESTS ) {
android.util.Log.d("tearDow", "*** Last test run ***");
}
}https://stackoverflow.com/questions/7208593
复制相似问题