Principes de base de l'intégration continue

L'intégration continue (CI) est une pratique de développement logiciel dans laquelle les développeurs fusionnent fréquemment les modifications de code dans un dépôt central, après quoi des builds et des tests automatisés sont exécutés.

Vous pouvez configurer un système CI de base pour éviter que de nouvelles modifications ne perturbent le build après la fusion. Vous pouvez programmer un système CI plus avancé pour tester automatiquement l'application et vous assurer qu'elle se comporte comme prévu dans différents environnements, tels que les niveaux d'API, les tailles d'écran et les plates-formes.

Schéma montrant comment plusieurs développeurs demandent des modifications de code et comment elles sont vérifiées par le système CI avant de les fusionner dans le dépôt de code principal.
Figure 1. Un système CI maintient un dépôt de code opérationnel en effectuant des vérifications avant la fusion.

Ce document présente les stratégies courantes que les développeurs utilisent pour configurer des systèmes CI efficaces pour les projets Android. Ces consignes sont génériques et s'appliquent à la majorité des solutions.

Exemple type

Un système CI classique suit un workflow ou un pipeline, qui peut se présenter comme suit:

  1. Le système CI détecte une modification dans le code, généralement lorsqu'un développeur crée une demande d'extraction, également appelée "liste de modifications" ou "demande de fusion".
  2. Elle provisionne et initialise un serveur pour exécuter le workflow.
  3. Elle récupère le code ainsi que des outils tels que le SDK Android ou les images de l'émulateur, si nécessaire.
  4. Il compile le projet en exécutant une commande donnée, par exemple ./gradlew build.
  5. Elle exécute les tests locaux en exécutant une commande donnée, par exemple avec ./gradlew test.
  6. Il démarre des émulateurs et exécute les tests d'instrumentation.
  7. Il importe des artefacts tels que des résultats de test et des APK.
Schéma illustrant un workflow CI de base
Figure 2. Workflow CI de base

Avantages de l'intégration continue

L'intégration continue présente les avantages suivants:

  • Meilleure qualité des logiciels: la CI peut contribuer à améliorer la qualité des logiciels en identifiant et en corrigeant les problèmes le plus tôt possible. Cela peut aider à réduire le nombre de bugs dans les versions logicielles et à améliorer l'expérience utilisateur globale.
  • Réduction du risque de défaillances des compilations: lorsque vous automatisez votre processus de compilation avec CI, vous pouvez mieux éviter les défaillances de compilation en résolvant les problèmes plus tôt dans le processus.
  • Renforcement de la confiance dans les versions: la CI peut vous aider à garantir que chaque version est stable et prête pour la production. En exécutant des tests automatisés, CI peut identifier les problèmes potentiels avant de les rendre publics.
  • Amélioration de la communication et de la collaboration: en fournissant aux développeurs un emplacement centralisé pour partager le code et les résultats des tests, la CI peut aider les développeurs et les autres membres de l'équipe à collaborer et à suivre les progrès.
  • Productivité accrue: la CI peut contribuer à accroître la productivité des développeurs en automatisant les tâches qui, autrement, seraient chronophages et sources d'erreurs.

Complément d'informations

Pour savoir comment utiliser l'intégration constante afin d'améliorer le développement de votre application, consultez les pages suivantes: