IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)

Vous êtes nouveau sur Developpez.com ? Créez votre compte ou connectez-vous afin de pouvoir participer !

Vous devez avoir un compte Developpez.com et être connecté pour pouvoir participer aux discussions.

Vous n'avez pas encore de compte Developpez.com ? Créez-en un en quelques instants, c'est entièrement gratuit !

Si vous disposez déjà d'un compte et qu'il est bien activé, connectez-vous à l'aide du formulaire ci-dessous.

Identifiez-vous
Identifiant
Mot de passe
Mot de passe oublié ?
Créer un compte

L'inscription est gratuite et ne vous prendra que quelques instants !

Je m'inscris !

Les développeurs devraient abandonner les méthodes agiles selon Ron Jeffries
L'un des signataires du Manifeste Agile

Le , par Bill Fassinou

721PARTAGES

10  1 
Ron Jeffries, un informaticien américain de renom dit qu'on devrait abandonner les méthodes agiles dans les entreprises. Son avis est d'autant plus important parce qu'il est l'un des 17 signataires du Manifeste pour le développement Agile de logiciels. Les méthodes dites agiles sont un ensemble de propositions de démarches et de pratiques pour la mise en œuvre d'un projet. Elles sont vite adoptées par les entreprises surtout celles spécialisées dans le développement d'applications informatiques. On voit alors apparaître des alliances pour la promotion des méthodes du Manifeste Agile : la Scrum Alliance, la Kanban Alliance... Des formations et des offres de projets agiles sont proposées. Toutes ces solutions sont offertes pour assister les entreprises dans leur marche pour le développement. Même si les méthodes ne sont pas toujours bien respectées, le fait de les essayer est toujours bénéfique pour l'entreprise. Car cela leur aura permis d'avoir une vision globale sur l'évolution des projets et les aider dans leur prise de décision.

Cependant, les choses ne sont pas toujours aussi simples pour les développeurs et tous ceux qui participent à un projet agile. Erik Meijer, un développeur de l’écosystème .NET disait il y a quelques années qu' « Agile est un cancer que nous devons éliminer de l’industrie ». Andy Hunt, l’un des 17 coauteurs du Manifeste Agile en 2001 n'a pas caché aussi sa déception. Pour lui, Agile n'a pas atteint les objectifs escomptés au départ. Selon Amir Yasin, cofondateur et CTO de June (société US spécialisée dans le recrutement des professionnels seniors de l’IT), « Agile est devenu tout ce que le modèle Waterfall était pour les développeurs, et pire. C’est un loup déguisé en agneau ». C'est maintenant au tour de Ron Jeffries de donner son avis.


Lorsque les idées sont mal appliquées, elles créent souvent la confusion et entraînent plus de travail à faire en peu de temps. Cela augmente par conséquent la pression au sein de l'équipe. Cet état de chose n'est pas toujours bénéfique ni pour les développeurs ni pour l'entreprise. Car cela entraîne plus d'erreurs et les objectifs sont de moins en moins atteints. Cette situation fait que plusieurs développeurs démissionnent de leur poste et l'entreprise devient à coup sûr moins efficace avant que les méthodes agiles ne soient adoptées. Ron Jeffries dit qu’il partage la même pensée que Kent Beck qui dit qu'il « voudrait que le monde soit sûr pour les développeurs ». Il dit être toujours un développeur et qu’il est écœuré de voir que les méthodes du Manifeste Agile compliquent la tâche aux développeurs plutôt que de les aider. C’est aussi attristant de constater que l’entreprise n'obtient pas les résultats escomptés.

Ron Jeffries estime qu’il est temps de passer à autre chose. Il conseille aux développeurs d’abandonner les méthodes agiles. Selon lui, ce n'est pas les méthodes qui sont en cause, mais plutôt la manière dont elles sont appliquées. Les développeurs devraient adopter les principes de base du Manifeste Agile indépendamment d’un framework ou d’une méthode dans le développement d’application comme cela était pensé initialement par les signataires du Manifeste. Cela permet aux développeurs de s’épanouir dans leur travail. Le logiciel étant fonctionnel à tout moment, d’importants travaux d’extension peuvent être effectués dans un délai assez raisonnable. Au mieux, Ron Jeffries propose d'utiliser l'Extreme Programming qui tient compte de la gestion de projet dans la réalisation de l'application.

Source : Ron Jeffries

Et vous ?

Êtes-vous du même avis que Ron Jeffries ? Pourquoi ?
L'Extreme Programming ne va-t-il pas aussi connaître les mêmes problèmes dans sa mise en pratique ?

Voir aussi

