Méthode agileEn ingénierie logicielle, les pratiques agiles mettent en avant la collaboration entre des équipes auto-organisées et pluridisciplinaires et leurs clients[1]. Elles s'appuient sur l'utilisation d'un cadre méthodologique léger mais suffisamment centré sur l'humain et la communication[2]. Elles préconisent une planification adaptative, un développement évolutif, une livraison précoce et une amélioration continue, et elles encouragent des réponses flexibles au changement[3],[4]. Cette approche a été popularisée à partir de 2001 par le Manifeste pour le développement agile de logiciels[5]. Les quatre valeurs et les douze principes adoptés dans ce manifeste sont issus d'un large éventail d'approches dont Scrum et eXtreme Programming [4],[6]. Depuis lors, les méthodes ou les approches qui s'inscrivent dans la philosophie de ce manifeste sont appelées « méthodes agiles[4] » ou « approches agiles ». Les méthodes agiles se veulent plus pragmatiques que les méthodes traditionnelles[note 1] , impliquent au maximum le demandeur (client) et permettent une grande réactivité à ses demandes. Elles reposent sur un cycle de développement itératif, incrémental et adaptatif. FondementsLe Manifeste pour le développement agile de logiciels est un texte rédigé aux États-Unis en 2001 par dix-sept experts du développement logiciels. Ils estimaient que le taux important d'échecs des projets de développements logiciels était dû à la lourdeur des méthodes traditionnelles inspirées du génie civil et s'appuyant sur un cycle de développement en cascade[4]. Chacun d'entre eux avait déjà mis au point et expérimenté de nouvelles méthodes plus légères. Les approches agiles ne sont donc pas apparues avec le manifeste agile. Cependant celui-ci a défini leurs dénominateurs communs et consacré le terme d'« agile » pour les référencer[4],[7]. Les valeurs et les principes du manifeste agile sont défendus et promus par l'Agile Alliance créée par certains des signataires[8]. En s'appuyant sur leur expérience combinée du développement logiciel, les dix-sept signataires du manifeste ont proclamé qu'ils attachaient de l'importance « aux individus et leurs interactions plutôt qu'aux processus et aux outils », « à un logiciel fonctionnel plutôt qu’à une documentation exhaustive », « à la collaboration avec les clients plutôt qu'à la négociation contractuelle » et « à l’adaptation au changement plutôt qu'à l'exécution d’un plan ». Cela signifie que les éléments à gauche du mot « plutôt » dans chaque citation sont réputés avoir plus de valeur que ceux à droite, bien qu'il y ait aussi de la valeur dans ces derniers. Ces quatre citations sont appelées les quatre « valeurs » du manifeste agile[5]. Les quatre valeurs du manifeste agile ont été déclinées en douze principes afin d'aider opérationnellement les équipes qui souhaitaient les suivre. HistoriqueTravaux sur le cycle de production itératif et incrémentalLes travaux sur le cycle de production itératif et incrémental remontent aux années 1930 et 1940, avec les travaux de Walter Shewhart et William Edwards Deming. Ces recherches sont appliquées à la production informatique à la fin des années 1950, notamment avec le développement de parties logicielles dans le cadre du programme Mercury[7]. Gerald Weinberg (en) mentionne un projet de développement réalisé en 1957 pour Motorola qui utilisait une technique similaire à ce qui sera plus tard l'eXtreme programming[7]. Les approches agiles sont l'aboutissement de nombreux travaux tels que ceux de Tom Gilb (cycle de vie évolutif)[9] en 1981, de Scott Shultz (production en itérations rapides), de Brian Gallagher et de Alex Balchin. Elles intègrent aussi les techniques JRP (Joint Requirements Planning) et JAD (Joint application design) (en) qui furent initiées par Dan Gielan, puis formalisées par Chuck Morris d'IBM en 1984 et diffusées sous forme de livres en 1989 par, entre autres, J. Wood et D. Silver. La première méthode agile[10] serait la méthode EVO[11], de Tom Gilb, publiée en 1976. En 1986, Barry Boehm publie le modèle en spirale (développement incrémental) tandis que Hirotaka Takeuchi (en) et Ikujiro Nonaka publient « The new new product development game[12] » un modèle de développement de produits industriels basé sur l'engagement simultané des diverses disciplines concernées (ingénierie concourante). Apparition du terme « agile »Le terme agile apparaît dans le monde économique anglophone en 1991[13]. En 1991, James Martin (en), s’appuyant sur une vision de l'évolution continue des techniques informatiques, propose une méthode de développement rapide d’application (RAD). La structure itérative, incrémentale et adaptative de cette méthode est une base des approches agiles actuelles. Elle détermine les phases essentielles du cycle de développement et met en œuvre une adaptation permanente fondée sur la validation permanente des utilisateurs et leur responsabilité directe dans la dynamique applicative. À partir de 1994, Jean-Pierre Vickoff en France, notamment avec le Processus RAD2 publié par le Gartner Group en 1999, et Jennifer Stapleton en Grande-Bretagne, avec DSDM, introduisent des compléments et des évolutions (détails Développement rapide d'applications). Manifeste agileEn 2001, aux États-Unis, dix-sept figures éminentes du développement logiciel se réunissent pour débattre d'un thème unificateur de leurs méthodes respectives. Les plus connus d'entre eux sont Ward Cunningham, l'inventeur du Wiki via WikiWikiWeb, Kent Beck, père de l'extreme programming et cofondateur de JUnit, Ken Schwaber créateur de Scrum et Jeff Sutherland son promoteur, Jim Highsmith (en), prônant l'ASD, Alistair Cockburn pour la méthode Crystal clear, Martin Fowler et Dave Thomas, ainsi qu'Arie van Bennekum pour DSDM (Dynamic System Development Method). Ces 17 experts extraient alors de leurs usages respectifs les critères communs et les principes qui, selon eux, conduisent aux meilleurs concepts de direction de projets et de développement de logiciels. De cette réunion émerge le Manifeste agile, considéré comme la définition commune des valeurs du développement agile de logiciels et de ses principes sous-jacents par les praticiens et les universitaires[14],[15]. Pour décrire leur manifeste au mieux, les dix-sept signataires ont d'abord pensé au terme lightweight (léger) pour se fixer finalement sur agile (traduit à l'identique en français). D'après Fowler, ce terme traduit mieux l'aspect rapidement adaptatif de ces méthodes[16]. Au début des années 2000, une dizaine de méthodes agiles (dont XP Extreme programming et Scrum sont les principales représentantes) sont popularisées. L'apport méthodologique d'XP réside dans la préconisation de pousser à l’extrême les principales pratiques de qualité de la construction applicative ainsi que les techniques adaptatives d’estimation consensuelle, de planification pilotée par l'utilisateur et de reporting visuel en temps réel de l'avancement ainsi que des problèmes rencontrés (affichage mural à base de post-it). Scrum propose un ensemble réduit de pratiques concentrées sur le développement de l'adaptabilité par l'apprentissage et l'auto-organisation. Approches agilesAu sens strictLes approches pouvant être qualifiées d'agiles, depuis la publication du manifeste Agile, sont :
Limitations et extensionsExemples de pratiques agiles
Modèles d'organisation agiles à grande échelleAfin de pouvoir mener un (très) gros projet ou un portefeuille de projets nécessitant plusieurs équipes agiles, différents modèles d'organisation agiles à grande échelle ont vu le jour. En voici la liste :
Entreprise agileUne entreprise agile est une entreprise disposant d’une culture et de pratiques issues ou inspirées des approches agiles, lui offrant une grande capacité d’adaptation à son environnement. Dans un monde devenant de plus en plus complexe et incertain, cette capacité d’adaptation fait l'objet d'un précieux levier de croissance ou de survie pour de plus en plus d’entreprises. Les principales caractéristiques communes aux entreprises agiles sont les suivantes :
Les entreprises agiles parviennent ainsi à réaliser des produits ou services innovants faisant l'objet d'un haut niveau de satisfaction, tout en réduisant les coûts et délais de production. Par ailleurs, le management agile offre un environnement de travail de qualité pour les équipes, limitant ainsi l'absentéisme et le turn-over. Voici ci-dessous plusieurs sources d'auteurs différents permettant d'appréhender davantage ce modèle d'entreprise :
CritiquesParmi les 17 signataires du manifeste agile, certains ont depuis émis des critiques non sur les principes Agiles, mais sur leur mise en pratique. Ron Jeffries[27] montre plusieurs problèmes :
Il conseille aux développeurs, non pas d'abandonner l'agile comme le titre de sa note laisse penser, mais de détacher sa réflexion des méthodes agiles imposées et de rester concentré sur le développement d'un logiciel qui marche, par exemple en mettant en pratique l'Extreme Programming. Andy Hunt[28] quant à lui pense que si la mise en pratique des approches agiles ne marche pas, c'est parce que nous préférons appliquer des règles simples alors qu'elles imposent une constante remise en question. Les deux valeurs "inspection" et "adaptation au changement" sont essentielles, notamment dans le framework Scrum, mais peu respectées, du fait de la nécessité de remise en question sous-jacente. Martin Fowler[29] indique que la plupart des projets agiles en 2018 sont « faux-agile » et ne respectent pas ses valeurs et ses principes. Ainsi, les trois principaux défis sont de :
Dave Thomas[30] pointe du doigt le fait que beaucoup de personnes et d'entreprises ont profité du courant « agile » afin de vendre des produits et des services. De manière humoristique, il dit « l'Agile est mort, vive l'agilité ». Utiliser un nom plutôt qu'un adjectif permettrait selon lui de mieux détecter les vendeurs peu scrupuleux de produits et services prétendument agiles. Robert C. Martin (Uncle Bob)[31] pense que le mouvement agile était censé promouvoir les idéaux du Software craftsmanship mais a en fait horriblement échoué. Selon lui, le mouvement agile est devenu commercial, et a mis de côté ses valeurs d'origine. Notes et référencesNotes
Références
AnnexesArticles connexes |
Portal di Ensiklopedia Dunia