Mit der Google Cloud CLI testen

In diesem Leitfaden wird beschrieben, wie Sie einen XCTest oder einen Game Loop-Test mit der gcloud CLI ausführen.

Schritt 1: Lokale Google Cloud SDK-Umgebung konfigurieren

  1. Google Cloud SDK herunterladen
  2. Dazu gehört auch das gcloud-CLI-Tool.

  3. Prüfen Sie, ob Ihre Installation auf dem neuesten Stand ist und den Befehl gcloud firebase enthält:
          gcloud components update
  4. Melden Sie sich mit Ihrem Google-Konto in der gcloud CLI an:
          gcloud auth login
  5. Legen Sie Ihr Firebase-Projekt in gcloud fest. Dabei steht PROJECT_ID für die ID Ihres Firebase-Projekts:
         gcloud config set project PROJECT_ID

Schritt 2: Test ausführen

XCTest ausführen

  1. Laden Sie die ZIP-Datei Ihres Tests mit dem folgenden Befehl hoch. Wenn Sie Ihre App noch nicht verpackt haben, lesen Sie den Hilfeartikel XCTest-Paket erstellen.

    cd FOLDER_WITH_TEST_OUTPUT/Build/Products ; \
    zip -r MyTests.zip Debug-iphoneos YOUR_SCHEME_iphoneosDEPLOYMENT_TARGET-arm64.xctestrun
  2. Wählen Sie die Testdimensionen aus.

    Mit Test Lab können Sie Tests auf verschiedenen iOS-Versionen, Geräten, Bildschirmausrichtungen und Sprachen ausführen. Diese Konfigurationen werden als Testdimensionen bezeichnet. Wenn Sie die Optionen für die einzelnen Dimensionen sehen möchten (z.B. unterstützte Xcode-Versionen für die iOS-Version des Geräts), ersetzen Sie im folgenden Befehl dimension durch models, versions oder locales:

    gcloud firebase test ios dimension list

    Die Bildschirmausrichtung ist etwas einfacher, da nur die Optionen portrait und landscape verfügbar sind.

    Sehen Sie sich die Liste der Testdimensionen an und wählen Sie einige Kombinationen aus, für die Sie den Test ausführen möchten. Unter Preismodelle finden Sie die maximale Anzahl von Kombinationen, die Sie pro Tag ausführen können.

  3. Nachdem Sie eine Reihe von Testdimensionen ausgewählt haben, können Sie die Tests mit dem Befehl firebase test ios run ausführen.Test Lab Fügen Sie für jede Kombination von Testdimensionen, die Sie testen möchten, ein separates --device-Flag ein:

    gcloud firebase test ios run --test PATH/TO/MyTests.zip \
     --device model=MODEL_ID_1,version=VERSION_ID_1,locale=LOCALE_1,orientation=ORIENTATION_1 \
     --device model=MODEL_ID_2,version=VERSION_ID_2,locale=LOCALE_2,orientation=ORIENTATION_2 \
     etc...

    Es ist möglich, dass der Test aufgrund einer Inkompatibilität zwischen der Xcode-Version, mit der der Test erstellt wurde, und der von Test Lab verwendeten Standard-Xcode-Version fehlschlägt. Wenn Sie eine unterstützte Xcode-Version für Ihren Test angeben möchten, verwenden Sie das Flag --xcode-version:

    gcloud firebase test ios run --test PATH/TO/MyTests.zip \
     --device model=MODEL_ID_1,version=VERSION_ID_1,locale=LOCALE_1,orientation=ORIENTATION_1 \
     --xcode-version=15

    Damit Sie Ihre Testmatrizen in der Firebase-Konsole leichter finden, können Sie sie wie im folgenden Beispiel mit dem Flag --client-details matrixLabel="<label>" versehen:

    gcloud beta firebase test ios run --test PATH/TO/MyTests.zip \
      --device model=MODEL_ID_1,version=VERSION_ID_1,locale=LOCALE_1,orientation=ORIENTATION_1 \
      --client-details matrixLabel="my label"

Spezielle Berechtigungen testen

Wenn Sie Berechtigungen testen möchten, für die eine explizite App-ID erforderlich ist, können Sie das Flag --test-special-entitlements festlegen. Test Lab signiert die Anwendung noch einmal mit einer neuen Bundle-ID, um spezielle Berechtigungen zu unterstützen. Achten Sie daher darauf, dass sich in Ihrer ZIP-Datei keine Ressourcen befinden, die direkte Verweise auf die Bundle-ID der App enthalten.

Unterstützte Berechtigungen:
  1. Push-Benachrichtigungen apns-environment
  2. Persönliches VPN com.apple.developer.networking.vpn.api
Push-Benachrichtigungen

Zur Autorisierung von Push-Benachrichtigungsanfragen können Nutzer JSON-Webtokens erstellen. Dazu verwenden sie den privaten Signaturschlüssel zusammen mit der Schlüssel-ID C7FD9DJAA8 und der Team-ID 9CKCGNNUQN. Die generierten Tokens sind eine Stunde lang gültig und müssen alle 60 Minuten aktualisiert werden. Weitere Informationen finden Sie unter Herstellen einer tokenbasierten Verbindung zu APNs.

