Présentation
EnglishRÉSUMÉ
Le développement rapide des techniques dans les projets, particulièrement dans le domaine informatique, a conduit à l'amélioration des pratiques et des démarches. Le but étant de satisfaire les besoins du client en livrant rapidement et régulièrement des fonctionnalités à forte valeur ajoutée, un groupe de pratiques pragmatiques a été défini, nommé méthodes agiles. Celles-ci sont axées autour de quatre valeurs : l'équipe, l'application, la collaboration et l'acceptation du changement. Cet article propose de faire le tour de la question, en détaillant les fondamentaux des méthodes agiles. Les différents principes sont ainsi expliqués, de leurs caractéristiques à leurs enjeux, afin de donner la ligne de conduite des acteurs au sein d'un projet Agile.
Lire cet article issu d'une ressource documentaire complète, actualisée et validée par des comités scientifiques.
Lire l’articleAuteur(s)
-
Jacques PRINTZ : Professeur au Conservatoire National des Arts et Métiers CNAM
INTRODUCTION
Les méthodes dites « agiles », qui apparaissent sous cette appellation dans les années 2000 ont cependant une histoire un peu plus ancienne. Comme souvent, et malheureusement, en informatique on change la terminologie à défaut de changer de concepts. Le seul résultat certain de cette pratique déplorable est la confusion dans les esprits, en particulier celui des décideurs qui ont fini par perdre toute confiance dans ce que leur racontent leur DSI et/ou leurs experts informatiques. Le scepticisme et la défiance règne.
À la fin des années 1980, James Martin, auteur prolixe, a publié en trois volumes, chez Prentice Hall, son Information Engineering, qui a donné naissance, quelques années plus tard au RAD (Rapid Application Development) vite connu sous l'appellation « Quick and Dirty » et complètement décrédibilisé suite aux mauvaises pratiques qu'il a engendré. Il y avait beaucoup de bonnes choses dans l'Information Engineering, mais comme on peut s'en souvenir, c'est l'époque de la rupture technologique, avec le développement fulgurant des architectures distribuées, du client-serveur avec ses différentes variantes (client lourd, client semi-lourd, client léger, etc.). Les langages « anciens » comme Cobol, même rénovés avec les générateurs d'applications et autres L4G qui fleurissent vers la fin des années 1980, n'intéressent plus grand monde (quand bien même il reste encore des milliards de lignes de codes en Cobol dans les banques, les assurances, dans les administrations...). La mode est désormais aux langages objets (C++, Java) et aux méthodes de conception orientées objets qui, dans les années 1990, donneront naissance au langage UML. On est encore dans l'euphorie de l'intelligence artificielle, dont le battage médiatique a réussi à faire croire à de nombreux décideurs que l'on va pouvoir mécaniser la fabrication des programmes (en se débarrassant des programmeurs, ces gêneurs qui font des erreurs et qui sont incapables de s'exprimer dans un langage compréhensible de tous) et enfin, connaître le meilleur des mondes informatiques où l'erreur a disparu comme par magie. Le réveil, qui prend les allures d'un crash, sera particulièrement brutal (cf. le rapport Chaos du Standish Group [Doc. H 3 200]).
C'est également la période de tous les excès issus d'une démarche qualité mal comprise, qui va vite se transformer en bureaucratie, dont l'objectif est de satisfaire à des normes souvent ineptes (la norme du DOD 2167, tristement célèbre, est encore dans les mémoires de certains), inventées par des « experts » n'ayant jamais réalisé un système de leur vie. Comme on le sait, l'échec sera au rendez-vous, avec en plus un discrédit général sur la qualité dont on n'ose même plus prononcer le nom dans les entreprises qui se veulent sérieuses et informées.
Il faut également signaler le cycle de développement dit « en spirale » popularisé par B. Boehm dans son article de la revue IEEE Computer, vol. 21, no 5, mai 1988, A spiral model of software development and enhancement. Comme tout ce qu'a publié B. Boehm, c'est intelligent et profond, fondé sur la vraie expérience de l'auteur en matière de système logiciel. L'idée de Boehm est de coupler le processus de développement classique « en cascade » avec une gestion de risque qui donne des critères de convergence permettant de réaliser le système attendu par les parties prenantes. C'est une façon élégante de gérer les rétroactions sur une base réellement objective : quel décideur sensé pourrait refuser de prendre en compte les risques identifiés qui mettraient le projet en échec ?
Sur toute cette période, le lecteur intéressé peut consulter le recueil de textes, sélectionnés par D. Reifer, Software management, publié par l'IEEE en 1993, qui donne une bonne photo des problématiques de l'époque.
En fait, rien de vraiment nouveau dans la démarche agile, si ce n'est, comme on dit au football, une remise de la balle au centre.
DOI (Digital Object Identifier)
Cet article fait partie de l’offre
Technologies logicielles Architectures des systèmes
(240 articles en ce moment)
Cette offre vous donne accès à :
Une base complète d’articles
Actualisée et enrichie d’articles validés par nos comités scientifiques
Des services
Un ensemble d'outils exclusifs en complément des ressources
Un Parcours Pratique
Opérationnel et didactique, pour garantir l'acquisition des compétences transverses
Doc & Quiz
Des articles interactifs avec des quiz, pour une lecture constructive
Présentation
6. Processus agiles
En réaction aux méthodologies appliquées sans nuance à n'importe quel type de projet, la communauté AGILE met l'accent sur :
-
les individus concrets et leurs pratiques culturelles ;
-
la bonne communication entre tous les acteurs, y compris avec les usagers et leur mandataire MOA ;
-
la capacité de réaction et la prise en compte de nouveaux besoins, quand bien même le développement est déjà très avancé.
Plutôt que des définitions plus ou moins absconses des processus et des activités, telles qu'on peut les trouver dans les documents normatifs (cf. IEEE Software Engineering standards, Normes ISO/CEI, etc.), l'accent est mis sur la dimension humaine et sociale, sur les bonnes pratiques d'ingénierie qui sont souvent de l'ordre du bon sens, sur le découpage du développement en phases temporelles et sur les livraisons régulières de code source immédiatement utilisable par les usagers.
Aux méthodologies « lourdes », dont l'intérêt est quand même reconnu pour les projets critiques, on préfère les méthodologies « légères » que l'on peut adapter simplement en fonction des circonstances rencontrées dans la vie du projet. On peut classer les points de vue proposés en fonction du degré de formalisation de la notion de processus, et distinguer trois groupes de méthodes AGILES.
-
Groupe 1
Dans ce groupe, le concept de processus est parfaitement défini. Les processus sont explicites, avec une finalité claire ; leur enchaînement est précisé grâce à la notion de phase. C'est le cas de UP qui est un aménagement de ce qui est connu et pratiqué depuis fort longtemps. Il n'y a rien de particulier à dire.
-
Groupe 2
Dans ce groupe, le concept de processus est intuitif ; il est laissé à l'appréciation de chacun. Les méthodologies correspondantes sont qualifiées de « légères » ; elles mettent l'accent sur la capacité d'adaptation de la méthode aux individus et aux projets. La méthode s'adapte au réel, et non l'inverse. C'est le cas de ASD-Crystal (A. Cockburn) et ASDE (J. Highsmith). Pour expliquer comment s'y prendre pour évaluer une situation et adapter la méthode, on donne un certain nombre de principes et des règles pratiques, comme par exemple :
-
Communiquer face à face (cf. principe no 6).
-
Une...
-
Cet article fait partie de l’offre
Technologies logicielles Architectures des systèmes
(240 articles en ce moment)
Cette offre vous donne accès à :
Une base complète d’articles
Actualisée et enrichie d’articles validés par nos comités scientifiques
Des services
Un ensemble d'outils exclusifs en complément des ressources
Un Parcours Pratique
Opérationnel et didactique, pour garantir l'acquisition des compétences transverses
Doc & Quiz
Des articles interactifs avec des quiz, pour une lecture constructive
Processus agiles
BIBLIOGRAPHIE
-
(1) - COMTE-SPONVILLE - Petit traité des grandes vertus. - PUF (1995).
-
(2) - OZ (E.) - When professional standards are lax : the CONFIRM failure and its lessons. - Communications of the ACM, vol. 37, no 10 (1994).
-
(3) - EWUSI-MENSAH (K.) - Software development failures. - MIT Press (2003).
-
(4) - HOCK (D.) - Birth of the chaordic age. - Berrett-Koehler (1999).
-
(5) - HIGHSMITH (J.) - Adaptive software development, a collaborative approach to managing complex systems. - Dorset House (1999).
-
(6) - SKROWRONSKI (V.) - Do agile methods marginalize problem solvers ? - IEEE Computer, oct. 2004.
-
(7)...
DANS NOS BASES DOCUMENTAIRES
Site du Manifeste AGILE http://www.agilealliance.org
HAUT DE PAGE
IEEE std 1058 - 1998 - Software project management plan - -
IEEE std 1490 - 2003 - A guide to the project management body of knowledge (PMBOOK) - -
HAUT DE PAGECet article fait partie de l’offre
Technologies logicielles Architectures des systèmes
(240 articles en ce moment)
Cette offre vous donne accès à :
Une base complète d’articles
Actualisée et enrichie d’articles validés par nos comités scientifiques
Des services
Un ensemble d'outils exclusifs en complément des ressources
Un Parcours Pratique
Opérationnel et didactique, pour garantir l'acquisition des compétences transverses
Doc & Quiz
Des articles interactifs avec des quiz, pour une lecture constructive