Passer au contenu principal

Automatiser CI/CD avec des commits conventionnels

Découvrez comment les commits conventionnels peuvent automatiser vos processus CI/CD, simplifier la gestion des versions et améliorer l'efficacité de déploiement.

Martin Donadieu

Martin Donadieu

Spécialiste du contenu

Automatiser la CI/CD avec les commits conventionnels

Vous souhaitez simplifier votre pipeline CI/CD? Les commits conventionnels peuvent vous aider en automatisant la versionnage, la création du changelog et le déploiement. Voici comment :

  • Utilisez un format de commit standard comme feat: add new feature ou fix: resolve issue.
  • Automatisez les mises à jour de version sur la base des types de commit (par exemple, fix = correction mineure, feat = version mineure).
  • Générez automatiquement les changelogs pour une transparence accrue.
  • Appliquez des normes de commit avec des outils comme Commitlint et Husky.
  • Intégrez semantic-release pour une versionnement et des publications sans heurt.
  • Simplifiez les mises à jour des applications mobiles avec des outils comme __CAPGO_KEEP_0__ Capgo.

Avantages Clés :

  • Historique de commit lisible par machine.
  • Réduction des erreurs manuelles dans la versionnage et la mise en production.
  • Procédure CI/CD plus rapide et plus fiable.

Exemple Rapide :

  1. Installez Commitlint et Husky pour appliquer les règles de commit.
  2. Utilisez semantic-release pour automatiser la versionnage et les mises à jour du changelog.
  3. Configurez GitHub Actions pour l'automatisation CI/CD de bout en bout.

Cette configuration garantit que votre équipe passe moins de temps à gérer les commits et plus de temps à créer de grandes logiciels.

Versionnage Automatique de Build avec Github Actions et Conventions de Commits conventionnels par Roman Ivaniuk

Github Actions

Guide de configuration de la chaîne de production CI/CD

Facilitez votre chaîne de production CI/CD en l'automatisant avec Conventions de Commits. Suivez ces étapes pour configurer tout.

Configuration Commitlint

Outil de convention de commit de Commitlint

Commitlint aide à faire respecter la spécification des Conventions de Commits, en garantissant des messages de commit cohérents et significatifs.

  • Installation des dépendances requises

Démarrez par l'installation de Commitlint, de sa configuration conventionnelle et de Husky :

npm install @commitlint/cli @commitlint/config-conventional --save-dev
npm install husky --save-dev
  • Configurer Commitlint

Créer un fichier dans le répertoire racine de votre projet pour définir les règles : commitlint.config.js Activer les hooks Git

module.exports = {
    extends: ['@commitlint/config-conventional'],
    rules: {
        'header-max-length': [2, 'always', 50],
        'type-enum': [2, 'always', [
            'feat', 'fix', 'docs', 'style', 'refactor',
            'perf', 'test', 'build', 'ci', 'chore'
        ]]
    }
}
  • Utiliser Husky pour configurer les hooks Git qui imposent des normes pour les messages de commit :

Implémenter

npx husky install
npm set-script prepare "husky install"
npx husky add .husky/commit-msg "npx --no -- commitlint --edit $1"

semantic-release semantic-release

Automatiser la gestion de version, la création de changelog et les releases avec semantic-release.

Installer les dépendances

  • Installer semantic-release ainsi que les plugins pour Git et la génération de changelog :

Configurer les règles de release

npm install semantic-release @semantic-release/git @semantic-release/changelog --save-dev
  • __CAPGO_KEEP_0__

Ajoutez un .releaserc fichier pour définir comment semantic-release gère la versionnement et les actifs :

{
    "branches": ["main"],
    "plugins": [
        "@semantic-release/commit-analyzer",
        "@semantic-release/release-notes-generator",
        ["@semantic-release/changelog", {
            "changelogFile": "CHANGELOG.md"
        }],
        "@semantic-release/npm",
        ["@semantic-release/git", {
            "assets": ["package.json", "CHANGELOG.md"],
            "message": "chore(release): ${nextRelease.version} [skip ci]"
        }]
    ]
}

GitHub Actions Implementation

Configurez un workflow GitHub Actions pour valider les commits et automatiser les processus CI/CD.

name: CI/CD Pipeline
on:
  push:
    branches: [ main ]
  pull_request:
    branches: [ main ]

