Ron Jeffries et Martin Fowler). La lecture de ces articles (que je vous conseille vivement) et mes dernières expériences de coaching m’ont donné envie de partager mes réflexions via le blog.
A cet âge, on est convaincu d'avoir compris pourquoi le monde du développement logiciel tourne à l'envers et trouvé ce qu'il faut faire pour tout changer.
L'énergie est là, la rage au ventre de changer la donne. Cependant la vie s'apprête à nous donner quelques claques nous rappelant à l'ordre pour nous montrer du doigt ce qui était devant nous depuis le début : "Tout n'est pas si simple...Une seule méthode ne peut pas changer le monde".
Nous faisons aujourd’hui la promotion de méthodes telles Scrum ou autres programmations extrêmes en y associant de beaux espoirs de réussites projet. Bien heureusement, nos espoirs se concrétisent souvent. Ces méthodes ne sont cependant que des cadres de travail, des propositions. Les considérer pour plus qu'elles ne sont peut s'avérer dangereux.
Scrum propose plusieurs outils pour planifier, estimer, prioriser. Les grandes lignes sont simples à comprendre, quiconque voudrait s'improviser "Scrum Master" pourrait le faire en quelques jours de lecture bien sentis. Pourtant il est malheureusement de plus en plus fréquent de rencontrer autour de nous des projets Scrum en difficulté. Le backlog n’est pas correctement priorisé, le product owner n’a pas été correctement identifié, les rétrospectives sont baclées. Est-ce à dire que Scrum n'est pas une bonne méthode ? Je ne le pense pas. Bien entendu, on peut penser que tous ces problèmes sont dus à des carences de Scrum. Ou encore, que cela ne serait pas arrivé si l’on démarrait les projets sur de "bonnes" bases agiles. Mais autant se le dire, ces occasions sont rares et difficiles. Le contexte culturel d'une entreprise n'est pas à prendre à la légère. La mise en œuvre d'une méthode agile "by the book" est un projet d’amélioration drastique (kaikaku en Lean) très risqué. Insuffler progressivement les pratiques agiles me semble l'approche la moins douloureuse et promise à plus de succès (kaizen en Lean).
Scrum possède cet avantage ironique de n'être qu'un squelette méthodologique presque vide de pratiques : c’est une discipline. Commencer par un backlog et la mise en œuvre d'un processus de développement itératif est un bon début. L'équipe fera probablement "comme avant" à l'intérieur de chaque itération, mais aura un retour extrêmement rapide sur la pertinence de ses pratiques. Là même où en mode cascade il fallait attendre plusieurs mois pour difficilement prendre le temps du regard dans le rétroviseur.
Scrum est en ce sens un catalyseur. Il nous donne les moyens de réaliser nos erreurs rapidement (aka « fail fast ») et d'amorcer en conséquence une réelle démarche d'amélioration continue. Il ne faudra pour cela ne pas baisser les bras trop tôt et se faire aider d’un coach expérimenté. Le coach aidera l'équipe à prendre les décisions les plus adéquates quant à l'adoption de nouvelles pratiques agiles. Il aidera l'équipe, en fonction de son niveau de maturité, à adapter ces pratiques au contexte de l'entreprise. Pourquoi les adapter ? Simplement parce que chaque contexte culturel d'entreprise induit un existant qui ne peut être balayé par un "magical Scrum" ou un "astonishing XP". Le TPS ne s'est pas créé en une fois ! Toyota l’a continuellement remis en cause et adapté pour devenir ce qu’il est aujourd’hui.
Si un projet rencontre des problèmes avec Scrum, ce n'est probablement pas « la faute à Scrum ». L'équipe est simplement en train de toucher quelques-unes des limites de cette méthode dans son contexte. Fort de ce constat, on pourra choisir d’être de ceux qui montrent du doigt la méthode comme on l’a fait avec RUP il y a maintenant 10 ans. On pourra aussi choisir d’affronter nos difficultés pour saisir humblement l’opportunité de s’améliorer qui s’offre à nous.