diff options
| author | Romain Guy <romainguy@android.com> | 2009-12-10 11:16:43 -0800 |
|---|---|---|
| committer | Romain Guy <romainguy@android.com> | 2009-12-10 11:16:43 -0800 |
| commit | d432656e60dd6b3e9a1acb14001bc2d2b886789d (patch) | |
| tree | f6d540aeec93d16679bcadf9ab4f6ab499edcca9 /core/java | |
| parent | 7cd4029473431c56100e52f631b9733829dc3171 (diff) | |
| download | frameworks_base-d432656e60dd6b3e9a1acb14001bc2d2b886789d.zip frameworks_base-d432656e60dd6b3e9a1acb14001bc2d2b886789d.tar.gz frameworks_base-d432656e60dd6b3e9a1acb14001bc2d2b886789d.tar.bz2 | |
Add support for @UiThreadTest on setUp() and tearDown() in InstrumentationTestCase.
Diffstat (limited to 'core/java')
| -rw-r--r-- | core/java/android/test/InstrumentationTestCase.java | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/core/java/android/test/InstrumentationTestCase.java b/core/java/android/test/InstrumentationTestCase.java index 22d95d1..6d92ea3 100644 --- a/core/java/android/test/InstrumentationTestCase.java +++ b/core/java/android/test/InstrumentationTestCase.java @@ -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. |
