Aller directement au contenu principal

Configuration de CI/CD pour les applications Capacitor

Découvrez comment rationaliser vos déploiements d'applications pour iOS et Android en utilisant des pipelines CI/CD, améliorant l'efficacité et réduisant les erreurs.

Martin Donadieu

Martin Donadieu

Spécialiste du contenu

Configuration de CI/CD pour les applications Capacitor

Voulez-vous des déploiements d'applications plus rapides et sans erreurs pour iOS et Android ? Pipelines CI/CD pour Capacitor les applications automatisent la construction, les tests et la mise en production, réduisant les temps de mise en production de jusqu'à 70 % et les erreurs de 60 %. Cette guide couvre tout ce dont vous avez besoin de savoir, de la configuration de votre environnement à l'automatisation des mises à jour en direct avec Capgo.

Rappels clés :

  • Pourquoi la CI/CD est-elle importante pour les Capacitorapplications ?
  •  : Accélère les builds de 78 % et réduit les rejets de magasins de 60 %.: Outils essentiels, Xcode, Android StudioCocoaPods
  • Configuration de pipeline: Automatiser des tâches comme npx cap sync, mise en cache de dépendances et construction de builds spécifiques à la plateforme.
  • Mises à jour en temps réel avec Capgo: Activer les mises à jour post-sortie avec des déploiements étalés et des garanties de reversion.

Étapes de configuration rapide :

  1. Préparez votre environnement: Installez les outils requis pour iOS et Android.
  2. Configurez votre projet: Mettre à jour capacitor.config.ts et gérer les variables d'environnement de manière sécurisée.
  3. Construction de pipelines: Automate l'installation des dépendances, la construction et les tests pour les deux plateformes.
  4. Optimiser les performances: Utilisez le cache, les constructions parallèles et les workflows conditionnels.
  5. Ajoutez des mises à jour en temps réel: Intégrez Capgo pour des mises à jour OTA sécurisées avec des déploiements étalés.

Avec CI/CD, les applications Capacitor atteignent des lancements plus rapides, plus fluides tout en minimisant les erreurs et les interventions manuelles. Prêt à optimiser votre flux de travail ? Découvrons-le !

Intégrez vos pipelines CI/CD existants avec des capacités mobiles

Préparation de votre environnement CI/CD

Une fois que vous avez les bases de CI/CD, l'étape suivante est de configurer votre environnement. C'est la base de l'automatisation fiable.

Configuration des outils et logiciels

Assurez-vous d'avoir ces outils clés installés :

Pour le développement iOS :

  • Xcode 14 ou une version plus récente
  • Outils de ligne de commande Xcode
  • CocoaPods pour gérer les dépendances

Pour le développement Android :

  • Android Studio
  • Android SDK 33 ou une version supérieure
  • Kit de développement Java (JDK)

Pour confirmer que vos outils de ligne de commande Xcode sont installés, utilisez :

xcode-select -p

Création d'un Capacitor Projet

Capacitor Framework Documentation Website

Votre projet Capacitor doit être configuré correctement pour les flux de travail CI/CD. Le capacitor.config.ts Le fichier est au cœur de cette configuration :

const config: CapacitorConfig = {
  appId: 'com.example.app',
  webDir: 'build',
  ios: { 
    scheme: 'MyApp'
  }
}

Ce fichier assure que votre projet est conforme aux exigences CI/CD.

Configuration des Variables d'Environnement

Gérer les informations d'identification de manière sécurisée constitue une partie clé du lien entre votre configuration d'environnement et la file d'attente CI/CD.

Variables Clés à Définir :

  • BUILD_ENV: Spécifie la phase de déploiement (par exemple, production)
  • IOS_SIGNING_IDENTITY: Votre certificat de signature code
  • ANDROID_KEYSTORE_PATH: Chemin vers votre keystore Android

Pour les builds Android, générer dynamiquement un local.properties __CAPGO_KEEP_0__ fichier pendant le processus CI :

echo "sdk.dir=$ANDROID_SDK_ROOT" > android/local.properties

Lorsque vous travaillez avec des builds iOS, assurez-vous que votre plateforme CI prend en charge les agents macOS.

Pour vérifier si votre environnement est prêt :

node --version | grep "v16" && xcodebuild -version | grep "Xcode 14" || exit 1

Gérer correctement les clés et les informations d'identification peut considérablement réduire les chances de rejets de l'App Store, comme le montre les statistiques précédentes. [1].

Créer votre pipeline CI/CD

Une fois votre environnement prêt, l'étape suivante consiste à configurer un pipeline CI/CD pour votre Capacitor applicationCe pipeline doit gérer efficacement les actifs web et les builds de plateformes natives.

Installer et mettre à jour les dépendances

Dans les environnements CI/CD, gérer les dépendances nécessite un contrôle de version strict. Commencez par un processus d'installation propre :

npm install --ignore-scripts
npm install @capacitor/cli