App-Gruppen

App-Gruppen-IDs sind global eindeutig. Das bedeutet, dass wir beim erneuten Signieren von Nutzer-Apps nur die App-Gruppen-ID verwenden können, die dem Test Lab-Entwicklerkonto zugewiesen ist. Wenn Ihr Test auf App-Gruppen basiert, schlägt er fehl.

Spielschleifentest ausführen

Führen Sie den Befehl gcloud beta firebase test ios run aus und verwenden Sie die folgenden Flags, um den Ablauf zu konfigurieren:

Flags für Spielschleifentests
--type

Erforderlich: Gibt den Typ des iOS-Tests an, den Sie ausführen möchten. Sie können die Testtypen xctest (Standard) oder game-loop eingeben.

--app

Erforderlich: Absoluter Pfad (GCS oder Dateisystem) zur IPA-Datei Ihrer App. Dieses Flag ist nur gültig, wenn Spielschleifentests ausgeführt werden.

--scenario-numbers

Die Schleifen (auch Szenarien genannt), die in Ihrer App ausgeführt werden sollen. Sie können eine Schleife, eine Liste von Schleifen oder einen Bereich von Schleifen eingeben. Die Standardschleife ist 1.

Beispiel: --scenario-numbers=1-3,5 führt die Schleifen 1, 2, 3 und 5 aus.

--device-model

Das physische Gerät, auf dem Sie den Test ausführen möchten (Hier finden Sie Informationen zu den verfügbaren Geräten).

--timeout

Die maximale Dauer, für die der Test laufen soll. Sie können eine Ganzzahl eingeben, um die Dauer in Sekunden anzugeben, oder eine Ganzzahl und eine Aufzählung, um die Dauer in einer längeren Zeiteinheit anzugeben.

Beispiel:

  • Mit --timeout=200 wird der Test nach 200 Sekunden beendet.
  • Mit --timeout=1h wird der Test nach einer Stunde beendet.

Mit dem folgenden Befehl wird beispielsweise ein Game Loop-Test ausgeführt, bei dem die Schleifen 1, 4, 6, 7 und 8 auf einem iPhone 8 Plus ausgeführt werden:

gcloud beta firebase test ios run
 --type game-loop --app path/to/my/App.ipa --scenario-numbers 1,4,6-8
 --device-model=iphone8plus

Weitere Informationen zur gcloud CLI finden Sie in der Referenzdokumentation.

Schritt 3 (optional): Künftige Tests automatisieren

gcloud-Befehle mit Test Lab in Skripts verwenden

Mit Shell-Scripts oder Batchdateien können Sie Befehle für mobile App-Tests automatisieren, die Sie sonst über die gcloud-Befehlszeile ausführen würden. In diesem Beispiel-Bash-Script wird ein XCTest mit einer Zeitüberschreitung von zwei Minuten ausgeführt und es wird gemeldet, ob der Test erfolgreich abgeschlossen wurde:

if gcloud firebase test ios run --test MyTest.zip --timeout 2m
then
    echo "Test matrix successfully finished"
else
    echo "Test matrix exited abnormally with non-zero exit code: " $?
fi

Script-Exit-Codes

Test Lab bietet mehrere Beendigungscodes, mit denen Sie die Ergebnisse von Tests besser nachvollziehen können, die Sie mit Scripts oder Batchdateien ausführen.

Exit-Code Hinweise
0 Alle Testausführungen wurden bestanden.
1 Ein allgemeiner Fehler ist aufgetreten. Mögliche Ursachen sind ein nicht vorhandener Dateiname oder ein HTTP-/Netzwerkfehler.
2 Die Tests wurden beendet, weil unbekannte Befehle oder Argumente angegeben wurden.
10 Mindestens einer der Testfälle (getestete Klassen oder Klassenmethoden) innerhalb einer Testausführung ist fehlgeschlagen.
15 Firebase Test Lab konnte aufgrund eines unerwarteten Fehlers nicht feststellen, ob die Testmatrix bestanden oder nicht bestanden hat.
19 Die Testmatrix wurde vom Nutzer abgebrochen.
20 Ein Fehler bei der Testinfrastruktur ist aufgetreten.

Schritt 4: Testergebnisse untersuchen

Zu Beginn des Tests erhalten Sie einen Link zur Seite Testergebnisse. Die Ausführung der Tests kann einige Minuten dauern, je nachdem, wie viele verschiedene Konfigurationen Sie ausgewählt haben und wie lang die Zeitüberschreitung für die Tests ist. Nach Abschluss der Tests können Sie die Testergebnisse überprüfen. Weitere Informationen zur Interpretation Ihrer Testergebnisse finden Sie unter Firebase Test Lab-Ergebnisse analysieren.

Nächster Schritt

In der Google Cloud SDK-Dokumentation finden Sie Informationen zu Testoptionen, die allgemein verfügbar oder in der Betaphase sind.