Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 7d26aca8 authored by Romain Guy's avatar Romain Guy Committed by Android Git Automerger
Browse files

am f44ecff4: Merge change Id432656e into eclair-mr2

Merge commit 'f44ecff4' into eclair-mr2-plus-aosp

* commit 'f44ecff4':
  Add support for @UiThreadTest on setUp() and tearDown() in InstrumentationTestCase.
parents c7afd922 f44ecff4
Loading
Loading
Loading
Loading
+36 −0
Original line number Diff line number Diff line
@@ -147,6 +147,42 @@ public class InstrumentationTestCase extends TestCase {
        }
    }

    @Override
    public void runBare() throws Throwable {
        runMethod("setUp");

        try {
            runTest();
        } finally {
            runMethod("tearDown");            
        }
    }

    private Throwable[] runMethod(String name) throws Throwable {
        final Throwable[] exceptions = new Throwable[1];
        final Method m = getClass().getMethod(name, (Class[]) null);

        if (m.isAnnotationPresent(UiThreadTest.class)) {
            getInstrumentation().runOnMainSync(new Runnable() {
                public void run() {
                    try {
                        m.invoke(this);                        
                    } catch (Throwable throwable) {
                        exceptions[0] = throwable;
                    }
                }
            });
            if (exceptions[0] != null) {
                throw exceptions[0];
            }
            exceptions[0] = null;
        } else {
            m.invoke(this);
        }

        return exceptions;
    }

    /**
     * Runs the current unit test. If the unit test is annotated with
     * {@link android.test.UiThreadTest}, the test is run on the UI thread.