In diesem Dokument wird beschrieben, wie Sie Tests direkt über die Befehlszeile ausführen. Dabei wird davon ausgegangen, dass Sie bereits wissen, wie Sie eine Android-App erstellen und Tests für Ihre App schreiben. Weitere Informationen zum Erstellen von Tests für Ihre App finden Sie unter Apps auf Android testen.
Wenn Sie Ihre App mit dem Gradle-Build-System erstellen, können Sie mit dem Android Gradle Plug-in Tests über die Befehlszeile in Ihrem Gradle Projekt ausführen. Für eine detailliertere Steuerung können Sie Ihre Tests auch über eine Android Debug Bridge (adb) Shell ausführen. Das kann nützlich sein, wenn Sie Tests in einer Umgebung für die kontinuierliche Integration ausführen.
Informationen zum Ausführen automatisierter instrumentierter Tests über die Befehlszeile mit virtuellen Geräten, die von Gradle verwaltet werden, finden Sie unter Tests mit von Gradle verwalteten Geräten skalieren.
Tests mit Gradle ausführen
Mit dem Android-Gradle-Plug-in können Sie Tests über die Befehlszeile in Ihrem Gradle-Projekt ausführen.
In der folgenden Tabelle wird zusammengefasst, wie Sie Ihre Tests mit Gradle ausführen:
Tabelle 1 Verschiedene Möglichkeiten zum Ausführen von Tests mit Gradle
| Art des Einheitentests | Befehl zum Ausführen | Speicherort der Testergebnisse |
|---|---|---|
| Lokaler Einheitentest |
Führen Sie die Aufgabe test aus:
|
HTML-Testergebnisdateien:path_to_your_project/module_name/build/reports/tests/
Verzeichnis.
XML-Testergebnisdateien: |
| Instrumentierter Einheitentest |
Führen Sie die Aufgabe connectedAndroidTest aus:
|
HTML-Testergebnisdateien:path_to_your_project/module_name/build/reports/androidTests/connected/
Verzeichnis.
XML-Testergebnisdateien: |
Gradle unterstützt
Abkürzungen für Aufgabennamen.
Sie können die Aufgabe connectedAndroidTest beispielsweise mit dem folgenden Befehl starten:
./gradlew cATSie können auch die Gradle-Aufgaben check und connectedCheck ausführen. Mit diesen Aufgaben werden Ihre lokalen bzw. instrumentierten Tests ausgeführt. Sie umfassen aber auch andere Prüfungen, die von anderen Gradle-Plug-ins hinzugefügt wurden.
Tests für ein Modul ausführen
Mit den Aufgaben test und connectedAndroidTest werden Tests für jedes Modul in Ihrem Projekt ausgeführt. Sie können Tests für ein bestimmtes Modul ausführen, indem Sie der Aufgabe test oder connectedAndroidTest den Modulnamen und einen Doppelpunkt (:) voranstellen. Mit dem folgenden Befehl werden beispielsweise instrumentierte Tests nur für das Modul mylibrary ausgeführt:
./gradlew mylibrary:connectedAndroidTestTests für eine Build-Variante ausführen
Mit den Aufgaben test und connectedAndroidTest werden Tests für jede
Build-Variante in Ihrem Projekt ausgeführt. Sie können eine bestimmte Build-Variante mit der folgenden Syntax auswählen:
- Für lokale Einheitentests:
./gradlew testVariantNameUnitTest - Für instrumentierte Tests:
./gradlew connectedVariantNameAndroidTest
Bestimmte Testmethoden oder -klassen ausführen
Wenn Sie lokale Einheitentests ausführen, können Sie mit Gradle bestimmte Tests mit dem Flag --tests auswählen. Mit dem folgenden Befehl werden beispielsweise nur die Tests sampleTestMethod für die angegebene Build-Variante ausgeführt. Weitere Informationen zur Verwendung des Flags --tests finden Sie in der Gradle-Dokumentation zum
Testfiltern.
./gradlew testVariantNameUnitTest --tests '*.sampleTestMethod'
Tests mit adb ausführen
Wenn Sie Tests über die Befehlszeile mit Android Debug Bridge (adb) ausführen, haben Sie mehr Möglichkeiten, die auszuführenden Tests auszuwählen als bei jeder anderen Methode. Sie können einzelne Testmethoden auswählen, Tests nach einer benutzerdefinierten Annotation filtern oder Testoptionen angeben. Da die Testausführung vollständig über die Befehlszeile gesteuert wird, können Sie Ihre Tests mit Shell-Skripten auf verschiedene Weise anpassen.
Wenn Sie einen Test über die Befehlszeile ausführen möchten, starten Sie mit adb shell eine Befehlszeilen-Shell auf Ihrem Gerät oder Emulator. In dieser Shell können Sie mit dem
Aktivitätsmanager
mit dem Befehl am interagieren und mit dem Unterbefehl instrument Ihre Tests ausführen.
Alternativ können Sie eine adb-Shell starten, am instrument aufrufen und Befehlszeilen-Flags in einer Eingabezeile angeben. Die Shell wird auf dem Gerät oder Emulator geöffnet, führt Ihre Tests aus, erzeugt eine Ausgabe und kehrt dann zur Befehlszeile auf Ihrem Computer zurück.
So führen Sie einen Test mit am instrument aus:
- Erstellen Sie Ihr Hauptanwendungs- und Testpaket oder erstellen Sie es neu.
- Installieren Sie die Android-Paketdateien (APK-Dateien) Ihres Testpakets und Ihrer Hauptanwendung auf Ihrem aktuellen Android-Gerät oder Emulator.
Geben Sie in der Befehlszeile Folgendes ein:
adb shell am instrument -w <test_package_name>/<runner_class>Dabei ist
<test_package_name>der Android-Paketname Ihrer Test anwendung und<runner_class>der Name der Android-Testausführungsklasse, die Sie verwenden. Der Android-Paketname ist der Wert des Paketattributs des Manifestelements in der Manifestdatei (AndroidManifest.xml) Ihres Testpakets.Die Android-Testausführungsklasse ist normalerweise
AndroidJUnitRunner:adb shell am instrument -w com.android.example/androidx.test.runner.AndroidJUnitRunner
Ihre Testergebnisse werden in STDOUT angezeigt.
am instrument-Flags
Eine Liste aller Flags, die Sie mit dem Befehl am instrument verwenden können, finden Sie mit adb shell am help. Einige wichtige Flags werden in der folgenden Tabelle beschrieben:
Tabelle 2 Wichtige am instrument-Flags
| Flag | Wert | Beschreibung |
|---|---|---|
-w
|
(keine) |
Erzwingt, dass am instrument wartet, bis die Instrumentierung
beendet ist, bevor es selbst beendet wird. Dadurch bleibt die
Shell geöffnet, bis die Tests abgeschlossen sind. Dieses Flag ist erforderlich, um die Ergebnisse Ihrer Tests zu sehen.
|
-r
|
(keine) |
Gibt Ergebnisse im Rohformat aus. Verwenden Sie dieses Flag, wenn Sie
Leistungsmessungen erfassen möchten, damit sie nicht als
Testergebnisse formatiert werden. Dieses Flag ist für die Verwendung mit dem Flag
-e perf true vorgesehen (siehe Abschnitt Optionen für „am instrument“).
|
-e
|
<test_options>
|
Bietet Testoptionen als Schlüssel/Wert-Paare. Das
am instrument Tool übergibt diese mit der
Methode an die angegebene
onCreate()
Instrumentierungsklasse. Sie können
-e <test_options> mehrmals angeben. Die Schlüssel und Werte werden im
Abschnitt Optionen für „am instrument“ beschrieben. Sie können
diese Schlüssel/Wert-Paare nur mit
AndroidJUnitRunner
oder mit InstrumentationTestRunner
und seinen Unterklassen verwenden. Die Verwendung mit einer anderen Klasse hat keine Auswirkungen.
|
--no-hidden-api-checks
|
(keine) | Deaktiviert Einschränkungen für die Verwendung verborgener APIs. Weitere Informationen zu verborgenen APIs und dazu, wie sich das auf Ihre App auswirken kann, finden Sie unter Einschränkungen für Nicht-SDK-Schnittstellen. |
Optionen für „am instrument“
Das Tool am instrument übergibt Testoptionen in Form von Schlüssel/Wert-Paaren mit dem Flag -e an AndroidJUnitRunner oder InstrumentationTestRunner. Die Syntax sieht so aus:
-e <key> <value>
Einige Schlüssel akzeptieren mehrere Werte. Sie geben mehrere Werte in einer durch Kommas getrennten Liste an. Bei diesem Aufruf von AndroidJUnitRunner werden beispielsweise mehrere Werte für den Schlüssel package angegeben:
adb shell am instrument -w -e package com.android.test.package1,com.android.test.package2 \
> com.android.test/androidx.test.runner.AndroidJUnitRunnerIn der folgenden Tabelle sind die Schlüssel/Wert-Paare aufgeführt, die Sie mit Ihrer Testausführung verwenden können:
Tabelle 3 Schlüssel/Wert-Paare für das Flag „-e“ für die Verwendung mit Ihrer Testausführung
| Schlüssel | Wert | Beschreibung |
|---|---|---|
package
|
<Java_package_name>
|
Der voll qualifizierte Java-Paketname für eines der Pakete in der Testanwendung. Alle Testfallklassen, die diesen Paketnamen verwenden, werden ausgeführt. Beachten Sie, dass dies kein Android-Paketname ist. Ein Testpaket hat einen einzelnen Android-Paketnamen, kann aber mehrere Java-Pakete enthalten. |
class |
<class_name> |
Der voll qualifizierte Java-Klassenname für eine der Testfall klassen. Nur diese Testfallklasse wird ausgeführt. |
<class_name>#method name |
Ein voll qualifizierter Testfallklassenname und eine seiner Methoden. Nur diese Methode wird ausgeführt. Beachten Sie das Hash-Zeichen (#) zwischen dem Klassen namen und dem Methodennamen. | |
func |
true |
Führt alle Testklassen aus, die
InstrumentationTestCase erweitern.
|
unit |
true |
Führt alle Testklassen aus, die nicht erweitern, weder
InstrumentationTestCase noch
PerformanceTestCase.
|
size |
[small | medium | large]
|
Führt eine Testmethode aus, die nach Größe annotiert ist. Die Annotationen sind
@SmallTest, @MediumTest und
@LargeTest.
|
perf |
true |
Führt alle Testklassen aus, die
PerformanceTestCase implementieren.
Wenn Sie diese Option verwenden, geben Sie das -r Flag für
am instrument an, damit die Ausgabe im Rohformat bleibt
und nicht als Testergebnisse neu formatiert wird.
|
debug |
true |
Führt Tests im Debug-Modus aus. |
log |
true |
Lädt und protokolliert alle angegebenen Tests, führt sie aber nicht aus. Die Test
Informationen werden in STDOUT angezeigt. Verwenden Sie diese Option, um
Kombinationen anderer Filter und Testspezifikationen zu prüfen.
|
emma |
true |
Führt eine EMMA-Codeabdeckungsanalyse aus und schreibt die Ausgabe auf dem Gerät in
/data/<app_package>/coverage.ec. Wenn Sie den Speicherort der Datei überschreiben möchten, verwenden Sie den coverageFile Schlüssel
der im folgenden Eintrag beschrieben wird.
Hinweis: Für diese Option ist ein EMMA-instrumentierter
Build der Testanwendung erforderlich, den Sie mit dem
|
coverageFile |
<filename> |
Überschreibt den standardmäßigen Standort der EMMA-Abdeckungsdatei auf dem Gerät. Geben Sie diesen Wert als Pfad und Dateinamen im UNIX-Format an.
Der Standarddateiname wird im Eintrag für den
emma Schlüssel beschrieben.
|
Beachten Sie bei der Verwendung des Flags -e Folgendes:
am instrumentruftonCreate(Bundle)mit einemBundleauf, das die Schlüssel/Wert Paare enthält.- Der Schlüssel
packagehat Vorrang vor dem Schlüsselclass. Wenn Sie ein Paket angeben und dann separat eine Klasse in diesem Paket angeben, führt Android alle Tests im Paket aus und ignoriert den Klassenschlüssel. - Die Schlüssel
funcundunitschließen sich gegenseitig aus.
Beispiele für die Verwendung
In den folgenden Abschnitten finden Sie Beispiele für die Verwendung von am instrument zum Ausführen von Tests.
Sie basieren auf der folgenden Struktur:
- Das Testpaket hat den Android-Paketnamen
com.android.demo.app.tests. - Zwei instrumentierte Testklassen:
TestClass1mit der TestmethodetestMethod1.TestClass2mit den TestmethodentestMethod2undtestMethod3.
- Die Testausführung ist
AndroidJUnitRunner.
Gesamtes Testpaket ausführen
Geben Sie Folgendes ein, um alle Testklassen im Testpaket auszuführen:
adb shell am instrument -w com.android.demo.app.tests/androidx.test.runner.AndroidJUnitRunnerAlle Tests in einer Testfallklasse ausführen
Geben Sie Folgendes ein, um alle Tests in der Klasse TestClass1 auszuführen:
adb shell am instrument -w \
> -e class com.android.demo.app.tests.TestClass1 \
> com.android.demo.app.tests/androidx.test.runner.AndroidJUnitRunnerTeilmenge von Tests auswählen
Geben Sie Folgendes ein, um alle Tests in der Klasse TestClass1 und die Methode testMethod3 in TestClass2 auszuführen:
adb shell am instrument -w \
> -e class com.android.demo.app.tests.TestClass1,com.android.demo.app.tests.TestClass2#testMethod3 \
> com.android.demo.app.tests/androidx.test.runner.AndroidJUnitRunnerWeitere Anwendungsfälle finden Sie in der
AndroidJUnitRunner
API-Referenz.
Einheitliche Testberichte ansehen
Das Android-Gradle-Plug-in bietet Aufgaben für einheitliche Testberichte, mit denen HTML-Dashboards generiert werden, in denen die Ergebnisse von Einheitentests und instrumentierten Tests zusammengeführt werden.
Voraussetzungen
- Android-Gradle-Plug-in 9.2.0-alpha07 oder höher.
Führen Sie eine der folgenden Aufgaben aus, um einheitliche Testberichte zu generieren:
| Berichtsumfang | Befehl | Beschreibung | Speicherort des Berichts |
|---|---|---|---|
| Aktuelles Modul | ./gradlew :module_name:createTestReport |
Generiert einen einheitlichen Testbericht für das aktuelle Modul, in dem die Ergebnisse von Einheitentests und instrumentierten Tests zusammengeführt werden. | path_to_your_project/module_name/build/reports/tests/test-report/ |
| Aktuelles Modul und Abhängigkeiten | ./gradlew :module_name:createAggregatedTestReport |
Generiert einen einheitlichen Testbericht für das aktuelle App-Modul und seine Bibliotheksabhängigkeiten. | path_to_your_project/module_name/build/reports/tests/aggregated-test-report/ |