我有一个使用Instrumentation.ActivityMonitor来检查是否发送了Intent的测试用例。测试成功后,这可以很好地工作。如果断言失败,则下一个测试用例将卡在setUp()中的getActivity()调用上。
我应该调用一些方法来清理吗?
它似乎围绕着一个Activity启动,但是ActivityMonitor没有捕捉到它。也就是说,没有触发IntentFilter。测试失败,但是新的Activity永远不会消失,并且似乎会干扰下一个getActivity()调用。
这个问题是similar to another question,但是那里的这个解决方案(调用super.tearDown())不能解决我的问题。
public class SimpleActivityTest
extends ActivityInstrumentationTestCase2<SimpleActivity> {
private SimpleActivity activity;
@Override
protected void setUp() throws Exception {
super.setUp();
this.getInstrumentation().setInTouchMode(false);
Intent intent = new Intent();
intent.putExtra("DATA_ITEM_1", 1);
intent.putExtra("DATA_ITEM_2", 2);
this.setActivityIntent(intent);
this.activity = getActivity(); // this call hangs on second test
}
public void testOtherActivityCalled() {
IntentFilter ifilter = new IntentFilter(Intent.ACTION_VIEW);
ifilter.addDataScheme("http");
ifilter.addDataAuthority("some.domain.com", null);
ifilter.addDataPath("foobar", PatternMatcher.PATTERN_PREFIX);
ActivityMonitor activityMonitor = getInstrumentation().addMonitor(
ifilter, null, false);
activity.runOnUiThread(new Runnable() {
@Override
public void run() {
// launch other activity somehow
}
});
getInstrumentation().waitForIdleSync();
Activity otherActivity = activityMonitor.waitForActivityWithTimeout(2000);
assertNotNull(otherActivity);
otherActivity.finish();
}
public void testSomethingElse() {
// This code will never run because getActivity() in setUp() will
// never return
}
}
最佳答案
我怀疑您创建的Runnable永远不会退出。由于它在UI线程上运行,因此永远不允许Activity生命周期执行所需的操作。您是否有从UI线程执行此操作的特定原因?
关于Android ActivityMonitor故障导致getActivity()永不返回,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/9122016/