Bonnes pratiques pour distribuer des applications Apple aux testeurs de contrôle qualité à l'aide de la CI/CD et de Fastlane

Ce document présente les bonnes pratiques d'utilisation de Firebase App Distribution et fastlane pour rendre vos workflows de test préliminaire sur la plate-forme Apple durables et reproductibles dans un environnement CI/CD. Bien que ce document se concentre sur fastlane, nous décrivons également les solutions disponibles via la Firebase console, la Firebase CLI et l'API publique Firebase App Distribution pour vous offrir plus de flexibilité. Nous décrivons également les limites de version et de testeur afin que vous puissiez planifier à l'avance une expérience optimale.

Si vous utilisez également Android, consultez Bonnes pratiques pour distribuer des applications Android aux testeurs QA à l'aide de CI/CD.

Avant de commencer

Avant d'implémenter les bonnes pratiques décrites dans ce document, assurez-vous d'activer App Distribution dans la console Firebase pour chaque application. Si vous n'avez pas activé App Distribution, vous recevrez une erreur 404.

Pour activer App Distribution, procédez comme suit :

  1. Ouvrez la page App Distribution dans la console Firebase.

  2. Sélectionnez votre application iOS.

  3. Cliquez sur Commencer.

Automatiser votre workflow de test préliminaire à l'aide de CI/CD

Si vous souhaitez automatiser la création et la publication d'applications auprès de vos testeurs et que vous utilisez CI/CD, nous vous recommandons d'utiliser fastlane. Vous pouvez également utiliser la Firebase CLI, qui vous permet d'accéder à un large éventail de produits Firebase.

Utiliser fastlane

Intégrez App Distribution à votre pipeline CI/CD à l'aide de fastlane, un outil Open Source qui automatise la création et la publication d'applications iOS et Android. En créant et en distribuant automatiquement vos dernières versions aux testeurs, vous vous assurez qu'ils disposent toujours de la version de test la plus récente de votre application.

Pour découvrir comment intégrer App Distribution à fastlane, consultez Distribuer des applications iOS aux testeurs à l'aide de fastlane. Consultez également un atelier de programmation qui vous guide tout au long du processus d'intégration de fastlane.

Utiliser la Firebase CLI

Utilisez les outils de la CLI Firebase fournis par App Distribution pour distribuer des builds aux testeurs de manière programmatique. Vous pouvez spécifier des testeurs et des notes de version pour une build.

Distribuez votre dernière build iOS test.ipa en spécifiant l'ID d'application Firebase de l'application, en ajoutant éventuellement une note de version et un fichier contenant les adresses e-mail des testeurs :

firebase appdistribution:distribute test.ipa  \
    --app 1:1234567890:ios:0a1b2c3d4e5f67890  \
    --release-notes "Bug fixes and improvements" --testers-file testers.txt

Pour en savoir plus sur l'utilisation de la CLI Firebase pour automatiser vos builds, consultez Distribuer des applications iOS aux testeurs à l'aide de la CLI Firebase.

Utiliser des identifiants de service pour l'authentification

Utilisez le App Distribution plug-in fastlane ou la CLI Firebase avec des comptes de service, qui tirent parti des identifiants par défaut de l'application et vous aident à gérer votre CI. Un compte de service est un type de compte Google qui représente des applications plutôt que des utilisateurs. Votre système CI peut utiliser des comptes de service pour exécuter vos charges de travail App Distribution. Pour en savoir plus, consultez S'authentifier avec un compte de service.

Si vous utilisez la fédération d'identité de charge de travail, vous pouvez générer et utiliser un fichier de configuration des identifiants au lieu d'une clé de compte de service.

Tenir compte des limites de version

App Distribution accepte un maximum de 1 000 versions par application. Cela signifie que lorsque vous dépassez la limite de version, App Distribution supprime automatiquement les versions les plus anciennes au-delà de cette limite. Pour découvrir comment gérer les limites de version, consultez Combien de temps les versions d'application sont-elles disponibles ?

Ajouter le même ensemble de testeurs à plusieurs versions

Si vous souhaitez ajouter un grand nombre de testeurs à vos versions, utilisez App Distribution's fonctionnalité de gestion groupée des testeurs.

