Istruzioni per la configurazione Espresso

Questa guida illustra l'installazione di Espresso utilizzando SDK Manager e la sua creazione utilizzando Gradle. Si consiglia Android Studio.

Configurare l'ambiente di test

Per evitare problemi di instabilità, ti consigliamo vivamente di disattivare le animazioni di sistema sui dispositivi virtuali o fisici utilizzati per i test. Sul dispositivo, in Impostazioni > Opzioni sviluppatore, disattiva le seguenti tre impostazioni:

  • Scala animazione finestra
  • Scala animazione transizione
  • Scala durata animatore

Aggiungi dipendenze Espresso

Per aggiungere le dipendenze di Espresso al tuo progetto, completa i seguenti passaggi:

  1. Apri il file build.gradle dell'app. Di solito non è il file build.gradle di primo livello, ma app/build.gradle.
  2. Aggiungi le seguenti righe all'interno delle dipendenze:

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')

Visualizza l'insieme completo di dipendenze Gradle.

Imposta lo strumento di esecuzione dei test di strumentazione

Aggiungi al file build.gradle la seguente riga in android.defaultConfig:

Groovy

testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"

Kotlin

testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner"

Esempio di file di build 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')
}

Analytics

Per assicurarci di essere sulla strada giusta con ogni nuova release, il test runner raccoglie dati di analisi. Più nello specifico, carica un hash del nome del pacchetto dell'applicazione in fase di test per ogni chiamata. In questo modo possiamo misurare sia il conteggio dei pacchetti unici utilizzando Espresso sia il volume di utilizzo.

Se non vuoi caricare questi dati, puoi disattivare l'opzione includendo l'argomento disableAnalytics nel comando di strumentazione:

adb shell am instrument -e disableAnalytics true

Aggiungi il primo test

Android Studio crea i test per impostazione predefinita in src/androidTest/java/com.example.package/.

Esempio di test JUnit4 che utilizza le regole:

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()));
    }
}

Esegui test

Puoi eseguire i test in Android Studio o dalla riga di comando.

In Android Studio

Per creare una configurazione di test in Android Studio, completa i seguenti passaggi:

  1. Apri Esegui > Modifica configurazioni.
  2. Aggiungi una nuova configurazione di test Android.
  3. Scegli un modulo.
  4. Aggiungi un runner di strumentazione specifico: androidx.test.runner.AndroidJUnitRunner
  5. Esegui la configurazione appena creata.

Dalla riga di comando

Esegui questo comando Gradle:

./gradlew connectedAndroidTest