Journal du mardi 13 mai 2025 à 09:38
Voici-ci dessous, une partie de la liste de labels d'Issues que l'équipe tech de Spacefill utlisait sous GitLab. Cette liste de labels est le fruit d'un travail itératif d'environ 15 personnes, sur une période de 4 ans.
Voici comment cette liste a été élaborée :
J'ai conservé cette liste afin de pouvoir l'utiliser comme source d'inspiration ou de fondation pour mes prochains projets en équipe.
Pour ceux qui souhaitent s'en inspirer, je recommande de ne pas adopter cette liste intégralement d'emblée. Privilégiez plutôt une sélection ciblée des labels qui correspondent à vos processus actuels, puis incorporez progressivement de nouveaux labels selon l'évolution de vos besoins.
Mon expérience m'a démontré que la mise en place de processus dans une organisation humaine fonctionne mieux par petites étapes successives. Cette approche incrémentale s'avère bien plus efficace que de tenter d'imposer en bloc un processus complet qui risquerait d'être inadapté à votre contexte spécifique.
Voici cette liste.
Une issue doit avoir dans tous les cas un type et un seul type.
type::user-story
: une issue qui apporte une fonctionnalité à l'applicationtype::improve
: une issue qui apporte une amélioration mineure à une fonctionnalité existante, qui est plus simple de ne pas exprimer sous forme d'une user story, et qui bien sûr n'est pas un bug.type::documentation-and-process
: problème ou amélioration d'un process ou d'une documentation interne (les deux sujets documentation et processus sont liés parce que les processus sont documentés). La documentation du logiciel à destination des usagers de l'application n'entre pas dans cette catégorie, elles sont du type user-story
, improve
ou bug
.type::enabler
: un changement qui n'apporte pas directement de valeur aux utilisateurs de l'application. Ce type est utilisé pour des issues dont le but est d'améliorer l'expérience des développeurs (voir définitions : SAFe Enablers,Les enablers en agile)type::technical-debt
: definition, label à utiliser, par exemple pour des issues dont le bug est d'upgrader une librairie, d'améliorer une implémentation, ou une proposition de refactoring… Ce label ne doit pas être utilisé pour des issues "produit".type::support-ops
: pour les tâches de support qui ne nécessitent généralement pas de merge request, par exemple : des migrations de données, des corrections de données, des extractions de données…type::spike
: voir la definitiontype::meta
: pour des issues de type "meta", par exemple, des issues dont le but est de créer d'autres issues, de faire de l'affinage d'issues, ou organiser des rituels…type::meta-spec-writing
: pour des issues dont l'objectif est de créer des issues ou des Epic, dont le but est de rédiger des spécifications techniques, ce sont des sortes d'issues de type "meta", mais plus spécifiques.type::bug
: pour des issues qui décrivent des dysfonctionnements de l'applicationtype::bug-job-CI
: pour des issues qui décrivent des bugs de CIpriority::critical
: une issue qui doit obligatoirement être traitée tout de suite par un développeurpriority::24h
: une issue qui doit être traitée d'ici 24hpriority::7days
: une issue qui doit être traitée d'ici à 1 semaineUne issue doit avoir un et seulement un label de type workflow
, un et un seul label de type product-review
.
workflow::need-product-specs
: l'issue doit être spécifiée par un membre de l'équipe produitworkflow::need-design
: l'issue a besoin de wireframe, design, …workflow::need-tech-specs
: l'issue doit être affiner par un membre de l'équipe techworkflow::ready-for-development
: l'issue est prête à être implémentéeworkflow::to-be-continued
: l'issue a été commencée, mais mise en pause parce que le développeur est assigné sur une autre issue.workflow::doing
: un développeur est en train de travailler sur cette issueworkflow::ready-for-first-review
: l'issue est prête à être review par un développeurworkflow::ready-for-maintainer-review
: l'issue est prête à être review par un maintainersworkflow::blocked
: l'issue est bloquée
Par exemple :
workflow::ready-for-merge
: l'issue a été review et est prête à être mergéneed-cto
: l'issue est bloquée parce qu'elle est en attente d'une validation par le CTOproduct-review::needed
: indique que l'issue doit être review par un membre de l'équipe produitproduct-review::not-needed
: indique que l'issue n'a pas besoin d'être review par l'équipe produitproduct-review::pending
: issue en attente de review par un membre de l'équipe produitproduct-review::feedback
: une demande de correction a été émise par un membre de l'équipe produitproduct-review::approved
: la Merge Request a été review et validée par un membre de l'équipe produit avec plus aucune demande de correctionboard-product-refinement
: pour intégrer des issues dans un Kanban board qui contient une liste d'issues que l'équipe produit doit affinerboard-tech-refinement
: pour intégrer des issues dans un Kanban board qui contient une liste d'issues que l'équipe tech doit affinerboard-support
: pour intégrer des issues dans un Kanban board qui contient une liste d'issues de support qui traitent des demandes externes à l'équipe tech ou produit.board-cto
: utilisé par le CTO pour suivre des issues "cross team"first-contribution
: pour identifier des issues en théorie facilement réalisables par un nouveau développeur en phase d'onboarding.sprint-planning
: pour les issues de type meta
, dont l'objectif est d'organiser le rituel Sprint Planning.sprint-retrospective
: pour les issues de type meta
, dont l'objectif est d'organiser le rituel Sprint Retrospective.sprint-retro-follow-up
: pour identifier les sujets qui ont été remontés lors d'une session de Sprint Retrospective.triage
: pour identifier les issues qui doivent être triées, c'est-à-dire, décider si l'issue doit être abandonnée pour être placée dans un backlog.need-to-be-planned
: pour identifier des issues validées, mais qui doivent être planifiées, c'est-à-dire, être ajoutées dans un sprintdanger
: pour identifier des issues qui doivent être traitées avec prudence, qui par exemple risquent de détruire des données.tech-refinement
: pour identifier une issue qui doit être affiner par l'équipe tech, mais qui n'a pas encore été ajoutée dans le board-tech-refinement
.tech-refinement-removed
: pour identifier des issues qui étaient dans un board-tech-refinement
mais qui n'ont pas été affiné par manque de temps et donc repoussées à une future session.security
: pour identifier des issues en lien avec la sécurité informatique, par exemple, un risque de fuite de données, de perte de données, d'intrusion…version-outdated
: pour identifier les issues dont l'objectif est la mise à jour de librairies ou de services.Liste de labels peu utilisés, ils permettaient d'identifier les compétences techniques nécessaires pour pouvoir traiter l'issue.
skills:ansible
skills:terraform
skills:nodejs
skills:postgraphile
skills:html/css
skills:docker
skills:gitlab-ci
skills:docker
skills:dev-ops
skills:postgres
skills:postgres-rls
skills:postgres-rbac
skills:postgresql-plsql
skills:postgresql-policy
skills:reactjs
skills:shellscript
skills:sql