Le bilan de notre migration

Stratégie d'une migration applicative

Posted by Tristan Bessoussa on July 18, 2016

Lorsque j’ai rejoins Y-Proximité, j’ai ressenti après avoir collecté de nombreux signaux décrits dans cette suite de billets, le besoin de lancer un processus de migration de notre application “CMS” orientée réseau, multi-tenant (1BDD = X clients) & marque blanche. Elle héberge aujourd’hui environ 2,000 sites/landing pages.

On peut lire de à certains endroits qu’une refonte c’est le mal. J’ai décidé de raconter comment s’est passé notre migration (moins abrasive sur le plan politique qu’une refonte) qui s’est déroulée sur 2 ans. Voici mon cahier de route de la migration vers “Yprox v2” qui couvre plusieurs sujets.

Les gains de cette migration

12700 commits

Une “meilleure” structure, introduction de microservices.

Cliquez pour une version dépliée de l’architecture

Architecture yprox v2 version simplifiée

Je tiens à préciser qu’il s’agit d’une migration, le code/logique n’a pas été réécrit “from scratch” puisque le coeur à bénéficié d’une base solide.

Cependant, beaucoup de modules ont bénéficié de gros refactorings et d’une restructuration profonde. Au final, voilà le tableau comparatif avant/après du nombre de lignes de code (acronyme LOC), tel que rapporté par l’utilitaire cloc.

Language V1 V2
PHP 138,000 75,000
JS 312,000 20,000
HTML+TWIG 182,000 25,000


Cela s’explique par:

  • Passage des librairies JS avec NPM, et publication avec Gulp
  • Refactorisation des modules métier en PHP
  • Suppression de code mort
  • Suppression de fonctionnalités très coûteuses à maintenir par rapport à leurs utilisations (ex: module e-commerce “maison”)

Certaines tâches métiers ont étés déportées dans d’autres repository. Nous avons pour certaines tâches un système de “queue” et de “worker” (en Silex qui tourne avec du Docker) chez Iron.io qui viennent performer certaines tâches en dehors de notre infrastructure.

architecture globale v2

Tests fonctionnels et unitaires

Nous avons augmenté le taux de couverture des tests unitaires, de classe (60 specs, 368 exemples PHPSpec) et fonctionnels (449 scénarios Behat).

Entre nous, sortir des taux de couverture, c’est bidon si les tests sont mals conçus, mais ça permet d’avoir une base afin de se “rassurer”. Nous sommes quand même loin de ce que peut faire Sylius côté tests. Afin de nous épauler, Travis a été boosté pour obtenir 5 build parallèles.

Un design plus “dans l’ère du temps”

Cliquez pour pouvoir agrandir Screenshot yproximite v2 Screenshot yproximite v2 - Listing

Certes, c’est un template d’admin qui a été acheté sur un site de template, mais il fait le travail. Notre graphiste & équipe d’intégration, très occupés (eux aussi) n’ont presque pas été sollicités, parfois à regret.

Migration = période de jachère ? Pas forcémment.

Bien qu’ayant freiné certains besoins des utilisateurs internes, au cours de cette migration plus de 20 nouvelles fonctionnalités ont vu le jour:

  • De nouveaux modules métiers
  • Des réécritures de modules en Vue.js avec des nouvelles fonctionnalités.
  • Une API Rest consommée par des partenaires
  • Le support d’HTTP2 pour le backoffice

Attention, le fait de continuer à faire évoluer le produit pendant une migration (+bugfixs), à un coût conséquent sur le temps de migration. Il aura fallu tenir un rythme parfois soutenu pendant 2 ans (début 05/2014) avec environ 3 à 4 (selon périodes) personnes à temps plein.

La résistance des utilisateurs: attention à la contamination.

Nous avons “perdu” l’adhésion de certains utilisateurs internes en 2 ans qui se demandent “pourquoi cette migration ?”, “est-elle vraiment nécessaire d’un point de vue de l’utilisateur ?”. La résistance au changement est un sujet qui serait à traiter à part entière et qui ne le sera pas ici ;-). Il faut veiller que ces critiques/craintes audibles ne viennent pas se répandre votre équipe de développement sans quoi cette dernière doutera aussi de la réelle utilité de leur travail. Trouvez des early-adopters qui ne verront pas ce changement comme “imposé” et “inutile”.

Bien que des workshop fûrent organisés, un travail d’accompagnement et de pédagogie aurait du être entrepris avec une plus grande ferveur avec nos utilisateurs internes afin d’être transparent sur l’avancée de la migration (difficile à estimer du fait du maintien de l’existant et d’ajout des nouvelles fonctionnalités).

Un rôle de Product Owner nous a fait défaut pour collecter les retours utilisateurs, qui parfois, se sont sentis un peu ignorés face la taille du backlog JIRA (>320 Tickets, syndrôme du “de toute façon, il ne va pas être traité”) et les axes d’améliorations de l’outil que vous êtes en train de faire évoluer.

Conclusion

Ne vous engagez dans ce genre de migration lourde (130,000 lignes de code PHP) que lorsque vous avez un soutien de l’opérationnel et de l’équipe en place. Sinon vous allez vous heurter à des murs qui risquent d’être fatals pour mener à bien un travail d’aussi longue haleine.

NB: Il s’agit d’un bilan anticipé rendu possible grace à cette migration continue. A l’heure où j’écris ces lignes, nous sommes en cours de validation dans un environnement final où tout a été migré (front et back).

NB2: Je ne parle pas ici, par choix, de tout ce qui a été introduit de manière annexe (industrialisation des développements, métriques métiers).