Questa guida illustra l'installazione di Espresso utilizzando SDK Manager e la sua creazione con Gradle. Android Studio è consigliato.
Configura l'ambiente di test
Per evitare 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 dipendenze Espresso al progetto, completa questi passaggi:
- Apri il file
build.gradle
dell'app. In genere non è il filebuild.gradle
di primo livello, maapp/build.gradle
. - Aggiungi le seguenti righe all'interno delle dipendenze:
trendy
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 il set completo delle dipendenze Gradle.
Imposta il runner della strumentazione
Aggiungi allo stesso file build.gradle
la seguente riga in
android.defaultConfig
:
trendy
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
Kotlin
testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner"
Esempio di file di build Gradle
trendy
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 assicurarsi di essere sulla strada giusta per ogni nuova release, l'esecutore del test raccoglie dati e analisi. Più precisamente, carica un hash del nome di pacchetto dell'applicazione in fase di test per ogni chiamata. In questo modo possiamo misurare sia il numero di pacchetti unici utilizzando Espresso sia il volume di utilizzo.
Se non vuoi caricare questi dati, puoi disattivarli includendo l'argomento disableAnalytics
nel comando di strumentazione:
adb shell am instrument -e disableAnalytics true
Aggiungi il primo test
Android Studio crea test per impostazione predefinita in src/androidTest/java/com.example.package/
.
Esempio di test JUnit4 con 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, svolgi i seguenti passaggi:
- Apri Esegui > Modifica configurazioni.
- Aggiungi una nuova configurazione di Android Tests.
- Scegli un modulo.
- Aggiungi un runner di strumentazione specifico:
androidx.test.runner.AndroidJUnitRunner
- Esegui la configurazione appena creata.
Dalla riga di comando
Esegui questo comando Gradle:
./gradlew connectedAndroidTest