Instrukcje konfiguracji espresso

Z tego przewodnika dowiesz się, jak zainstalować Espresso za pomocą Menedżera SDK i skompilować go za pomocą Gradle. Zalecamy Android Studio.

Konfigurowanie środowiska testowego

Aby uniknąć niestabilności, zalecamy wyłączenie animacji systemowych na urządzeniach wirtualnych lub fizycznych używanych do testowania. Na urządzeniu w sekcji Ustawienia > Opcje programisty wyłącz te 3 ustawienia:

  • Skala animacji okna
  • Skala animacji przejścia
  • Skala długości animacji

Dodawanie zależności Espresso

Aby dodać zależności Espresso do projektu, wykonaj te czynności:

  1. Otwórz plik build.gradle aplikacji. Zwykle nie jest to plik build.gradle najwyższego poziomu, ale app/build.gradle.
  2. W sekcji dependencies dodaj te wiersze:

Groovy

androidTestImplementation 'androidx.test.espresso:espresso-core:3.6.1'
androidTestImplementation 'androidx.test:runner:1.6.1'
androidTestImplementation 'androidx.test:rules:1.6.1'

Kotlin

androidTestImplementation('androidx.test.espresso:espresso-core:3.6.1')
androidTestImplementation('androidx.test:runner:1.6.1')
androidTestImplementation('androidx.test:rules:1.6.1')

Wyświetl pełny zestaw zależności Gradle

Ustawianie narzędzia do uruchamiania testów

Dodaj do tego samego pliku build.gradle ten wiersz w android.defaultConfig:

Groovy

testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"

Kotlin

testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner"

Przykładowy plik kompilacji Gradle

Groovy

plugins {
  id 'com.android.application'
}

android {
    compileSdkVersion 33

    defaultConfig {
        applicationId "com.my.awesome.app"
        minSdkVersion 21
        targetSdkVersion 33
        versionCode 1
        versionName "1.0"

        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
    }
}

dependencies {
    androidTestImplementation 'androidx.test:runner:1.6.1'
    androidTestImplementation 'androidx.test.espresso:espresso-core:3.6.1'
}

Kotlin

plugins {
    id("com.android.application")
}

android {
    compileSdkVersion(33)

    defaultConfig {
        applicationId = "com.my.awesome.app"
        minSdkVersion(21)
        targetSdkVersion(33)
        versionCode = 1
        versionName = "1.0"

        testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner"
    }
}

dependencies {
    androidTestImplementation('androidx.test:runner:1.6.1')
    androidTestImplementation('androidx.test.espresso:espresso-core:3.6.1')
}

Statystyki

Aby mieć pewność, że każda nowa wersja działa prawidłowo, narzędzie do testowania zbiera dane analityczne. W przypadku każdego wywołania przesyła on hash nazwy pakietu testowanej aplikacji. Dzięki temu możemy mierzyć zarówno liczbę unikalnych pakietów za pomocą Espresso, jak i wielkość wykorzystania.

Jeśli nie chcesz przesyłać tych danych, możesz zrezygnować z tego, dodając argument disableAnalytics do polecenia instrumentacji:

adb shell am instrument -e disableAnalytics true

Dodawanie pierwszego testu

Android Studio domyślnie tworzy testy w src/androidTest/java/com.example.package/.

Przykład testu JUnit4 z użyciem reguł:

Kotlin

@RunWith(AndroidJUnit4::class)
@LargeTest
class HelloWorldEspressoTest {

    @get:Rule
    val activityRule = ActivityScenarioRule(MainActivity::class.java)

    @Test fun listGoesOverTheFold() {
        onView(withText("Hello world!")).check(matches(isDisplayed()))
    }
}

Java

@RunWith(AndroidJUnit4.class)
@LargeTest
public class HelloWorldEspressoTest {

    @Rule
    public ActivityScenarioRule<MainActivity> activityRule =
            new ActivityScenarioRule<>(MainActivity.class);

    @Test
    public void listGoesOverTheFold() {
        onView(withText("Hello world!")).check(matches(isDisplayed()));
    }
}

Przeprowadzanie testów

Testy możesz uruchamiać w Android Studio lub z wiersza poleceń.

W Android Studio

Aby utworzyć konfigurację testu w Android Studio, wykonaj te czynności:

  1. Otwórz Uruchom > Edytuj konfiguracje.
  2. Dodaj nową konfigurację testów na Androida.
  3. Wybierz moduł.
  4. Dodaj konkretny program do uruchamiania testów: androidx.test.runner.AndroidJUnitRunner
  5. Uruchom nowo utworzoną konfigurację.

W wierszu poleceń

Uruchom to polecenie Gradle:

./gradlew connectedAndroidTest