In diesem Leitfaden wird beschrieben, wie Sie AAB-Builds mit fastlane an Tester verteilen. fastlane ist eine Open-Source-Plattform, mit der das Erstellen und Veröffentlichen von iOS- und Android-Apps automatisiert wird. Es folgt einer einfachen Anleitung, die in einer Fastfile
definiert ist. Nachdem du fastlane und deine Fastfile
eingerichtet hast, kannst du App Distribution in deine fastlane-Konfiguration einbinden.
App Distribution ist in den internen App-Freigabedienst von Google Play eingebunden, um die von Ihnen hochgeladenen AABs zu verarbeiten und APKs bereitzustellen, die für die Gerätekonfigurationen Ihrer Tester optimiert sind. Wenn Sie AABs bereitstellen, haben Sie folgende Möglichkeiten:
Optimierte APKs (von Google Play bereitgestellt) ausführen, die für die Geräte Ihrer Tester optimiert sind.
Gerätespezifische Probleme erkennen und beheben
App-Bundle-Funktionen wie Play Feature Delivery und Play Asset Delivery testen
Verringern Sie die Größe der Downloads für Ihre Tester.
Erforderliche Berechtigungen
Wenn Sie AABs auf App Distribution hochladen möchten, müssen Sie Ihre Firebase-App mit einer App in Google Play verknüpfen. Sie benötigen die erforderliche Zugriffsebene, um diese Aktionen ausführen zu können.
Wenn Sie keinen erforderlichen Firebase-Zugriff haben, können Sie einen Firebase-Projektinhaber bitten, Ihnen über die IAM-Einstellungen in der Firebase Console die entsprechende Rolle zuzuweisen. Wenn Sie Fragen zum Zugriff auf Ihr Firebase-Projekt haben, einschließlich zum Finden oder Zuweisen eines Inhabers, lesen Sie die häufig gestellten Fragen zu Berechtigungen und Zugriff auf Firebase-Projekte.
Die folgende Tabelle gilt für die Verknüpfung einer Firebase-App mit einer App in Google Play sowie für das Hochladen von AABs.
Aktion in der Firebase Console | Erforderliche IAM-Berechtigung | IAM-Rollen, die standardmäßig die erforderlichen Berechtigungen enthalten | Zusätzliche erforderliche Rollen |
---|---|---|---|
Firebase-App mit einer App in Google Play verknüpfen | firebase.playLinks.update
|
Eine der folgenden Rollen: | Zugriff auf ein Google Play-Entwicklerkonto als Administrator |
AABs in App Distribution hochladen | firebaseappdistro.releases.update
|
Eine der folgenden Rollen: | –– |
Hinweis
Fügen Sie Ihrem Android-Projekt Firebase hinzu, falls noch nicht geschehen. Am Ende dieses Workflows haben Sie eine Firebase-Android-App in Ihrem Firebase-Projekt.
Wenn Sie keine anderen Firebase-Produkte verwenden, müssen Sie nur ein Projekt erstellen und Ihre App registrieren. Wenn Sie zusätzliche Produkte verwenden möchten, müssen Sie alle Schritte unter Firebase Ihrem Android-Projekt hinzufügen ausführen.
Ihre App muss die folgenden Anforderungen erfüllen, um eine Firebase-Verknüpfung zu Google Play zu erstellen und Android App Bundles hochzuladen:
Die App in Google Play und die Firebase-Android-App sind unter demselben Paketnamen registriert.
Die App in Google Play wird im App-Dashboard eingerichtet und über einen der Google Play-Tracks veröffentlicht (interner, geschlossener oder offener Test bzw. Produktion).
Die Überprüfung der App in Google Play ist abgeschlossen und die App wird veröffentlicht. Ihre App wird veröffentlicht, wenn in der Spalte App-Status einer der folgenden Status angezeigt wird: „Interner Test“ (nicht „Entwurf“), „Geschlossener Test“, „Offener Test“ oder „Produktion“.
So verknüpfen Sie Ihre Firebase-Android-App mit Ihrem Google Play-Entwicklerkonto:
Rufen Sie in der Firebase-Konsole Ihre
auf und wählen Sie dann den Tab Integrationen aus. Projekteinstellungen Klicken Sie auf der Karte Google Play auf Verknüpfen.
Wenn Sie bereits Verknüpfungen mit Google Play haben, klicken Sie stattdessen auf Verwalten.Folgen Sie der Anleitung auf dem Bildschirm, um die App Distribution-Integration zu aktivieren und auszuwählen, welche Firebase-Android-Apps mit Google Play verknüpft werden sollen.
Schritt 1: fastlane einrichten
Wenn Sie App Distribution Ihrer Fastlane-Konfiguration hinzufügen möchten, führen Sie den folgenden Befehl im Stammverzeichnis Ihres Android-Projekts aus:
fastlane add_plugin firebase_app_distribution
Wenn Sie nach einer Option gefragt werden, wählen Sie
Option 3: RubyGems.org
aus.
Schritt 2: Mit Firebase authentifizieren
Bevor Sie das Fastlane-Plug-in verwenden können, müssen Sie sich auf eine der folgenden Arten mit Ihrem Firebase-Projekt authentifizieren. Standardmäßig sucht das Fastlane-Plug-in nach Anmeldedaten aus der Firebase-Befehlszeile, wenn keine andere Authentifizierungsmethode verwendet wird.
Schritt 3: Fastfile einrichten und App verteilen
- Fügen Sie einer
./fastlane/Fastfile
-Fahrspur einenfirebase_app_distribution
-Block hinzu. Verwenden Sie die folgenden Parameter, um die Verteilung zu konfigurieren:Parameter „firebase_app_distribution“ app
Erforderlich: Die Firebase-App-ID Ihrer App. Sie finden die App-ID in der Firebase Console auf der Seite Allgemeine Einstellungen.
app: "1:1234567890:android:0a1b2c3d4e5f67890"
firebase_cli_token
Ein Aktualisierungstoken, das ausgegeben wird, wenn Sie Ihre CI-Umgebung mit der Firebase CLI authentifizieren. Weitere Informationen finden Sie unter CLI mit CI-Systemen verwenden.
service_credentials_file
Der Pfad zur JSON-Datei Ihres Google-Dienstkontos. Informationen zur Authentifizierung mithilfe der Anmeldedaten des Dienstkontos
android_artifact_type
Gibt den Android-Dateityp (APK oder AAB) an.
android_artifact_path
Ersetzt
apk_path
(eingestellt). Absoluter Pfad zur APK- oder AAB-Datei, die Sie hochladen möchten. Wenn Sie keinen Speicherort angeben, ermittelt fastlane den Speicherort der Datei anhand der Lane, in der die Datei generiert wurde.release_notes
release_notes_file
Versionshinweise für diesen Build.
Sie können die Versionshinweise entweder direkt angeben:
release_notes: "Text of release notes"
Alternativ können Sie den Pfad zu einer Klartextdatei angeben:
release_notes_file: "/path/to/release-notes.txt"
testers
testers_file
Die E-Mail-Adressen der Tester, die Sie einladen möchten.
Sie können die Tester als durch Kommas getrennte Liste von E-Mail-Adressen angeben:
testers: "ali@example.com, bri@example.com, cal@example.com"
Sie können auch den Pfad zu einer Nur-Text-Datei angeben, die eine durch Kommas getrennte Liste von E-Mail-Adressen enthält:
testers_file: "/path/to/testers.txt"
groups
groups_file
Die Testergruppen, die Sie einladen möchten (siehe Tester verwalten). Gruppen werden mit
Gruppenaliassen angegeben, die Sie in der Firebase-Konsole nachschlagen können.Sie können die Gruppen als durch Kommas getrennte Liste angeben:
groups: "qa-team, trusted-testers"
Alternativ können Sie den Pfad zu einer Nur-Text-Datei angeben, die eine durch Kommas getrennte Liste von Gruppennamen enthält:
groups_file: "/path/to/groups.txt"
test_devices
test_devices_file
Die folgenden Verteilungstypen sind Teil der Betafunktion „Automatischer Tester“.
Die Testgeräte, auf die Sie Builds verteilen möchten (siehe Automatisierte Tests).
Sie können die Testgeräte als durch Semikolons getrennte Liste angeben:
test_devices: "model=shiba,version=34,locale=en,orientation=portrait;model=b0q,version=33,locale=en,orientation=portrait"
Alternativ können Sie den Pfad zu einer Nur-Text-Datei angeben, die eine durch Semikolons getrennte Liste von Testgeräten enthält:
test_devices_file: "/path/to/test-devices.txt"
test_username
Der Nutzername für die automatische Anmeldung bei automatischen Tests.
test_password
test_password_file
Das Passwort für die automatische Anmeldung bei automatisierten Tests.
Sie können auch den Pfad zu einer Nur-Text-Datei mit einem Passwort angeben:
test_password_file: "/path/to/test-password.txt"
test_username_resource
Ressourcenname für das Feld „Nutzername“ für die automatische Anmeldung bei automatisierten Tests.
test_password_resource
Ressourcenname für das Passwortfeld für die automatische Anmeldung, das bei automatisierten Tests verwendet werden soll.
test_non_blocking
Automatisierte Tests asynchron ausführen. Die Ergebnisse des automatischen Tests finden Sie in der Firebase Console.
debug
Ein boolescher Wert. Sie können diesen Wert auf
true
setzen, um eine ausführliche Debug-Ausgabe zu erhalten.
platform :android do desc "My awesome app" lane :distribute do build_android_app(task: "bundle", ...) # build_android_app is a built-in fastlane action. release = firebase_app_distribution( app: "1:123456789:android:abcd1234", testers: "tester1@company.com, tester2@company.com", release_notes: "Lots of amazing new features to test out!", android_artifact_type: "AAB" ) end end
Führen Sie die folgenden Schritte aus, um den Build für Tester verfügbar zu machen:
fastlane <lane>
Der Rückgabewert der Aktion ist ein Hash, der die hochgeladene Version darstellt.
Dieser Hash ist auch mit lane_context[SharedValues::FIREBASE_APP_DISTRO_RELEASE]
verfügbar.
Weitere Informationen zu den verfügbaren Feldern in diesem Hash finden Sie in der REST API-Dokumentation.
Das Fastlane-Plug-in gibt nach dem Upload der Release-Version die folgenden Links aus. Über diese Links können Sie Binärdateien verwalten und dafür sorgen, dass Tester und andere Entwickler die richtige Version haben:
- Ein Link zur Firebase-Konsole mit einer einzelnen Version. Sie können diesen Link mit anderen Entwicklern in Ihrer Organisation teilen.
- Ein Link zum Release in der Testeroberfläche (native Android-App), über den Tester Release-Notes aufrufen und die App auf ihrem Gerät installieren können. Der Tester benötigt Zugriff auf die Version, um den Link verwenden zu können.
- Ein signierter Link, über den die App-Binärdatei (APK- oder AAB-Datei) direkt heruntergeladen und installiert wird. Der Link läuft nach einer Stunde ab.
Nachdem Sie Ihren Build bereitgestellt haben, ist er 150 Tage lang im App Distribution-Dashboard der Firebase-Konsole verfügbar. Wenn der Build in 30 Tagen abläuft, wird in der Konsole und in der Liste der Builds des Testers auf seinem Testgerät eine entsprechende Benachrichtigung angezeigt.
Tester, die zuvor nicht zum Testen der App eingeladen wurden, erhalten eine E-Mail-Einladung. Vorhandene Tester erhalten E-Mail-Benachrichtigungen, dass ein neuer Build zum Testen bereit ist. Informationen zum Installieren der Test-App finden Sie im Leitfaden zur Einrichtung von Testern. In der Firebase-Konsole können Sie den Status der einzelnen Tester prüfen, um festzustellen, ob sie die Einladung angenommen und die App heruntergeladen haben.
Optional: Wenn Sie die Build-Nummer jedes Mal automatisch erhöhen möchten, wenn Sie einen neuen Release in der App-Bereitstellung erstellen, können Sie die Aktion firebase_app_distribution_get_latest_release
und beispielsweise das increment_version_code
Fastlane-Plug-in verwenden.
Im folgenden Codebeispiel wird gezeigt, wie die Build-Nummer automatisch erhöht wird:
lane :increment_version do
latest_release = firebase_app_distribution_get_latest_release(
app: "<your Firebase app ID>"
)
increment_version_code({ version_code: latest_release[:buildVersion].to_i + 1 })
end
Weitere Informationen zur Aktion firebase_app_distribution_get_latest_release
finden Sie unter Informationen zum neuesten Release Ihrer App abrufen.
Schritt 4 (optional) Tester für die Verteilung verwalten
Sie können Tester über die Datei Fastfile
oder durch direkte Ausführung von Fastlane-Aktionen zu Ihrem Projekt oder Ihrer Gruppe hinzufügen und daraus entfernen. Wenn Sie Aktionen direkt ausführen, werden die in Ihrer Fastfile
festgelegten Werte überschrieben.
Nachdem ein Tester Ihrem Firebase-Projekt hinzugefügt wurde, können Sie ihn einzelnen Releases hinzufügen. Tester, die aus Ihrem Firebase-Projekt entfernt werden, haben keinen Zugriff mehr auf Releases in Ihrem Projekt. Möglicherweise haben sie aber noch für eine gewisse Zeit Zugriff auf Ihre Releases.
Wenn Sie eine große Anzahl von Testern haben, sollten Sie Gruppen verwenden.
Fastfile
verwenden
# Use lanes to add or remove testers from a project. lane(:add_testers) do firebase_app_distribution_add_testers( emails: "foo@google.com,bar@google.com" # or file: "/path/to/testers.txt" group_alias: "qa-team" # (Optional) add testers to this group ) end lane(:remove_testers) do firebase_app_distribution_remove_testers( emails: "foo@google.com,bar@google.com" # or file: "/path/to/testers.txt" group_alias: "qa-team" # (Optional) remove testers from this group only ) end
# Add or remove testers with the terminal
$ fastlane add_testers
$ fastlane remove_testers
Fastlane-Aktionen ausführen
fastlane run firebase_app_distribution_create_group display_name:"QA Team" alias:"qa-team"
fastlane run firebase_app_distribution_add_testers group_alias:"qa-team" emails:"foo@google.com,bar@google.com"
fastlane run firebase_app_distribution_remove_testers group_alias:"qa-team" emails:"foo@google.com,bar@google.com"
fastlane run firebase_app_distribution_delete_group alias:"qa-team"
Sie können Tester auch mit --file="/path/to/testers.txt
anstelle von --emails
angeben.
Für die Aufgaben firebase_app_distribution_add_testers
und firebase_app_distribution_remove_testers
sind außerdem die folgenden Argumente zulässig:
project_name
: Ihre Firebase-Projektnummer.group_alias
(optional): Wenn angegeben, werden die Tester der angegebenen Gruppe hinzugefügt oder daraus entfernt.service_credentials_file
: Der Pfad zur Anmeldedatendatei für Google-Dienste.firebase_cli_token
: Authentifizierungstoken für die Firebase-Befehlszeile.
service_credentials_file
und firebase_cli_token
sind dieselben Argumente, die von der Upload-Aktion verwendet werden.
Schritt 5 (optional): Informationen zur neuesten Version Ihrer App abrufen
Mit der Aktion firebase_app_distribution_get_latest_release
können Sie Informationen zum neuesten Release Ihrer App in der App-Distribution abrufen, einschließlich Informationen zur App-Version, Versionshinweisen und Erstellungszeit. Anwendungsfälle umfassen das automatische Erhöhen der Version und das Übertragen der Release-Hinweise aus dem vorherigen Release.
Der Rückgabewert der Aktion ist ein Hashwert, der den neuesten Release darstellt.
Dieser Hash ist auch mit lane_context[SharedValues::FIREBASE_APP_DISTRO_LATEST_RELEASE]
verfügbar.
Weitere Informationen zu den verfügbaren Feldern in diesem Hash finden Sie in der REST API-Dokumentation.
Parameter
Parameter für „firebase_app_distribution_get_latest_release“ | |
---|---|
app
|
Erforderlich: Die Firebase-App-ID Ihrer App. Sie finden die App-ID in der Firebase Console auf der Seite Allgemeine Einstellungen. app: "1:1234567890:android:0a1b2c3d4e5f67890" |
firebase_cli_token
|
Ein Aktualisierungstoken, das ausgegeben wird, wenn Sie Ihre CI-Umgebung mit der Firebase CLI authentifizieren. Weitere Informationen finden Sie unter CLI mit CI-Systemen verwenden. |
service_credentials_file
|
Der Pfad zur JSON-Datei Ihres Google-Dienstkontos. Informationen zur Authentifizierung mithilfe der Anmeldedaten des Dienstkontos |
debug
|
Ein boolescher Wert. Sie können diesen Wert auf |
Nächste Schritte
Implementieren Sie In-App-Feedback, damit Tester ganz einfach Feedback zu Ihrer App senden können (einschließlich Screenshots).
Best Practices für die Bereitstellung von Android-Apps für QA-Tester mit CI/CD