Les SDK Firebase App Distribution et Android facultatifs vous permettent d'afficher des alertes intégrées à vos testeurs lorsque de nouvelles versions de votre application sont disponibles ; l'installation. Ce guide explique comment utiliser les SDK App Distribution pour iOS et Android pour créer et personnaliser des alertes de compilation pour vos testeurs.
Avant de commencer
Si ce n'est pas encore fait, ajoutez Firebase à votre projet iOS.
Étape 1 : Activez l'API App Distribution Tester
Sélectionnez votre projet dans la console Google Cloud.
Sous API Firebase App Testers, cliquez sur Activer.
Étape 2 : Ajoutez App Distribution à votre application
Ouvrez le Podfile que vous avez créé pour le projet (ou exécutez
pod init
pour créer 1), puis ajoutez la ligne suivante dans la section cible:pod 'FirebaseAppDistribution'
Dans le répertoire de votre fichier Podfile, exécutez
pod install
, puis ouvrez le fichier a créé le fichier.xcworkspace
.Importez le module Firebase dans votre structure
App
ouUIApplicationDelegate
:Swift
import FirebaseCore import FirebaseAppDistribution
Objective-C
@import FirebaseCore; @import FirebaseAppDistribution;
Configurez une instance partagée
FirebaseApp
dans le délégué de votre application Méthodeapplication(_:didFinishLaunchingWithOptions:)
:Swift
// Use Firebase library to configure APIs FirebaseApp.configure()
Objective-C
// Use Firebase library to configure APIs [FIRApp configure];
Si le forçage de l'ordre des caractères est désactivé, transmettez toutes les URL ouvertes au SDK App Distribution dans votre implémentation de
application(_:open:options:)
:Swift
func application(_ app: UIApplication, open url: URL, options: [UIApplication.OpenURLOptionsKey : Any] = [:]) -> Bool { if AppDistribution.appDistribution().application(application, open: url, options: options) { return true } // Handle other non-Firebase URLs here. return false }
Objective-C
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey, id> *)options { if ([[FIRAppDistribution appDistribution] application:app openURL:url options:options]) { return YES; } // Handle other non-Firebase URLs here. return NO; }
Enfin, recompilez votre application.
Étape 3: Configurez des alertes dans l'application
Le SDK App Distribution propose deux façons de configurer des alertes de compilation dans l'application pour vos testeurs : une configuration d'alerte de base, qui est fournie avec des boîtes de dialogue de mise à jour et de connexion prédéfinies à afficher aux testeurs, et une configuration d'alerte avancée, qui vous permet de personnaliser votre propre interface utilisateur. Mer recommandez d'abord d'utiliser la configuration d'alerte de base si vous débutez avec SDK App Distribution.
Configuration de base
Utilisez checkForUpdate
pour afficher une boîte de dialogue d'activation des alertes prédéfinie pour
des testeurs n'ayant pas encore activé les alertes, puis vérifiez si une nouvelle compilation est
disponibles. Lorsqu'elle est appelée, la méthode exécute la séquence suivante :
Vérifie si un testeur a activé les alertes en l'invitant à se connecter App Distribution avec son compte Google.
Si le testeur n'a pas encore activé les alertes, une boîte de dialogue prédéfinie s'affiche.
L'activation des alertes est un processus ponctuel sur l'appareil de test et persiste lors des mises à jour de votre application. Les alertes restent activées sur l'appareil de test jusqu'à ce que l'application soit désinstallée ou que la méthode
signOutTester
soit appelée. Pour en savoir plus, consultez la documentation de référence de la méthode (Swift ou Objective-C).Vérifie les nouveaux builds que le testeur peut installer.
Vous pouvez appeler checkForUpdate()
à tout moment dans votre application. Par exemple :
pouvez inviter vos testeurs à installer les nouveaux builds disponibles au démarrage en
inclure checkForUpdate()
dans le onAppear(perform:)
de la racine de votre application
vue.
L'exemple suivant vérifie si le testeur a activé les alertes et s'il a accès à une nouvelle version. Si c'est le cas, un message s'affiche lorsque la version est disponible à l'installation :
Swift
AppDistribution.appDistribution().checkForUpdate(completion: { release, error in
if error != nil {
// Handle error
return
}
guard let release = release else {
return
}
// Customize your alerts here.
let title = "New Version Available"
let message = "Version \(release.displayVersion)(\(release.buildVersion)) is available."
let uialert = UIAlertController(title: title,message: message, preferredStyle: .alert)
uialert.addAction(UIAlertAction(title: "Update", style: UIAlertAction.Style.default) {
_ in
UIApplication.shared.open(release.downloadURL)
})
uialert.addAction(UIAlertAction(title: "Cancel", style: UIAlertAction.Style.cancel) {
_ in
})
// self should be a UIViewController.
self.present(uialert, animated: true, completion: nil)
})
Objective-C
[[FIRAppDistribution appDistribution]
checkForUpdateWithCompletion:^(FIRAppDistributionRelease *_Nullable release,
NSError *_Nullable error) {
if (error) {
// Handle error
return;
}
if (release) {
UIAlertController *alert = [UIAlertController alertControllerWithTitle:@"New Version Available"
message:[NSString stringWithFormat:@"Version %@ (%@) is available.", release.displayVersion,
release.buildVersion] preferredStyle:UIAlertControllerStyleAlert];
UIAlertAction *updateAction = [UIAlertAction actionWithTitle:@"Update"
style:UIAlertActionStyleDefault handler:^(UIAlertAction *action) {
[[UIApplication sharedApplication] openURL:release.downloadURL options:@{}
completionHandler:nil];
}];
UIAlertAction *cancelAction = [UIAlertAction actionWithTitle:@"Cancel"
style:UIAlertActionStyleCancel handler:^(UIAlertAction *action) {}];
[alert addAction:updateAction];
[alert addAction:cancelAction];
[self presentViewController:alert animated:YES completion:nil];
}
}];
Configuration avancée
Les méthodes signInTester()
et isTesterSignedIn
vous offrent plus de flexibilité
personnaliser l'expérience de connexion du testeur afin qu'elle corresponde mieux à votre
de votre application.
L'exemple suivant vérifie si le testeur s'est déjà connecté à son compte de testeur Firebase App Distribution. Vous pouvez ainsi choisir d'afficher votre UI de connexion uniquement pour les testeurs qui ne se sont pas encore connectés. Une fois que le testeur s'est connecté, vous pouvez appeler checkForUpdate()
pour vérifier s'il a accès à une nouvelle version.
Swift
// Sign in a tester without automatically checking for update
if (!AppDistribution.appDistribution().isTesterSignedIn) {
AppDistribution.appDistribution().signInTester (completion: { error in
// completion block for signInTester
if (error != nil) {
// handle failed sign in
return
}
// handle successful sign in
})
}
// Only check for update if tester is already signed in - do not prompt
if (AppDistribution.appDistribution().isTesterSignedIn) {
AppDistribution.appDistribution().checkForUpdate(completion: { release, error in
// completion block for check for update
})
}
Objective-C
// Sign in a tester without automatically checking for update
if(![[FIRAppDistribution appDistribution] isTesterSignedIn]) {
[[FIRAppDistribution appDistribution]
signInTesterWithCompletion:^(NSError *_Nullable error) {
// completion block for signInTester
if (error) {
// handle failed sign in
return;
}
// handle successful sign in
}];
}
// only check for update if tester is already signed in - do not prompt
if([[FIRAppDistribution appDistribution] isTesterSignedIn]) {
[[FIRAppDistribution appDistribution]
checkForUpdateWithCompletion:^(FIRAppDistributionRelease *_Nullable release,
NSError *_Nullable error) {
// completion block for check for update
}];
}
Pour en savoir plus sur d'autres méthodes, y compris signOutTester()
, consultez la documentation de référence App Distribution pour Swift et Objective-C.
Étape 4: Créez et testez votre mise en œuvre
Enfin, créez votre application et testez votre implémentation en distribuer la compilation aux testeurs à l'aide de la console Firebase.
Consultez le App Distribution Guide de dépannage pour obtenir de l'aide concernant des problèmes courants, par exemple:
- Le testeur ne reçoit pas d'alertes dans l'application
- Le testeur est invité à se connecter à Google plusieurs fois