我有一个使用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/

10-11 03:50