Я пытаюсь создать класс, который создает намерение и запускает новое действие, теперь у меня есть проблема с его тестированием.
private static final String TAG = IntentToActivity.class.getSimpleName();
// ----------------
// START VARIABLES
// ----------------
private String fqClassName;
private Intent intentToActivity;
private Context context;
// --------------
// END VARIABLES
// --------------
/**
* Constructor sets needed variables, creates and performs intent
* @param fqClassName full qualified class name to intent to
* @param context context of the current using activity
*/
public IntentToActivity(String fqClassName, Context context) {
this.fqClassName = fqClassName;
this.context = context;
performIntent();
}
/**
* Creates and performs intent
*
* IMPORTANT: Intent must be referented in the manifest of the application use following code:
* <intent-filter>
* <action android:name="com.example.exampleapplication.ExampleClass" />
* <category android:name="android.intent.category.DEFAULT" />
* </intent-filter>
*/
private void performIntent() {
if (fqClassName != null) {
try {
intentToActivity = new Intent(fqClassName);
context.startActivity(intentToActivity);
} catch (Exception e) {
Log.e(TAG, "performIntent error: ", e);
}
}
}
}
Мой androidTest
publi c class IntentToActivityTest {@Rule publi c IntentsTestRule intetsRule = new IntentsTestRule <> (IntentToActivity.class);
@Test
public void newActivityLaunchingTest() {
Intents.intended(IntentMatchers.hasComponent("com.example.mmal.example.auth.IntentToActity2Example"));
}
Мой первый вопрос, как запустить намерение для теста Мой второй, как реализовать класс неактивности как правило
ошибка тока. Журнал:
java.lang.RuntimeException: Could not launch activity
at androidx.test.runner.MonitoringInstrumentation.startActivitySync(MonitoringInstrumentation.java:467)
at androidx.test.rule.ActivityTestRule.launchActivity(ActivityTestRule.java:354)
at androidx.test.rule.ActivityTestRule$ActivityStatement.evaluate(ActivityTestRule.java:525)
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 androidx.test.runner.AndroidJUnit4.run(AndroidJUnit4.java:104)
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 androidx.test.internal.runner.TestExecutor.execute(TestExecutor.java:56)
at androidx.test.runner.AndroidJUnitRunner.onStart(AndroidJUnitRunner.java:388)
at android.app.Instrumentation$InstrumentationThread.run(Instrumentation.java:2108)
Caused by: java.lang.RuntimeException: Unable to resolve activity for: Intent { act=android.intent.action.MAIN flg=0x14000000 cmp=com.motionminers.mmal.test/com.motionminers.mmal.backend.mv.IntentToActivity }
at android.app.Instrumentation.startActivitySync(Instrumentation.java:447)
at androidx.test.runner.MonitoringInstrumentation.access$101(MonitoringInstrumentation.java:98)
at androidx.test.runner.MonitoringInstrumentation$4.call(MonitoringInstrumentation.java:443)
at androidx.test.runner.MonitoringInstrumentation$4.call(MonitoringInstrumentation.java:440)
at java.util.concurrent.FutureTask.run(FutureTask.java:266)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1162)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:636)
at java.lang.Thread.run(Thread.java:764)