Agile - Guide rapide
Agile est une méthodologie de développement logiciel pour construire un logiciel de manière incrémentielle en utilisant de courtes itérations de 1 à 4 semaines afin que le processus de développement soit aligné sur les besoins changeants de l'entreprise. Au lieu d'un développement en un seul passage de 6 à 18 mois où toutes les exigences et les risques sont prédits à l'avance, Agile adopte un processus de rétroaction fréquente où un produit exploitable est livré après une itération de 1 à 4 semaines.
Rôles dans Agile
Scrum Master
Un Scrum Master est un chef d'équipe et un facilitateur qui aide les membres de l'équipe à suivre des pratiques agiles afin qu'ils puissent respecter leurs engagements. Les responsabilités d'un scrum master sont les suivantes -
Permettre une coopération étroite entre tous les rôles et fonctions.
Pour supprimer tous les blocs.
Pour protéger l'équipe de toute perturbation.
Travailler avec l'organisation pour suivre les progrès et les processus de l'entreprise.
Pour s'assurer que les processus Agile Inspect & Adapt sont exploités correctement, ce qui inclut
- Stand-ups quotidiens,
- Réunions planifiées,
- Demo,
- Review,
- Réunions rétrospectives, et
- Faciliter les réunions d'équipe et le processus de prise de décision.
Propriétaire du produit
Un Product Owner est celui qui conduit le produit du point de vue commercial. Les responsabilités ou un Product Owner sont les suivantes -
- Définir les exigences et prioriser leurs valeurs.
- Pour déterminer la date de sortie et le contenu.
- Jouer un rôle actif dans la planification des itérations et les réunions de planification des versions.
- Pour s'assurer que l'équipe travaille sur l'exigence la plus importante.
- Pour représenter la voix du client.
- Accepter les user stories qui répondent à la définition des critères d'acceptation terminés et définis.
Équipe interfonctionnelle
Chaque équipe agile doit être une équipe autosuffisante avec 5 à 9 membres d'équipe et une expérience moyenne allant de 6 à 10 ans. En règle générale, une équipe agile comprend 3 à 4 développeurs, 1 testeur, 1 responsable technique, 1 product owner et 1 scrum master.
Le Product Owner et le Scrum master sont considérés comme faisant partie de Team Interface, tandis que les autres membres font partie de Technical Interface.
Comment une équipe Agile planifie son travail?
Une équipe Agile travaille par itérations pour livrer des user stories où chaque itération dure de 10 à 15 jours. Chaque user story est planifiée en fonction de la hiérarchisation et de la taille de son backlog. L'équipe utilise sa capacité - le nombre d'heures disponibles avec l'équipe pour travailler sur des tâches - pour décider de la portée à planifier.
Point
Un point définit combien une équipe peut s'engager. Un point fait généralement référence à 8 heures. Chaque histoire est estimée en points.
Capacité
La capacité définit combien un individu peut s'engager. La capacité est estimée en heures.
Qu'est-ce qu'une User Story?
Une user story est une exigence qui définit ce qui est requis par l'utilisateur en tant que fonctionnalité. Une user story peut prendre deux formes -
- En tant que <Rôle utilisateur>, je veux <Fonctionnalité> afin que <Valeur métier>
- Afin de <Valeur commerciale> en tant que <Rôle utilisateur>, je veux <Fonctionnalité>
Lors de la planification de la version, une estimation approximative est donnée à une user story en utilisant l'échelle relative en points. Lors de la planification des itérations, l'histoire est décomposée en tâches.
Relation entre les histoires d'utilisateurs et les tâches
- La user story parle de ce qui doit être fait. Il définit ce dont un utilisateur a besoin.
- La tâche explique comment procéder. Il définit comment une fonctionnalité doit être mise en œuvre.
- Les histoires sont implémentées par tâches. Chaque histoire est une collection de tâches.
- La user story est divisée en tâches lorsqu'elle est planifiée dans l'itération actuelle.
- Les tâches sont estimées en heures, généralement de 2 à 12 heures.
- Les histoires sont validées à l'aide de tests d'acceptation.
Quand une histoire est terminée
L'équipe décide quoi doneveux dire. Les critères peuvent être -
- Toutes les tâches (développement, tests) sont terminées.
- Tous les tests d'acceptation sont en cours et réussis.
- Aucun défaut n'est ouvert.
- Le propriétaire du produit a accepté l'histoire.
- Livrable à l'utilisateur final.
Qu'est-ce que les critères d'acceptation?
Les critères définissent la fonctionnalité, le comportement et les performances requis par une fonctionnalité afin qu'elle puisse être acceptée par le propriétaire du produit. Il définit ce qui doit être fait pour que le développeur sache quand une user story est terminée.
Comment les exigences sont-elles définies?
Les exigences sont définies comme
- Une histoire d'utilisateur,
- Avec des critères d'acceptation, et
- Tâches pour mettre en œuvre l'histoire.
En février 2001, à la station Snowbird de l'Utah, 17 développeurs de logiciels se sont réunis pour discuter des méthodes de développement légères. Le résultat de leur réunion a été le Manifeste Agile pour le développement logiciel suivant -
Nous découvrons de meilleures façons de développer des logiciels en le faisant et en aidant les autres à le faire. Grâce à ce travail, nous en sommes venus à apprécier -
- Individus et interactions sur les processus et les outils
- Logiciel de travail sur une documentation complète
- Collaboration client sur négociation de contrat
- Répondre au changement au sujet d'un plan
Autrement dit, bien qu'il y ait de la valeur dans les éléments de droite, nous valorisons davantage les éléments de gauche.
Douze principes du Manifeste Agile
Customer Satisfaction - La plus haute priorité est donnée à la satisfaction des exigences des clients grâce à la livraison précoce et continue de logiciels précieux.
Welcome Change- Les changements sont inévitables pendant le développement du logiciel. Des exigences en constante évolution devraient être les bienvenues, même tard dans la phase de développement. Les processus agiles devraient travailler pour augmenter l'avantage concurrentiel des clients.
Deliver a Working Software - Livrer fréquemment un logiciel fonctionnel, allant de quelques semaines à quelques mois, en considérant des délais plus courts.
Collaboration - Les gens d'affaires et les développeurs doivent travailler ensemble pendant toute la durée d'un projet.
Motivation- Les projets doivent être construits autour d'individus motivés. Fournissez un environnement pour soutenir les membres de l'équipe et leur faire confiance afin de les faire se sentir responsables de faire le travail.
Face-to-face Conversation - La conversation en face à face est la méthode la plus efficace et la plus efficace pour transmettre des informations à et au sein d'une équipe de développement.
Measure the Progress as per the Working Software - Un logiciel fonctionnel est la clé et doit être la principale mesure des progrès.
Maintain Constant Pace- Les processus agiles visent le développement durable. L'entreprise, les développeurs et les utilisateurs doivent être en mesure de maintenir un rythme constant avec le projet.
Monitoring - Portez une attention régulière à l'excellence technique et à la bonne conception pour améliorer l'agilité.
Simplicity - Gardez les choses simples et utilisez des termes simples pour mesurer le travail qui n'est pas terminé.
Self-organized Teams - Une équipe agile doit être auto-organisée et ne pas dépendre fortement d'autres équipes car les meilleures architectures, exigences et conceptions émergent d'équipes auto-organisées.
Review the Work Regularly - Revoir le travail effectué à intervalles réguliers afin que l'équipe puisse réfléchir à la manière de devenir plus efficace et d'ajuster son comportement en conséquence.
Itératif / incrémental et prêt à évoluer
La plupart des méthodes de développement agiles divisent un problème en tâches plus petites. Il n'y a pas de planification directe à long terme pour aucune exigence. Normalement, des itérations sont planifiées qui sont de courte durée, par exemple, 1 à 4 semaines. Une équipe interfonctionnelle est créée pour chaque itération qui fonctionne dans toutes les fonctions de développement logiciel telles que la planification, l'analyse des exigences, la conception, le codage, les tests unitaires et les tests d'acceptation. Le résultat à la fin de l'itération est un produit fonctionnel et il est démontré aux parties prenantes à la fin d'une itération.
Après la démonstration, les commentaires de révision sont pris et sont prévus pour être incorporés dans le logiciel de travail selon les besoins.
Communication en face à face
Chaque équipe agile doit avoir un représentant client tel qu'un propriétaire de produit dans la méthodologie Scrum. Ce représentant est autorisé à agir au nom des parties prenantes et il peut répondre aux requêtes des développeurs entre les itérations.
Un radiateur d'information (affichage physique) est normalement situé bien en vue dans un bureau, où les passants peuvent voir les progrès de l'équipe agile. Ce radiateur d'informations affiche un récapitulatif à jour de l'état d'un projet.
Boucle de rétroaction
Le stand-up quotidien est une culture commune à tout développement agile; il est également connu commedaily scrum. C'est une sorte de brève session où chaque membre de l'équipe se rend compte de l'état d'avancement de ce qu'il a fait, de la marche à suivre et des problèmes auxquels il est confronté.
Le stand-up quotidien, comme son nom l'indique, est une réunion de statut quotidienne entre tous les membres d'une équipe agile. Il fournit non seulement un forum pour des mises à jour régulières, mais met également l'accent sur les problèmes des membres de l'équipe afin qu'ils puissent être rapidement résolus. Le stand-up quotidien est une pratique incontournable, quelle que soit la façon dont une équipe agile est constituée, quel que soit l'emplacement de son bureau.
Qu'est-ce que le Daily Stand-up?
Un stand-up quotidien est une réunion de statut quotidienne entre tous les membres de l'équipe et dure environ 15 minutes.
Chaque membre doit répondre à trois questions importantes -
- Ce que j'ai fait hier?
- Qu'est-ce que je vais faire aujourd'hui?
- Tout obstacle auquel je suis confronté ... / Je suis bloqué en raison de ...
Le stand-up quotidien est pour la mise à jour du statut, pas pour toute discussion. Pour la discussion, les membres de l'équipe doivent planifier une autre réunion à un moment différent.
Les participants se lèvent généralement au lieu de s'asseoir pour que la réunion se termine rapidement.
Pourquoi le stand-up est-il important?
Les avantages d'avoir un stand-up quotidien en agile sont les suivants -
- L'équipe peut évaluer les progrès sur une base quotidienne et voir si elle peut livrer selon le plan d'itération.
- Chaque membre de l'équipe informe tout sur ses engagements de la journée.
- Il offre une visibilité à l'équipe sur tout retard ou obstacle.
Qui participe à un stand-up?
Le scrum master, le product owner et l'équipe de livraison doivent assister quotidiennement au stand-up.
Les parties prenantes et les clients sont encouragés à assister à la réunion et peuvent agir en tant qu'observateurs, mais ils ne sont pas censés participer à des stand-ups.
Il est de la responsabilité du scrum master de prendre note des requêtes de chaque membre de l'équipe et des problèmes auxquels ils sont confrontés.
Équipes dispersées géographiquement
Les stand-ups peuvent être effectués de plusieurs manières, au cas où les membres de l'équipe agile opéreraient à partir de fuseaux horaires différents -
Sélectionnez un membre sur une base de rotation, qui peut assister à la réunion debout des équipes situées dans différents fuseaux horaires.
Avoir un stand-up séparé par équipe, mettre à jour le statut du stand-up dans un outil tel que Rally, SharePoint, Wikis, etc.
Préparez une grande variété d'outils de communication tels que les conférences téléphoniques, les vidéoconférences, les messageries instantanées ou tout autre outil de partage de connaissances tiers.
La définition de done pour User Story, Itération et Release est donnée ci-dessous.
Histoire de l'utilisateur
Une user story est une exigence qui est formulée en quelques phrases dans le langage courant d'un utilisateur et qui doit être complétée dans une itération. Une user story est réalisée lorsque
- Tous les codes associés ont été enregistrés.
- Tous les cas de test unitaires ont été réussis.
- Tous les cas de test d'acceptation ont été réussis.
- Le texte d'aide est rédigé.
- Le Product Owner a accepté l'histoire.
Itération
Une itération est une collection de récits d'utilisateurs / défauts sur lesquels travailler et accepter lors de la sortie d'un produit. Les itérations sont définies lors de la réunion de planification des itérations et complétées par une démonstration d'itération et une réunion de révision. Une itération est également appeléesprint. Une itération est effectuée lorsque
- La sauvegarde du produit est terminée.
- Les performances ont été testées.
- Les user stories ont été acceptées ou déplacées vers l'itération suivante.
- Les défauts ont été corrigés ou reportés à la prochaine itération.
Libération
Une version est une étape majeure qui représente une livraison interne ou externe d'une version opérationnelle et testée du produit / système. Une libération est effectuée lorsque
- Le système est soumis à des tests de résistance.
- Les performances sont réglées.
- Des validations de sécurité sont effectuées.
- Le plan de reprise après sinistre est testé.
Le but de la planification des versions est de créer un plan pour fournir un incrément au produit. Cela se fait tous les 2 à 3 mois.
Qui est impliqué?
Scrum Master - Le scrum master agit en tant que facilitateur pour l'équipe de livraison agile.
Product Owner - Le Product Owner représente la vue générale du backlog du produit.
Agile Team - L'équipe de livraison Agile fournit des informations sur les faisabilités techniques ou sur les dépendances.
Stakeholders - Les parties prenantes telles que les clients, les responsables de programme et les experts en la matière agissent en tant que conseillers lorsque des décisions sont prises concernant la planification de la version.
Prérequis de la planification
Les conditions préalables à la planification des versions sont les suivantes:
Un backlog produit classé, géré par le Product Owner. En général, cinq à dix fonctionnalités sont prises qui, selon le propriétaire du produit, peuvent être incluses dans une version
Contribution de l'équipe sur les capacités, la vitesse connue ou sur tout défi technique
Vision de haut niveau
Objectif commercial et marché
Reconnaître si de nouveaux éléments du backlog de produit sont nécessaires
Matériaux nécessaires
La liste des matériaux requis pour la planification des versions est la suivante:
- Agenda publié, objectif
- Tableaux à feuilles mobiles, tableaux blancs, marqueurs
- Projecteur, moyen de partager des ordinateurs ayant des données / outils nécessaires lors de la réunion de planification
- Données de planification
Données de planification
La liste des données nécessaires à la planification des versions est la suivante:
- Itérations précédentes ou résultats de planification des versions
- Commentaires de divers intervenants sur le produit, les conditions du marché et les délais
- Plans d'action des versions / itérations précédentes
- Caractéristiques ou défauts à prendre en compte
- Vitesse des publications / estimations précédentes.
- Calendriers organisationnels et personnels
- Contributions d'autres équipes et experts en la matière pour gérer toutes les dépendances
Production
Le résultat d'une planification de version peut être le suivant:
- Plan de sortie
- Commitment
- Problèmes, préoccupations, dépendances et hypothèses à surveiller
- Suggestions pour améliorer les planifications de versions futures
Ordre du jour
L'ordre du jour d'une planification de publication peut être -
Opening ceremony - Message de bienvenue, révision du but et de l'ordre du jour, outils d'organisation et introduction aux sponsors commerciaux.
Product Vision, Roadmap - Montrez la grande image du produit.
Review previous releases - Discussion sur tout élément pouvant avoir un impact sur le plan.
Release name / theme - Inspectez l'état actuel des thèmes de la feuille de route et effectuez les ajustements nécessaires, le cas échéant.
Velocity - Présentez la vitesse de la version actuelle et des versions précédentes.
Release schedule - Examiner les jalons clés et les décisions sur les délais de publication et les itérations dans la version.
Issues and concerns - Vérifiez tout problème ou problème et enregistrez-le.
Review and Update the Definition of Done - Revoir la définition de done et apporter les changements appropriés en fonction de la technologie, des compétences ou des changements des membres de l'équipe depuis la dernière itération / version.
Stories and items to be considered - Présentez les user stories et les fonctionnalités du backlog du produit à prendre en compte pour la planification dans la version actuelle.
Determine sizing values - Si la vitesse est inconnue, planifiez les valeurs de dimensionnement à utiliser dans la planification des versions.
Coarse the size of stories- L'équipe de livraison détermine la taille appropriée des histoires considérées et divise les histoires en plusieurs itérations si une histoire est trop grande. Le propriétaire du produit et les experts en la matière clarifient les doutes, élaborent les critères d'acceptation et répartissent correctement les histoires. Le scrum master facilite la collaboration.
Map stories to iterations- L'équipe de livraison et le propriétaire du produit déplacent les histoires / défauts dans les itérations en fonction de la taille et de la vitesse. Le scrum master facilite la collaboration.
New concerns or issues - Vérifiez tout nouveau problème basé sur l'expérience précédente et enregistrez-le.
Dependencies and assumptions - Vérifiez les dépendances / hypothèses prévues lors de la planification de la version.
Commit- Le scrum master appelle à la planification. L'équipe de livraison et le propriétaire du produit le signalent comme le meilleur plan, puis s'engagent à passer au niveau de planification suivant, à savoir la planification des itérations.
Communication and logistics planning - Revoir / mettre à jour la planification de la communication et de la logistique pour la sortie.
Parking lot - Traiter le parking signifie que tous les éléments doivent être soit résolus, soit définis comme éléments d'action.
Distribute Action items and action plans - Distribuez les actions à leurs propriétaires, traitez le plan d'action.
Retrospect - Solliciter les commentaires des participants pour assurer le succès de la réunion.
Close - Célébrez le succès.
Le but de la planification des itérations est que l'équipe complète l'ensemble des éléments de backlog de produit les mieux classés. Cet engagement est limité dans le temps en fonction de la durée de l'itération et de la vitesse de l'équipe.
Qui est impliqué?
Scrum Master - Le scrum master agit en tant que facilitateur pour l'équipe de livraison agile.
Product Owner - Le product owner s'occupe de la vue détaillée du backlog produit et de ses critères d'acceptation.
Agile Team - La livraison agile définit leurs tâches et définit les estimations d'effort nécessaires pour remplir l'engagement.
Prérequis de la planification
- Les éléments du backlog de produit sont dimensionnés et ont un point d'histoire relatif attribué.
- Un classement a été attribué aux éléments du portefeuille par le propriétaire du produit.
- Les critères d'acceptation ont été clairement énoncés pour chaque élément du portefeuille.
Processus de planification
Voici les étapes impliquées dans la planification des itérations -
- Déterminez combien d'histoires peuvent tenir dans une itération.
- Divisez ces histoires en tâches et attribuez chaque tâche à leurs propriétaires.
- Chaque tâche est estimée en heures.
- Ces estimations aident les membres de l'équipe à vérifier le nombre d'heures de tâche dont dispose chaque membre pour l'itération.
- Les membres de l'équipe se voient attribuer des tâches en tenant compte de leur vitesse ou de leur capacité afin de ne pas être surchargés.
Calcul de la vitesse
Une équipe agile calcule la vitesse en fonction des itérations passées. La vitesse est un nombre moyen d'unités nécessaires pour terminer les user stories dans une itération. Par exemple, si une équipe a pris 12, 14, 10 points d'histoire dans chaque itération pour les trois dernières itérations, l'équipe peut prendre 12 comme vélocité pour l'itération suivante.
La vitesse planifiée indique à l'équipe combien de user stories peuvent être complétées dans l'itération actuelle. Si l'équipe termine rapidement les tâches assignées, d'autres user stories peuvent être intégrées. Sinon, les stories peuvent également être déplacées vers l'itération suivante.
Capacité de tâche
La capacité d'une équipe découle des trois faits suivants:
- Nombre d'heures de travail idéales par jour
- Jours de personne disponibles dans l'itération
- Pourcentage de temps pendant lequel un membre est exclusivement disponible pour l'équipe.
Supposons qu'une équipe compte 5 membres, engagés à travailler à plein temps (8 heures par jour) sur un projet et que personne ne soit en congé pendant une itération, alors la capacité de tâche pour une itération de deux semaines sera -
5 × 8 × 10 = 400 heures
Étapes de planification
- Le Product Owner décrit l'élément le mieux classé du carnet de commandes.
- L'équipe décrit les tâches requises pour terminer l'élément.
- Les membres de l'équipe sont propriétaires des tâches.
- Les membres de l'équipe estiment le temps nécessaire pour terminer chaque tâche.
- Ces étapes sont répétées pour tous les éléments de l'itération.
- Si un individu est surchargé de tâches, sa tâche est répartie entre les autres membres de l'équipe.
Un backlog de produit est une liste d'éléments à effectuer. Les éléments sont classés avec des descriptions de fonctionnalités. Dans un scénario idéal, les éléments doivent être décomposés en user stories.
Pourquoi le backlog produit est-il important?
- Il est préparé pour que des estimations puissent être données pour chaque fonctionnalité.
- Cela aide à planifier la feuille de route du produit.
- Cela aide à re-classer les fonctionnalités afin que plus de valeur puisse être ajoutée au produit.
- Cela aide à déterminer ce qu'il faut prioriser en premier. L'équipe classe l'élément, puis crée de la valeur.
Caractéristiques du carnet de commandes de produits
Chaque produit doit avoir un backlog de produit qui peut avoir un ensemble de fonctionnalités de grande à très grande taille.
Plusieurs équipes peuvent travailler sur un seul backlog de produit.
Le classement des fonctionnalités est effectué en fonction de la valeur commerciale, de la valeur technique, de la gestion des risques ou de la pertinence stratégique.
Les éléments les mieux classés sont décomposés en histoires plus petites lors de la planification de la publication afin de pouvoir être complétés dans les itérations futures.
Critères d'acceptation
Ce sont les conditions fixées par le propriétaire du produit ou le client afin d'accepter qu'une fonctionnalité soit valide et conforme à leurs exigences.
Toilettage de l'arriéré
Il s'agit d'un processus continu dans lequel le chef de produit ou le client gère le backlog produit en obtenant les commentaires des équipes agiles. Ce processus implique de hiérarchiser les éléments du portefeuille, de les diviser en éléments plus petits, de les planifier pour les futures itérations, de créer de nouvelles histoires, de mettre à jour les critères d'acceptation ou d'élaborer des critères d'acceptation en détail.
Capacité
C'est la quantité de travail qu'une équipe peut prendre pour terminer en une itération.
Fonctionnalité
Une amélioration apportée à un produit ou une capacité de valeur pour une partie prenante qui peut être développée dans une version.
Itération
Un élément de travail basé sur un thème qui peut être complété dans une zone de temps et accepté dans la sortie d'un produit. Le travail d'itération est défini lors de la planification de l'itération et se termine par une réunion de démonstration et de révision. Il est également appelé Sprint.
Incrément
Un incrément est l'état changeant d'un produit à mesure qu'il subit un développement progressif. Il est normalement représenté par des jalons ou un nombre d'itérations fixes.
Propriétaire du produit
Le propriétaire du produit est membre de l'équipe de livraison Agile, chargé de collecter et de classer les exigences métier dans le backlog du produit. Un propriétaire de produit communique ce qui doit être fait dans une version / itération. Il / elle fixe les engagements et est responsable de protéger l'équipe de tout changement d'exigences lors d'une itération.
Backlog produit
Ensemble d'exigences produit fonctionnelles et non fonctionnelles.
Articles du backlog de produit
Il peut s'agir de user stories, de défauts, de fonctionnalités qui doivent être développées par l'équipe agile.
Points
Une unité commune utilisée pour définir la taille relative des user stories, des fonctionnalités ou de tout autre élément de portefeuille.
Libération
Une boîte de temps où le travail est effectué pour prendre en charge la livraison d'incrément testable à un logiciel. Dans Scrum, une version se compose de plusieurs itérations.
Exigence
Une spécification d'un produit logiciel pour satisfaire un contrat ou une fonctionnalité déclarés. Les user stories et les éléments de portefeuille sont des types d'exigences.
Points d'histoire
Une unité utilisée par l'équipe agile pour estimer les tailles relatives des user stories et des fonctionnalités.
Sprint
Identique à Itération.
Timebox
Une durée fixe pendant laquelle un livrable doit être développé. Normalement, avec la fixation de la date de début et de fin d'une boîte de temps, le nombre de ressources est également fixe.
Tâche
C'est une unité de travail qui contribue à la réalisation d'une user story au sein d'une itération. Les user stories sont décomposées en plusieurs tâches et chaque tâche peut être divisée entre les membres de l'équipe en les marquant comme propriétaire des tâches. Les membres de l'équipe peuvent prendre la responsabilité de chaque tâche, mettre à jour les estimations, consigner le travail effectué ou à faire comme ils le souhaitent.
Histoire de l'utilisateur
Critères d'acceptation énumérés pour répondre à certaines exigences d'un utilisateur. Il est normalement rédigé du point de vue d'un utilisateur final.
Rapidité
Une mesure pour pondérer le travail accepté dans une itération ou une boîte de temps. Normalement, il s'agit de la somme des points d'histoire acceptés dans une itération.