jobs:
  verify:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v6
        with:
          fetch-depth: 0
          filter: blob:none

      - name: Verify Commits
        uses: wagoid/commitlint-github-action@v5

  release:
    needs: verify
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v6
      - name: Setup Node.js
        uses: actions/setup-node@v3
        with:
          node-version: '24'

      - name: Release
        env:
          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
          NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
        run: npx semantic-release

Caractéristiques clés de cette configuration

Cette configuration garantit :

  • Les messages de commit sont automatiquement validés.
  • Les versions sémantiques sont générées en fonction des types de commit.
  • Les fichiers de changelog sont créés et mis à jour automatiquement.
  • Les releases sont déclenchées et gérées sans intervention manuelle.
Type de commitVersion de BumpExemple d'utilisation
fixPatch (0.0.x)Correctifs de bogues ou de patches
featMineur (0.x.0)Nouvelles fonctionnalités ajoutées
feat! ou fix!Majeur (x.0.0)Changements de rupture introduits

Avec cette base en place, vous êtes prêt à explorer des techniques d'automatisation plus avancées dans les sections suivantes.

Methods d'automatisation avancés de CI/CD

Détecter les changements de rupture

Détecter les changements de rupture est essentiel pour maintenir une version semantique correcte. Les outils d'automatisation peuvent aider à détecter ces changements et déclencher les mises à jour de version nécessaires.

Par exemple, les changements de rupture peuvent être signalés en ajoutant un '!' à l'en-tête du commit ou en incluant un pied-de-page 'BREAKING CHANGE'. Voici une mise en œuvre d'exemple:

// Example implementation for breaking change detection
module.exports = {
  analyzeCommits: (commits) => {
    const hasBreakingChange = commits.some(commit => {
      return commit.notes.some(note => note.title === 'BREAKING CHANGE') ||
             commit.header.includes('!');
    });
    return hasBreakingChange ? 'major' : null;
  }
};

Cela garantit que les changements de rupture sont signalés et gérés de manière appropriée, simplifiant le processus de versionnement et réduisant les erreurs dans les dépôts complexes.

Gestion des commits dans un monorepo

Gérer les commits dans les monorepos peut être compliqué, surtout lorsqu'on traite de plusieurs composants. Pour optimiser les processus de build, vous pouvez mettre en œuvre des builds sélectifs qui se concentrent uniquement sur les composants affectés. Voici un exemple de configuration:

# Example configuration for selective builds
trigger:
  paths:
    - 'packages/core/**'
    - 'packages/api/**'
    - 'shared/**'

Les builds sélectifs assurent l'efficacité en ciblant des composants spécifiques. Voici comment différents types de composants peuvent être gérés:

Type de composantStratégie de buildContrôle de version
Bibliothèques partagéesBuild when les dépendances changentVersionnement centralisé
Services indépendantsConstructions isoléesVersions spécifiques aux packages
Composants de baseConstructions prioritairesContrôle de version strict

Cette approche complète les méthodes de versionnement automatisées, telles que celles basées sur les Commit Conventions, en s'assurant que seules les constructions nécessaires sont déclenchées.

Vérifications de sécurité et de conformité

Automatiser les vérifications de sécurité et de conformité est crucial pour maintenir la qualité de code et répondre aux normes réglementaires. Par exemple, les outils comme Cocogitto Mise à jour de leurs GitHub Actions en mars 2025 pour appliquer la spécification des commits conventionnels, soulignant l'importance croissante des vérifications de conformité automatisées [2].

Vous pouvez configurer votre pipeline CI/CD pour inclure ces vérifications :

security-compliance:
  script:
    - commitlint --from $CI_COMMIT_BEFORE_SHA --to $CI_COMMIT_SHA
    - security-scan --severity high
    - compliance-check --standard pci-dss

Voici un aperçu des outils et de leurs buts :

Type de vérificationOutilObjectif
Format de commitCommitlintAssure la conformité des commits conventionnels
Scanning de sécuritéSAST/DASTIdentifie les vulnérabilités
ConformitéRègles personnaliséesVérifie les exigences réglementaires

CI/CD d'application mobile avec Capgo

Capgo Tableau de bord d'actualisation en direct

Capgo étend les workflows automatisés dans l'écosystème mobile, ce qui en fait une intégration sans heurts aux pratiques CI/CD établies.

Capgo Caractéristiques

Capgo simplifie le CI/CD mobile en permettant des mises à jour instantanées et conformes en ligne (OTA). Certaines caractéristiques notables incluent chiffrement de bout en bout et canaux d'actualisation ciblés for precise delivery.