Un développeur estime qu'Agile est un « loup déguisé en agneau », le Waterfall 2.0, qu'en pensez-vous ?
CollabNet : l'adoption des pratiques agiles augmente en entreprise mais très peu d'organisations auraient un haut niveau de compétence
La méthode agile SCRUM est-elle une mauvaise méthode de gestion de projet ? Oui répond un professionnel du secteur
Que faire pour minimiser l'impact des interruptions sur l'activité de développement de logiciels ? Appliquer les méthodes Agile ?

Une erreur dans cette actualité ? Signalez-nous-la !

Avatar de el_slapper
Expert éminent sénior https://www.developpez.com
Le 22/05/2018 à 14:08
Citation Envoyé par clorr Voir le message
(.../...) il n'y a pas vraiment de méthodo out-of-the-box qui puisse s'appliquer comme une recette magique.
ça.

Quand le donneur d'ordres n'a aucun contact avec la réalité, quand le recruteur ne connait que le coût des gens, quand le chef de projet est incapable de sortir de schémas de pensée préétablis, quand le développeur est quelconque, quand le testeur manque de flair, et que tout ce petit monde essaye de refaire google maps en mieux en 6 mois, comment dire..... Je ne sais pas quelle méthode ils vont choisir, mais je sais déjà qu'ils vont l'accuser de leur échec.

Les gens qui ont signé le manifeste agile étaient des pointures. Des gens à la frontière du progrès, à l'époque. Qui travaillaient dans d'excellentes conditions. Ils n'ont pas pu imaginer que dans de mauvaises mains, tout ceci puisse terminer abominablement mal. Leur méthode fonctionne, quand elle est appliquée correctement.

Mais depuis les années 1970, le vrai point de blocage est toujours le même : on choisit les gens n'importe comment, sur de mauvais critères, à tous les postes, et on espère naïvement que la méthode perlimpinpin va permettre à 11 chèvres de gagner la ligue des champions.
8  0 
Avatar de Bono_BX
Membre confirmé https://www.developpez.com
Le 22/05/2018 à 10:08
Il y a beaucoup de regrets dans ces explications, mais hélas, on ne peut que lui donner raison quand il dit "Lorsque les idées sont mal appliquées".
Trop de SSII et d'incompétents se sont emparés de l'Agilité et lui ont porté atteinte (petite digression totalement hors sujet : je prévois exactement le même futur aux micro-services ...).

Et je suis totalement d'accord avec la conclusion :

Il conseille aux développeurs d’abandonner les méthodes agiles. Selon lui, ce n'est pas les méthodes qui sont en cause, mais plutôt la manière dont elles sont appliquées. Les développeurs devraient adopter les principes de base du Manifeste Agile indépendamment d’un framework ou d’une méthode dans le développement d’application comme cela était pensé initialement par les signataires du Manifeste.
5  0 
Avatar de Kihmé Xs
Membre confirmé https://www.developpez.com
Le 22/05/2018 à 12:23
J'ai vu énormément de projets gérés, pilotés et managés avec une mentalité "à l'ancienne" sur laquelle on a ajouté des principes agiles.

Et ça c'est le bordel, ça n'améliore rien, on ajoute au contraire toujours plus de process et de complexité sur le développeur.

A l'inverse, j'ai vu des projets pensés agiles, où malgré la complexité technique et fonctionnelle du projet, on obtient un projet où tout va presque bien, et où le développeur peut travailler en toute sérénité.

Il faut juste savoir être critique et améliorer ce qui doit l'être.
5  0 
Avatar de Luckyluke34
Membre émérite https://www.developpez.com
Le 22/05/2018 à 17:19
Citation Envoyé par Bill Fassinou Voir le message
Ron Jeffries estime qu’il est temps de passer à autre chose. Il conseille aux développeurs d’abandonner les méthodes agiles.
Pas vraiment. Il recommande aux développeurs d'abandonner Agile, qu'il définit comme

"the many instances, approaches, and processes that use the word “agile” to describe themselves, but that do not necessarily adhere to the letter or spirit of Agile Software Development we wrote about in the Agile Manifesto. I will sometimes refer to “Faux Agile” for emphasis"

Citation Envoyé par Bill Fassinou Voir le message
il est écœuré de voir que les méthodes du Manifeste Agile compliquent la tâche aux développeurs plutôt que de les aider.
Là c'est carrément un gros contresens, ce n'est pas "les méthodes du manifeste agile" mais la façon dont elles sont interprétées et appliquées en entreprise, ce qui change tout.

"their organization is doing “Agile” wrong: they’re not doing what the Manifesto authors recommended, what Scrum recommends, what the many Agile Software Development experts recommend"