Pour accélérer les builds, utilisez la mise en cache des dépendances. Par exemple, Azure DevOps Les utilisateurs ont vu leurs temps de construction améliorés de 40 à 60% avec ce setup :

- task: Cache@2
  inputs:
    key: 'npm | "$(Agent.OS)" | package-lock.json'
    path: |
      node_modules
      android/.gradle
      ios/Pods

Configuration de la mise en ligne pour iOS et Android

Voici comment configurer les constructions pour les deux plateformes :

Configuration de la construction pour iOS :

steps:
  - task: InstallAppleCertificate@2
    inputs:
      certSecureFile: 'certificate.p12'
      certPwd: $(P12_PASSWORD)
  - script: |
      xcodebuild -workspace ios/App/App.xcworkspace -scheme App -configuration Release -archivePath ios/App/App.xcarchive archive

Configuration de la construction pour Android :

cd android
./gradlew bundleRelease

Étapes de test et de déploiement

Exécutez les tests de plateforme en parallèle en utilisant une stratégie de matrice :

test:
  steps:
    - run: npm run test:unit
    - run: npm run test:e2e
    - name: Run Platform Tests
      matrix:
        platform: [ios, android]
      run: npm run test:${{ matrix.platform }}

Pour le déploiement, configurez la gestion d'artefacts spécifique à la plateforme :

PlateformeType d'artefactCanal de distribution
iOS.ipaApp Store Connect
Android.aabGoogle Play Console

L'utilisation de builds parallèles peut considérablement réduire le temps d'exécution de la chaîne de pipeline lorsqu'elle est configurée correctement.

Une fois vos builds validés et emballés, vous êtes prêt à passer à des mises à jour en direct avec Capgo (discuté dans la section suivante).

sbb-itb-f9944d2

Ajouter Capgo pour les Mises à jour en Direct

Capgo Interface de la Console de Mise à jour en Direct

L'intégration de Capgo à votre flux de travail améliore votre processus CI/CD en permettant des mises à jour post-dépot. Voici comment l'installer :

Capgo Configuration de pipeline

Tout d'abord, installez le Capgo CLI dans votre environnement de pipeline :

steps:
  - name: Install Capgo CLI
    run: npm install -g @capgo/cli
  - name: Configure Authentication
    env:
      CAPGO_KEY: ${{ secrets.CAPGO_API_KEY }}

Cette addition étend votre cycle de vie CI/CD en intégrant la gestion des mises à jour à votre processus de construction et de déploiement automatisé. Ensuite, incluez la commande d'upload après vos étapes de construction :

Pour des

- name: Upload Update
  run: |
    capgo upload --api-key $CAPGO_KEY --bundle ./build/app-release.apk
    capgo deploy v${VERSION} --channel production

mises à jour sécurisées , configurez les paramètres de validation comme suit :Pour __CAPGO_KEEP_2__

{
  "verification": {
    "checksum": "strict",
    "certificatePinning": true,
    "updateTimeout": 500
  }
}

Capgo Fonctionnalités Vue d'ensemble

FonctionnalitéDescription
Chiffrement de bout en boutRéduit considérablement les erreurs de déploiement.
Déploiement par canalAdapte les mises à jour aux environnements spécifiques.
Déploiement en phasesS'assure que les mises à jour sont distribuées progressivement.

Lignes directrices de mise à jour OTA

Améliorez vos processus de test en suivant ces principaux indicateurs après déploiement :

Stratégie de déploiement en phases

Utilisez un déploiement étalé pour contrôler la façon dont les mises à jour sont distribuées :

- name: Staged Rollout
  run: |
    capgo deploy v1.2.3 --group "beta-users" --rollout 10%
    capgo deploy v1.2.3 --rollout 50%

Suivi des mises à jour

Tenez une œil sur ces indicateurs :

  • Taux d'adoption: Visez 40-60% dans les 24 premières heures.
  • Sessions sans crash: Maintenez au-dessus de 99,5%.
  • Temps de vérification: Assurez-vous qu'il est inférieur à 500ms.

Si les crashes dépassent les niveaux acceptables, automatiser un retour en arrière :

- name: Rollback Check
  run: |
    if [ $(capgo stats --version v1.2.3 --metric crashes) -gt 2 ]; then
      capgo rollback --channel production
    fi

Amélioration de la performance de la chaîne d'approvisionnement

Se concentrer sur trois domaines clés peut conduire à des améliorations notables dans votre chaîne d'approvisionnement :

Optimisation de la vitesse de construction

Pour les modifications web uniquement, en utilisant npx cap sync peut économiser du temps en sautant les reconstructions natives complètes, en réduisant le temps de reconstruction d'environ 40 %. Voici comment vous pouvez mettre en œuvre la construction conditionnelle :

- name: Build Strategy
  run: |
    [ "$WEB_ONLY" = true ] && npx cap sync || (./gradlew assembleRelease && xcodebuild ...)

Cette approche garantit que seuls les composants nécessaires sont reconstruits, simplifiant le processus.

Automatisation du Contrôle de Version