Voici un aperçu des derniers indicateurs de performance de Capgo:

  • 82% taux de réussite de mise à jour mondiale
  • 434ms temps moyen de réponse de API
  • Support pour 1,7K d'applications
  • Plus de 1,6 trillion de mises à jour délivrées [3]

Avec ces capacités, l'intégration de Capgo dans votre pipeline CI/CD peut simplifier votre processus de développement d'applications mobiles.

Capgo Pipeline Setup

Pour commencer avec Capgo, suivez ces étapes pour l'intégrer dans votre workflow CI/CD :

ÉtapeCommandeObjectif
Génération de Buildnpx @capgo/cli buildProduit un bundle prêt pour la production
Mise à jour de la versionnpx semantic-releaseMise à jour de la version de l'application en fonction des commits
Déploiementnpx @capgo/cli bundle uploadEnvoie les mises à jour vers un canal spécifique

Voici un exemple de configuration YAML pour un workflow CI/CD avec Capgo:

jobs:
  deploy:
    steps:
      - name: Build Web
        run: npm run build
      - name: Generate Version
        run: npx semantic-release
      - name: Upload to Capgo
        run: npx @capgo/cli bundle upload --channel production
        env:
          CAPGO_API_KEY: ${{ secrets.CAPGO_API_KEY }}

Capgo: Comparaison des fonctionnalités

Capgo propose plus que l'automatisation - il offre une performance robuste et des économies de coûts. Avec un coût mensuel d'environ $300 pour les opérations CI/CD [3], il s'agit d'une alternative abordable par rapport à de nombreux concurrents.

Une étude de cas menée en mars 2025 a mis en évidence son impact :

  • $26 100 économisés sur 5 ans
  • 95 % d'adoption des mises à jour dans les 24 heures

“Nous pratiquons le développement agile et @Capgo est essentiel à la livraison continue à nos utilisateurs !” - Rodrigo Mantica [3]

Capgo se distingue également par ces fonctionnalités clés :

  • architecture 100 % open-source
  • Gestion des équipes flexible avec permissions granulaires
  • Rougeau d'un clic pour une résolution rapide des problèmes
  • Détails analytiques et suivi des erreurs
  • Intégration fluide avec les principaux plateformes CI/CD comme GitHub Actions et GitLab CI

Ces fonctionnalités rendent Capgo une excellente option pour automatiser les workflows CI/CD des applications mobiles de début à fin.

Conclusion

Cette guide met en évidence comment la versionnage automatique, la gestion simplifiée des commits et les mises à jour mobiles intégrées se combinent pour soutenir une approche bien équilibrée de CI/CD. En adoptant les Conventional Commits, les équipes peuvent apporter de la structure au contrôle de version et simplifier les processus de déploiement.

Avantages Principaux

Les commits conventionnels offrent une gamme de bénéfices aux équipes de développement modernes. Leur format standardisé pour les messages de commit aide à minimiser les problèmes de versionnement et réduit les chances de failures de déploiement [4].

AvantageImpact
Automatisation de la VersionAdapte automatiquement la versionnement semantique en fonction des types de commit
Lisibilité AmélioréeFournit une histoire Git claire et compréhensible pour une meilleure collaboration
Efficacité CI/CDRéduit les erreurs de pipeline en ajoutant de la clarté au contexte des commit
Transmission des ConnaissancesAccélère l'inscription et améliore la communication au sein de l'équipe

Ces avantages renforcent la base d'un pipeline CI/CD fiable.

“La spécification des messages de commit conventionnels est une convention légère sur les messages de commit. Elle fournit un ensemble facile à suivre de règles pour créer une histoire de commit explicite ; ce qui facilite la rédaction d'outils automatisés sur le dessus.” - conventionalcommits.org [1]

Guide d'implémentation

Pour tirer le maximum de profit des messages de commit conventionnels, implémentez-les avec soin. Utilisez des outils comme Commitlint et Husky pour imposer des normes sur les messages de commit, intégrez semantic-release pour une version automatique, et Capgo pour les mises à jour sur les appareils mobiles en ligne (OTA).

Capgo complète le flux de travail des messages de commit conventionnels en offrant :

  • Gestion automatique de la version à travers l'intégration de semantic-release
  • Déploiement simplifié en utilisant des déclencheurs basés sur les commits
  • Sécurité améliorée via la livraison d'actualisations chiffrées
  • Options de reversion fiables liées directement à l'historique des commits