La tonalité de la news DVP ne me parait pas rendre justice à la précision du contenu du billet de Jeffries - même si à sa décharge, le titre volontairement sensationnaliste et provocateur n'aide pas. Pour moi, il appelle plus à un "protestantisme agile" qu'on pourrait résumer par :

Résistez à la pression de "l'Agile dévoyé" qu'on vous impose, en rejetant toute méthode étiquetée Agile mais en restant fidèle aux pratiques fondatrices de l'agile manifesto.
5  0 
Avatar de Terin
Membre habitué https://www.developpez.com
Le 24/05/2018 à 12:27
Cycle en V ou méthode Agile le fond du problème reste et resteras l'incompétence de la MOA (le client ou son représentant) qui n'est que rarement capable d'exprimer un besoin correctement, la faute à une horde de cadre, chef de projet, produit, qui sont autant éloigné du besoin (le problème) que de l'outil (le développeur).

La grosse différence c'est que la responsabilité du résultat produit est imputé au développeur dans la méthode agile (c'est pas écrit dans la méthode, c'est mon triste constat), la MOA et MOE se décharge de toute leur responsabilité sur le technique qui supporte toute la charge du projet. Un projet agile ça se passe comme ça :

Client : J'ai besoin d'une table
MOA : on a besoin d'une table
MOE : Fait une table
Développeur : j'ai fait une table
MOE : il a fait une table
MOA : voilà votre table
Client : mais la table passe pas ma porte ...
MOA : faut que la table passe la porte (voyons c'est évident)
MOE : La table doit passer la porte !
Développeur : Voilà, la table passe la porte
.
.
.

Un bonheur pour les SSII, un cauchemar pour les développeurs qui subissent tout (et encore j'ai réduit de beaucoup le nombre d'intermédiaire). Au moins l'avantage du cycle en V, c'est qu'on rédige un cahier des charges technique pour le dev (chose inexistante aujourd'hui) à partir d'un cahier des charges fonctionnels étonnamment rare.

Pour ma part, nous travaillons uniquement en cycle en V avec nos prestataire de service, la charge de travail est plus conséquente, mais les projets sont mieux faits et plus courts. Pour de l'interne, nous essayons de mettre en contact directement développeurs et les services en besoin, cela reste compliqué, on cherche pas des développeurs experts full-stack, mais des humains avec une certaine sociabilité capable de comprendre le métier, le besoin et d'y répondre, mais c'est très compliqué à trouver.
5  0 
Avatar de d_d_v
Membre éprouvé https://www.developpez.com
Le 06/06/2024 à 9:18
Agile ou pas, ce qu'il faut à un moment, ce sont des spécifications écrites quelque part. J'ai l'impression que la méthode agile est un prétexte pour na jamais écrire de documentation technique. Je ne comprend même pas comment on peut penser que ça peut fonctionner.
Comment vous pouvez savoir si tel comportement dans le logiciel est normal ou pas s'il n'est documenté nulle part. C'est encore pire quand le turnover est important: ceux qui détenaient la connaissance se sont barrés et les nouveaux arrivants se débrouillent comme ils peuvent.
6  1 
Avatar de pyros
Membre expérimenté https://www.developpez.com
Le 06/06/2024 à 17:12
J'aimerai connaitre, parmis la part des projets "Agile" ayant échoué, quels sont les projets vraiment Agile et quels sont les projets ou un caoch agile grassement payé s'est pointé en déroulant son template et en collant des réunions à tour de bras parce que c'est marqué dans le Scrum Guide...

