Normez vos branches avec validate-branch-name

Par Maxime Bréhin • Publié le 6 septembre 2021 • 4 min

Fonctionnement de validate-branch-name

validate-branch-name analyse la branche que vous tentez de pousser (git push) et stoppe l’opération si les contraintes ne sont pas respectées.

On peut renseigner ces contraintes dans un fichier de configuration. Sinon les motifs autorisés par défaut seront utilisés et vérifieront que :

  • les branches correspondent exactement à master ou develop ;
  • sinon que les branches sont préfixées par feature, fix, hotfix ou release, suivi d’un slash (/).

Mise en place

Tout comme husky, il s’agit d’un module npm pour la phase de développement :

# Installation
npm install --save-dev validate-branch-name
# Configuration en pre-push via husky
npx husky add .husky/pre-push "npx --no-install validate-branch-name"

Puis on définit selon nos règles la configuration dans le fichier .validate-branch-namerc.js :

module.exports = {
  pattern: '^(main|staging|production)$|^(bump|feat|fix|rel(?:ease)?)/.+$',
  errorMsg:
    '🤨 La branche que tu essaies de pusher ne respecte pas nos conventions, tu peux la renommer avec `git branch -m <nom-actuel> <nouveau-nom>`',
}

Plus tard, quand on tentera de partager une branche mal nommée, on se fera rattraper par le col et notre push sera rejeté, nous encourageant à bien nommer notre branche :

Recommandations de convention

À défaut d’un guide en ligne pour une convention bien établie, je vous fais un résumé de ce qui pourrait s’en rapprocher, basé sur mon propre vécu et les retours d’expérience dont on m’a fait part.

Je vous encourage, pour bien définir vos catégories de branches (et donc leur nommage), à vous interroger sur les grands rôles ou thèmes qui seront utiles à votre projet.

Note : vous remarquerez peut-être qu’une partie des recommandations qui suivent sont similaires à des workflows documentés tels que le GitLab flow ou le Git flow. C’est logique si on considère que les noms de nos branches doivent faire écho à notre gestion de projet.

Quels environnements ?

À l’initialisation d’un projet, Git crée par défaut une branche main (anciennement master). Cette branche peut prendre le rôle que nous désirons et peut même être renommée. Elle est le plus souvent utilisée comme tronc commun des développements ou comme branche de production.

Outre cette branche déjà existante à la création du projet, on retrouvera souvent des branches pour les “environnements” suivants :

  • production : celle qui sert à l’extraction / la génération de nos livrables ;
  • preproduction / staging : permet des vérifier le livrable avant fusion dans la production (assurance qualité) ;
  • develop / main : branche de développement stable (jouera parfois le rôle de preproduction pour limiter la profondeur des branches).

Certains projets ont plusieurs versions de production à un instant T. Leur maintenance nécessitera des branches dédiées : release-X.X.X (pour éviter la confusion avec d’éventuels tags nommés vX.X.X).

Quelles étapes traverse mon projet ?

La plupart des projets de développement passent par des étapes de création, d’amélioration et de correction. On isole ainsi deux grands rôles pour lesquels nous pourrions utiliser des préfixes dans notre convention :

  • feat/ pour la création et l’amélioration des fonctionnalités (en raccourci de feature) ;
  • fix/ ou hotfix/ pour la gestion des corrections (problèmes liés à la production).

Le suffixe prendrait ensuite une valeur contextuelle, intégrant éventuellement la référence équivalente au thème dans vos outils de gestion de projet (exemple d’une référence d’un ticket ou d’un projet dans GitHub ou GitLab) : fix/24-restore-form-validation.

_Note : je recommande généralement l’usage du slash (/) pour la découpe de contextes / préfixe (un seul niveau suffit généralement, mais on peut imaginer feat/gdpr/notice, par exemple), et réserver les tirets voire soulignés (- ou _) pour les segments du nom, afin de ne pas se limiter à un seul mot (comme dans l’exemple de correctif du paragraphe précédent)._

Cas particuliers de la mise à jour des dépendances

Peut-être utilisez-vous un service comme dependabot qui analyse les dépendances de votre projet et vous propose automatiquement une mise à jour via une branche (et une pull request). Il ne s’agit dans ce cas pas d’une fonctionnalité ni d’un réel correctif. La branche ainsi proposée est alors préfixée bump/. Vous pouvez donc choisir d’employer / d’autoriser ce préfixe dans votre convention.

Envie d’automatiser encore plus ?

On prend vite goût à automatiser au maximum les tâches répétitives ou sources d’erreurs. On gagne en qualité dans nos projets et surtout on gagne du temps pour nous concentrer sur des savoir-faire plus utiles et valables.

Si vous voulez creuser un peu plus le sujet, je vous invite à parcourir nos autres articles sur le même thème :

Tu veux aller plus loin et maîtriser pleinement les fondamentaux de Git ou être accompagné pour garantir la qualité de tes projets grâce à une bonne mise en place de Git ? On peut t’aider ou te former, il suffit de nous décrire ton besoin !
Tu peux aussi regarder le programme de notre formation "Comprendre Git" ou nous poser tes questions sur notre forum discord.