私は、次のコードで活性を有する:onCreate()でstartActivity()を呼び出す方法は?
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
if (mUser.getLoggedInUser() != null) {
startActivity(new Intent(this, MainActivity.class));
finish();
return;
}
}
ユーザーがログインしているのであれば、それはMainActivity
を開始する必要があり、すぐに終了します。 MainActivityが実際に起動されたことを確認するための単体テストを作成したいと思います。
@Test
public void testUserLoggedIn() {
Intents.init();
mUser = new User();
mActivityRule.launchActivity(null);
intended(hasComponent(MainActivity.class.getName()), times(1));
Intents.release();
}
mUser
が依存注射を介して設定されており、期待通りの活動が動作します。私はエスプレッソとIntentsTestRule
を使用して、以下のことを試してみました。ただし、次の出力でテストが失敗します。
java.lang.RuntimeException: Could not launch intent Intent { act=android.intent.action.MAIN flg=0x14000000 cmp=global.snappy.android/.activities.onboarding.FirstStartActivity } within 45 seconds. Perhaps the main thread has not gone idle within a reasonable amount of time? There could be an animation or something constantly repainting the screen. Or the activity is doing network calls on creation? See the threaddump logs. For your reference the last time the event queue was idle before your activity launch request was 1486519735157 and now the last time the queue went idle was: 1486519735163. If these numbers are the same your activity might be hogging the event queue.
at android.support.test.runner.MonitoringInstrumentation.startActivitySync(MonitoringInstrumentation.java:360)
at android.support.test.rule.ActivityTestRule.launchActivity(ActivityTestRule.java:219)
at global.snappy.android.activities.onboarding.FirstStartActivityTest.testUserLoggedIn(FirstStartActivityTest.java:108)
at java.lang.reflect.Method.invoke(Native Method)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26)
at android.support.test.internal.statement.UiThreadStatement.evaluate(UiThreadStatement.java:55)
at android.support.test.rule.ActivityTestRule$ActivityStatement.evaluate(ActivityTestRule.java:270)
at org.junit.rules.RunRules.evaluate(RunRules.java:20)
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
at org.junit.runners.Suite.runChild(Suite.java:128)
at org.junit.runners.Suite.runChild(Suite.java:27)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
at org.junit.runner.JUnitCore.run(JUnitCore.java:115)
at android.support.test.internal.runner.TestExecutor.execute(TestExecutor.java:59)
at android.support.test.runner.AndroidJUnitRunner.onStart(AndroidJUnitRunner.java:262)
at android.app.Instrumentation$InstrumentationThread.run(Instrumentation.java:1886)
エスプレッソがテストに添付する前にアクティビティが閉じられているようです。 onCreate()
のfinish()
コールを削除しても、これは変更されません。この動作をテストする方法はありますか?エスプレッソが望ましいでしょうが、必要に応じて別のフレームワークを使用することもできます。
「mActivityRule.launchActivity(null)」で同じアクティビティを2回起動していないことを確認してください。あなたのルールは3番目のコンストラクタパラメータとしてfalseを持っていますか? –
はい、 'launchActivity'パラメータはfalseに設定されています:' new IntentsTestRule <>(FirstStartActivity.class、true、false) ' – Nutomic