Как правильно отключить тест AndroidX Espresso?
Я пишу тест Espresso, чтобы проверить, правильно ли мои приложения обрабатывают ссылки на приложения. Я установил Android Studio и создал тест, который проходит успешно, но проблема в том, что тестовый набор зависает. Я создал класс, LinkDispatcherActivity
, который отвечает за анализ входящих ссылок и отправку их данных для соответствующей деятельности. Тесты настроены на использование ActivityTestRule
запустить LinkDispatcherActivity
и дать ему намерение с URL-адресом для проверки. Тесты выполняются и проходят, поэтому я предполагаю, что все настроил правильно (задача сама по себе).
Я пытался использовать новый ActivityScenarioRule
но не могу понять, как передать ему намерение.
Вот мой тестовый класс:
import android.content.Intent
import android.net.Uri
import android.widget.TextView
import androidx.test.espresso.Espresso.onView
import androidx.test.espresso.assertion.ViewAssertions.matches
import androidx.test.espresso.matcher.ViewMatchers.*
import androidx.test.ext.junit.runners.AndroidJUnit4
import androidx.test.filters.LargeTest
import androidx.test.rule.ActivityTestRule
import gov.nih.nlm.wiser.R
import gov.nih.nlm.wiser.link.WiserLinkDispatcherActivity
import org.hamcrest.Matchers.allOf
import org.hamcrest.Matchers.instanceOf
import org.junit.Rule
import org.junit.Test
import org.junit.runner.RunWith
@RunWith(AndroidJUnit4::class)
@LargeTest
class SubstanceLinkTest {
@get:Rule
val activityTestRule: ActivityTestRule<LinkDispatcherActivity>
= ActivityTestRule(LinkDispatcherActivity::class.java, false, false) // initialTouchMode: false, launchActivity: false
@Test
fun shouldOpenLinkDispatcherActivity() {
val i = Intent().apply {
data = Uri.parse("https://mydomain/action?data=338")
}
activityTestRule.launchActivity(i)
onView(allOf(instanceOf(TextView::class.java), withParent(withId(R.id.action_bar))))
.check(matches(withText("My Title"))) // Passes!!
}
}
Вот мои добавленные зависимости в build.gradle
:
dependencies {
// Core library
implementation 'androidx.test:core:1.2.0'
// AndroidJUnitRunner and JUnit Rules
implementation 'androidx.test:runner:1.2.0'
implementation 'androidx.test:rules:1.2.0'
// Assertions
implementation 'androidx.test.ext:junit:1.1.1'
implementation 'androidx.test.ext:truth:1.2.0'
implementation 'com.google.truth:truth:0.42'
// Espresso dependencies
implementation 'androidx.test.espresso:espresso-core:3.2.0'
implementation 'com.android.support:multidex-instrumentation:1.0.3'
}
Наконец, вот что Android Studio показывает на панели "Выполнить":
Ура!
Изменить: Забыл добавить, что я получаю эту ошибку в Logcat:
2019-06-21 12:02:24.326 6311-6035/? E/cckz: *~*~*~ Channel {0} was not shutdown properly!!! ~*~*~*
Make sure to call shutdown()/shutdownNow() and wait until awaitTermination() returns true.
java.lang.RuntimeException: ManagedChannel allocation site
at cclc.<init>(:com.google.android.gms@17455040@17.4.55 (100700-248795830):1)
at cckz.<init>(:com.google.android.gms@17455040@17.4.55 (100700-248795830):2)
at ccdo.b(:com.google.android.gms@17455040@17.4.55 (100700-248795830):14)
at rzc.a(:com.google.android.gms@17455040@17.4.55 (100700-248795830):43)
at rzc.a(:com.google.android.gms@17455040@17.4.55 (100700-248795830):58)
at atbl.a(:com.google.android.gms@17455040@17.4.55 (100700-248795830):9)
at atbl.a(:com.google.android.gms@17455040@17.4.55 (100700-248795830):26)
at qbi.run(:com.google.android.gms@17455040@17.4.55 (100700-248795830):1)
at sgs.b(:com.google.android.gms@17455040@17.4.55 (100700-248795830):37)
at sgs.run(:com.google.android.gms@17455040@17.4.55 (100700-248795830):21)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
at smq.run(Unknown Source:7)
at java.lang.Thread.run(Thread.java:764)
ОБНОВЛЕНИЕ: тест завершается правильно при запуске на физическом устройстве. Все еще не уверен, что заставляет эмулятор зависать.
1 ответ
Я бы предложил использовать @After
аннотация с помощью метода, называемого "tearDown". Вы можете сделать последние утверждения здесь и очистить любые базы данных или процессы, которые должны быть завершены, и, возможно, вызвать publisher.shutdown();
а также publisher.awaitTermination(1, TimeUnit.MINUTES)
Надеюсь, это поможет.
Проверьте эту тему тоже: [ https://github.com/googleapis/google-cloud-java/issues/3648]