Nous vous recommandons d'utiliser des groupes pour ajouter les mêmes testeurs à plusieurs versions. Un groupe fait office de liste de contrôle d'accès. Lorsque vous supprimez un testeur d'un groupe, il perd l'accès à toutes les versions distribuées à ce groupe. Pour en savoir plus, consultez Ajouter et supprimer des testeurs d'un groupe.

Si vous avez de nombreux testeurs à gérer, vous pouvez les ajouter et les supprimer de manière groupée à l'aide de la console Firebase. Pour automatiser l'ajout et la suppression de testeurs, utilisez la Firebase CLI, fastlane, ou l'API App Distribution publique Firebase.

Tenir compte des limites de testeur

App Distribution limite le nombre de testeurs que vous pouvez ajouter à un projet Firebase ou à un groupe App Distribution. Lorsque vous dépassez ces limites, vous ne pouvez plus distribuer votre application à d'autres testeurs. Pour en savoir plus sur les limites de testeur, consultez Existe-t-il des limites pour l'ajout de testeurs à mon application ?

Gérer et ajouter automatiquement de nouveaux appareils de test iOS

Pour vous aider à enregistrer des appareils de test iOS supplémentaires, App Distribution vous aide à gérer vos appareils de test iOS dans l'Apple Developer Portal en vous informant des nouveaux appareils de test iOS par e-mail ou via des fichiers CSV. Pour en savoir plus, consultez Importer des testeurs à partir de fichiers CSV. Vous pouvez également exporter de nouveaux appareils de manière programmatique à l'aide de fastlane.

Pour découvrir comment configurer une action fastlane qui extrait automatiquement les UDID, les ajoute à la console pour développeurs Apple, puis recrée l'application et la distribue, consultez Distribuer plus rapidement vos versions iOS préliminaires avec App Distribution et fastlane.

Permettre aux testeurs potentiels de s'inscrire eux-mêmes pour les tests

Pour faciliter la distribution de votre application à davantage de testeurs, nous vous recommandons d'utiliser des liens d'invitation. Un lien d'invitation est une URL unique qui permet aux testeurs de saisir leur adresse e-mail pour s'inscrire et tester une application. Permettre aux utilisateurs de s'ajouter eux-mêmes à votre liste de testeurs d'applications est un moyen simple d'augmenter votre base de testeurs internes.

Les cas d'utilisation des liens d'invitation incluent les programmes de test interne, les organisations avec de grandes équipes QA et les groupes de développeurs qui souhaitent que des clients individuels puissent contrôler l'accès des testeurs.

Nous vous recommandons de créer un lien d'invitation pour un groupe. Tout testeur qui s'inscrit à l'aide du lien d'invitation est automatiquement ajouté aux versions suivantes.

Pour en savoir plus, consultez Créer des liens d'invitation et Ajouter et supprimer des testeurs d'un groupe.

S'assurer que les testeurs testent la version qui vous intéresse

Lorsqu'une nouvelle version est importée, vos testeurs sont avertis par e-mail. Pour compléter cette notification, vous pouvez utiliser les fonctionnalités suivantes (liens de version et alertes intégrées à l'application) afin de vous assurer que vos testeurs testent la version spécifique de l'application qui vous intéresse :

  • Liens de version : utilisez cette fonctionnalité lorsque vous souhaitez partager une version spécifique avec des testeurs. Pour découvrir comment utiliser les liens de version, consultez Distribuer des applications iOS aux testeurs à l'aide de la consoleFirebase. Ces liens sont également disponibles avec nos outils de ligne de commande (CLI) Firebase et fastlane pour une utilisation avec vos outils d'automatisation de build.

  • Alertes intégrées à l'application : utilisez ces alertes lorsque vous souhaitez vous assurer que vos testeurs testent la dernière version de votre application. En intégrant le SDK Firebase App Distribution pour iOS, vous pouvez afficher des alertes directement dans l' application pour vos testeurs lorsque de nouvelles builds de votre application sont disponibles. Pour découvrir comment ajouter des alertes intégrées à l'application, consultez Informer les testeurs des nouvelles builds.

Supprimer automatiquement l'accès des testeurs qui quittent l'entreprise

Une fois que votre flux de test interne CI/CD est opérationnel, vous devez vous assurer que les personnes qui quittent l'entreprise n'ont plus accès à vos builds internes. Pour vous aider à gérer l'accès des testeurs aux builds, App Distribution propose les options suivantes :