On s'est mis à faire de l'agile car les méthodes de gestion projet classique type Waterfall ou cycle en V ne s'adaptaient pas aux projets portant sur des techno emergente ou des marché inconnue. Il y a beaucoup de projet où on ne sait juste pas ce que le logiciel est censé faire et où même le client n'es sais foutre rien, (quoi qu'il puisse en penser). C'est là qu'Agile a un intéret. Il permet de piloter un système cahotique par itération successive.

Pour un system connue, contrain et un marché stable comme l'aéronautique, le médical, etc... Agile a beaucoup moins d'intéret. Il faut arréter de vouloir trouver une formule magique qui marche partout.
5  0 
Avatar de OuftiBoy
Membre éclairé https://www.developpez.com
Le 14/08/2024 à 20:38
Bonjour à tous.

Nous voici donc avec une discution commencée en 2018 et qui "repart" en 2024. Intéressant... Je n'avais pas participé à l'époque, car la discussion ressemblait plus à une guerre de religion qu'a autre chose.

J'ai maintenant une certaine expérience, et des méthodes, j'en ai vu passer, du moins "théoriquement".

Sans penser avoir "la solution" à la difficulté de réussir un projet "logiciel", j'ai, au fil du temps, remarqué plusieurs choses. Je les cite en vrac.

- La "compétence" ou "formation" des "développeurs" a grandement diminué depuis qlq décénies. Je ne sais pas à quoi cela est dû exactement, c'est juste une constatation que j'ai faite. D'autres n'ont peut être pas ce ressentiment, et peut-être que cela dépend du domaine dans lequel on bosse.

- Faire appel à la sous-traitance a toujours été un fiasco. Un sous-traitant n'est pas là pour touver une "bonne solution" à un projet, mais à prendre tous les raccourcis possible pour livrer "au plus vite" quelque chose qui "ressemble" à une solution. Que cette solution puisse ou pas "évoluer" dans le temps long ne fait pas partie des préoccupations. C'est même le contraire, afin de se rendre "indispensable" au "client", s'assurant la/les mises à jour.

- De plus en plus (ça doit être l'époque qui veut ça), des mots magiques "sortent du lot" (pour l'instant c'est l'IA), et il faut utiliser ces nouvelles "religions" pour se sentir exister ou être "à la pointe du progrès".

- De plus en plus de couches se sont glissées entre le besoin et la réalisation de ce besoin. Au point de parfois même "inventer un besoin" pour justifier le rôle d'un "Poste".

- Pour monter en salaire, l'expérience n'est pas valorisée, et la seule solution et de soit changer de boîte, soit grimper dans la hiérarchie de l'entreprise. Et là, ça devient plus un jeu politique que technique, et les "camas" des "camas" auront toujours l'avantage, ce n'est plus une question de compétence.

- Très vite arrive le "principe de peters", à savoir que l'on arrête de monter lorsque l'on est arriver à un point ou l'on n'est plus compétent. Un bon développeur (pour gagner plus), tente de passer chef de projet, là ou il sera éventuellement médiocre. L'entreprise perd un "bon développeur" et gagne un "mauvais chef de projet". Il suffirait d'augmenter le salaire des "bons développeurs" pour éviter la chose, mais sauf dans une entreprise où le "logiciel" est au coeur du métier, "l'informaticien" ne sera jamais valorisé, c'est juste une "ressource" comme disent les RH, pensant qu'on remplace un "développeur" par un autre "développeur" comme on change une chaise par une autre.

- On complexifie inutilement les "porblèmes a solutionner", mais aussi "la manière dont on les solutionne".

Les méthodes permettent au "superviseur" du projet à avoir des graphiques et des "choses" a montrer à ses supérieurs. Un projet ne profite pas plus d'une méthode que d'une autre.

En fait, la seule chose qui compte pour qu'un projet réussisse, c'est la communication entre les membres de l'équipe, savoir dire "non", savoir expliquer pourquoi ce "non", privilégier le bons sens, et s'en tenir au principe KISS. Il faut également savoir garder les gens là où ils sont le plus utiles à l'entreprise, et donc ne pas privilégier la montée dans la hiérarchie pour la montée en salaire.

Avec le temps, j'en suis arriver à la conclusion qu'il ne faut pas de "méthode", ni de "documentation" (souvent générée automatiquement et pas à jour, un code source clair, limpide et simple vaut 1000x toutes les documentations), mais énormément d'échange et d'intéraction, pour comprendre les problèmes (qui n'en sont peut-être pas). Une fois un problème bien cerné, implémenter une solution limpide et le plus simplement possible.

Perso, je garde à jour un simple document, évolutif, dans lequel se trouve (1) ce que l'on fait, (2) pourquoi on le fait, et (3) comment on l'a fait. Le comment on l'a fait est mixte de "problème/solution" (expliquer le problème, et comment on le résout).

BàV et Peace & Love.
5  0 
Avatar de KnifeOnlyI
Membre régulier https://www.developpez.com
Le 22/05/2018 à 9:30
Personnellement je déteste les arguments d'autorité du genre

Son avis est d'autant plus important parce qu'il est l'un des 17 signataires du Manifeste pour le développement Agile de logiciels.
Sa me donne envie de faire l'exacte contraire de ce qu'on me dit.

Si une équipe projet fonctionne bien (quelque soit la méthode choisie) pourquoi changer ?
4  1 
Avatar de clorr
Membre averti https://www.developpez.com
Le 22/05/2018 à 12:24
Quand on voit que même les crédits bancaires sont devenus "agiles", on comprend que la méthode est depuis longtemps dévoyée par son succès marketing. Beaucoup de gens dans les hiérarchies parlent d'agilité sans avoir compris que dans l'agile, c'est la base qui doit rester maitresse de l'organisation.

L'autre chose, c'est que Scrum ou Kanban marchent pas trop mal sur du court terme, mais sur des gros projets, il n'y a pas vraiment de méthodo out-of-the-box qui puisse s'appliquer comme une recette magique.
3  0