FAQs

::: faq

Comment l'utilisation de Conventional Commits peut-elle optimiser votre processus CI/CD ?

Conventional Commits apportent de l'ordre aux workflows CI/CD en fournissant une méthode standardisée claire pour structurer les messages de commit. Cette mise en forme aide les outils automatisés à interpréter facilement les changements, ce qui rend les tâches telles que le test, la construction et le déploiement plus précises. Avec moins de place pour la confusion, les erreurs sont réduites, ce qui entraîne un pipeline de développement plus fluide.

Un autre avantage des messages de commit structurés est la capacité de générer automatiquement des changelogs et d'appliquer une versionnement sémantique. Cela ne seulement économise du temps mais simplifie également la gestion des versions. Cela améliore également la collaboration en rendant l'historique des commits plus facile à suivre et à comprendre.

Pour les développeurs créant des Capacitoroutils comme Capgo portent les processus CI/CD à un niveau supérieur. Ils offrent une intégration sans heurts, des mises à jour en temps réel et s'assurent de la conformité aux exigences d'Apple et d'Android. Cela accélère la livraison des mises à jour sans nécessiter l'approbation des magasins d'applications, ce qui rend l'ensemble du processus plus efficace.

:::

::: faq

Quels outils sont essentiels pour automatiser CI/CD avec les Conventions de Commit ? Pour configurer le CI/CD automatique en utilisant l' approche des Conventions de Commit, vous aurez besoin de quelques outils essentiels pour rendre le processus plus fluide et plus efficace :

  • Commitlint: Ce outil vérifie que vos messages de commit respectent la norme des Conventions de Commit, en vous assurant qu'ils restent cohérents et faciles à interpréter.
  • Husky: Husky vous permet de configurer les hooks Git, comme pré-commit ou pré-push, pour appliquer automatiquement des règles pour les messages de commit pendant le développement.
  • Semantic Release: En analysant les messages de commit, cet outil automatise la versionnage et la publication de packages, ce qui rend les mises à jour prévisibles et sans souci.

Ensemble, ces outils vous aident à maintenir un pipeline CI/CD bien organisé avec une histoire de commit standardisée. Pour les équipes travaillant avec des applications Capacitor, les plateformes comme Capgo peuvent être une excellente addition, offrant des mises à jour en direct fluides qui s'intègrent parfaitement dans votre flux de travail CI/CD.

::: faq

Comment Capgo simplifie-t-il le CI/CD pour les applications mobiles ?

Capgo simplifie le processus CI/CD pour les applications mobiles en proposant des mises à jour instantanées qui évitent la nécessité d'approbations de magasins d'applications. Cela signifie que les développeurs peuvent déployer des correctifs, de nouvelles fonctionnalités et des mises à jour beaucoup plus rapidement, ce qui garantit que les applications restent à jour avec un minimum d'effort.

It s'intègre parfaitement dans les pipelines CI/CD existants, automatisant les mises à jour en maintenant une livraison sécurisée à travers une encryption de bout en bout. Capgo prend également en charge les mises à jour partielles, ce qui réduit l'utilisation de bande passante en téléchargeant que les modifications nécessaires. De plus, sa fonctionnalité de reversion rapide permet aux développeurs de résoudre rapidement les problèmes en revenant à une version précédente. Avec son focus sur la vitesse, la sécurité et l'adaptabilité, Capgo constitue un atout précieux pour améliorer les flux de développement et améliorer l'expérience utilisateur.

Continuer à partir de l'article Automatiser CI/CD avec des commits conventionnels

Si vous utilisez Automatiser CI/CD avec des commits conventionnels pour planifier le retrait et le contrôle de version, connectez-le à Rollbacks pour les détails d'implémentation dans Rollbacks, Version Targeting pour les détails d'implémentation dans Version Targeting, Comportement de mise à jour pour les détails d'implémentation dans Comportement de mise à jour, bundle pour les détails d'implémentation dans bundle, et Capgo Mises à jour en temps réel pour le flux de travail du produit dans Capgo Mises à jour en temps réel.

Mises à jour en temps réel pour les applications Capacitor

Lorsqu'un bug de la couche web est en ligne, expédiez la correction à travers 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 le chemin de revue normal.

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 vraiment professionnelle.