L'automatisation du contrôle de version peut simplifier votre flux de travail. Utilisez le script suivant pour définir dynamiquement les numéros de version et de construction :

- name: Set Version
  run: |
    VERSION=$(node -p "require('./package.json').version")
    BUILD_NUMBER=$GITHUB_RUN_NUMBER
    echo "APP_VERSION=${VERSION}" >> $GITHUB_ENV
    echo "BUILD_ID=${BUILD_NUMBER}" >> $GITHUB_ENV

De plus, la versionnement semantique automatisé peut être configuré avec cette configuration :

{
  "scripts": {
    "version": "standard-version",
    "build:prod": "npm version patch && ionic build --prod"
  }
}

Ces pratiques fournissent un cadre solide pour suivre et améliorer les performances de la chaîne d'outils à l'aide de métriques comme :

  • Temps de construction par étape
  • Efficacité de la cache (taux de hits/miss)
  • Utilisation maximale des ressources

Configuration de plusieurs environnements

La gestion de plusieurs environnements peut être simplifiée en utilisant des configurations spécifiques à l'environnement.

EnvironnementFichier de configuration
Développement.env.dev
Étape de test.env.staging
ProductionChiffriers sécurisés

Vous pouvez configurer les environnements dynamiquement avec ce script :

- name: Configure Environment
  env:
    API_KEY: ${{ secrets.ENV_SPECIFIC_API_KEY }}
    BUNDLE_ID: ${{ parameters.bundleId }}
  run: |
    echo "ENVIRONMENT=${{ parameters.environment }}" >> $GITHUB_ENV
    echo "API_ENDPOINT=${{ parameters.apiUrl }}" >> $GITHUB_ENV

L'association de ces configurations avec la mise en production basée sur les canaux de Capgo permet des mises à jour précises et spécifiques à l'environnement. Cela garantit des déploiements plus fluides et un meilleur contrôle du comportement de l'application dans différents environnements.

Résumé

Le rôle du CI/CD dans le développement

L'utilisation de pipelines CI/CD pour les applications Capacitor augmente significativement l'efficacité du flux de travail. Selon les données de l'industrie, les équipes peuvent atteindre 50-70% de cycles de mise à jour accélérés grâce à la construction simultanée d'iOS et d'Android [3]Automatiser des tâches comme l'installation de dépendances et la synchronisation de plateformes réduit les erreurs de déploiement par 40-60% [1][2].

Par exemple, les équipes utilisant les pipelines Azure DevOps ont automatisé des processus comme les étapes de construction séquentielles et le packaging Xcode. Elles utilisent également des environnements paramétrés pour le développement et la production. Cette approche supprime la nécessité d'opérations manuelles de Gradle et Xcode CLI, garantissant la création de artefacts fiables chaque fois.

Ces améliorations créent les bases pour une gestion de mise à jour fluide lorsqu'elle est associée à Capgo.

Capgo pour la gestion de mise à jour

Capgo fonctionne en harmonie avec les pipelines CI/CD pour déployer des mises à jour instantanées tout en restant conforme aux politiques des magasins d'applications. Les mises à jour ne sont déployées qu'après avoir passé les portes de test automatisées intégrées au pipeline.

En combinant la construction automatisée avec les lancements de phase, les équipes atteignent des résultats impressionnants : 80% de couverture utilisateur en 7 jours et des capacités de retrait en moins d'une heure.

Une stratégie courante consiste à exécuter des trajectoires de déploiement parallèles. Les constructions automatisées sont utilisées pour les tests internes, tandis que les lancements de phase ciblent les segments d'utilisateurs. Cela garantit que les mises à jour sont à la fois rapides et sûres, étayées par des portes de test automatisées rigoureuses [1].

FAQs

Comment créer une application Capacitor?

La création d'une application Capacitor implique quelques étapes simples :

  1. Configurer votre environnement: Installez Node.js et npm sur votre système. Ensuite, utilisez l'CLI Ionic pour démarrer un nouveau projet avec le support Capacitor :

    ionic start myApp tabs --capacitor
  2. Ajouter le support de plateforme: Ajoutez les plateformes que vous souhaitez cibler, telles que iOS ou Android :

    npx cap add ios
    npx cap add android
  3. Synchroniser votre web code: Assurez-vous que votre web code est aligné avec les plateformes natives en exécutant :

    npx cap sync

L'étape de synchronisation est cruciale pour maintenir votre application cohérente sur les plateformes et garantir une opération fluide dans les pipelines CI/CD. Pour plus de détails sur la configuration de votre environnement, consultez la section Outils.

Mises à jour en direct pour les applications Capacitor

Lorsqu'un bug de la couche web est en ligne, expédiez la correction par Capgo au lieu d'attendre des jours pour l'approbation de la boutique d'applications. Les utilisateurs reçoivent la mise à jour en arrière-plan tandis que les modifications natives restent dans la voie de revue normale.

Démarrer maintenant

Dernières actualités de notre blog

Capgo vous donne les meilleures informations dont vous avez besoin pour créer une application mobile véritablement professionnelle.