AFUP AFUP Day 2021 Baromètre Planète PHP

La parole est aux speakers : Estelle Le Cam

Jusqu’à l’AFUP Day 2021, retrouvez nos interviews de speakers pour mieux comprendre leur parcours et le sujet qu’ils ou elles aborderont lors de leur conférence !

La conférence

Comment dompter un Legacy ? Parlons smoke testing, golden master et même migration progressive.

Une fois notre projet bien lancé on se rend souvent compte qu'on est allé un peu vite ou que nos features ont grossi et nos tests, diminué. Comment maintenant vivre avec son historique et retrouver la maîtrise de son application pour aller sereinement ajouter de nouvelles feature ? La question a été posée chez SAFTI et en amont de notre migration progressive nous avons pu mettre en place plusieurs pratiques de test pour redompter le legacy qui fait notre force. Avec ce retour d'expérience vous trouverez des pistes sur comment vous réconcilier avec votre legacy.

Toulouse
11/06/2021
09:20-10:00

À partir de quel moment peut-on juger qu’il n’est plus nécessaire d’investir du temps sur la maintenance d’un code legacy ? À quel moment as-tu jugé que la migration devenait nécessaire ?

Généralement le code legacy c’est le code du cœur-métier de l’entreprise, l’application qui fait rentrer de l’argent, mais avec zéro (ou presque) tests. Impossible donc de juger qu’il n’est plus nécessaire d’y investir du temps.

Par contre, avec la croissance de l’entreprise et le besoin de nouvelles fonctionnalités, quand ce legacy devient un frein car il agit en mode boite noire, ou que cette codebase dont plus personne ne maîtrise les effets de bord et dont on passe plus de temps à corriger pour chaque nouvelle fonctionnalité, dans ces cas se pose la question de la migration et de sa nécessité.

Que conseillerais-tu pour la mise en place d’une stratégie de tests sur un code legacy ?

Plusieurs approches sont possibles en fonction de la taille, de la cible, du temps …

Dans un premier temps on a besoin déterminer les fonctionnalités clés de l’application, celle qui rapporte le plus que ce soit en terme de satisfaction, de fonctionnalité, d’argent ou tout ce qui est le plus important pour votre métier. Ce sont ces fonctionnalités-clés qu’il faut absolument sauvegarder et parvenir à tester pour éviter toutes régressions qui seraient trop punitives.

Dans tous les cas c’est très difficile (voir même non-souhaitable au vu du temps à investir) de tester à 100% son legacy : on peut plutôt s’orienter sur des stratégies de test en boite noire, en s’outillant également de log, via un golden master que l’on va voir ensemble.

Est-ce que la migration d’un projet legacy est un sujet qui te motive particulièrement ? Et si oui, pour quelle(s) raison(s) ?

J’adore les migrations, c’est toujours une casse-tête pour retrouver la maîtrise de son code. C’est un enjeu majeur pour les entreprises.

Je trouve que l’accompagnement via la montée en compétence sur le cœur du métier, un peu d’archéologie et beaucoup d’imagination pour aller vers une évolution technologique cohérente, constituent vraiment sujet palpitant.

On découvre toujours des pépites dans le code, tel qu’un framework maison que l’on pousse vers son évolution naturelle (qui peut-être un framework open source et soutenu par une communauté par exemple). Faire qu’une équipe puisse se réconcilier avec son legacy et continuer d’apprendre et d’avancer vers de nouveaux outils c’est également très important pour moi.

En poursuivant votre navigation sur ce site, vous acceptez l’utilisation des cookies pour améliorer votre navigation. plus d'infos

1. Qu’est-ce qu’un cookie?

Un Cookie est un petit fichier texte enregistré sur votre terminal (ordinateur, tablette, smartphone, etc.), à l’occasion de la consultation d’un service en ligne grâce à votre logiciel de navigation. Il permet à son émetteur d’identifier le terminal dans lequel il est enregistré, pendant la durée de validité ou d’enregistrement du Cookie. Lors de la consultation de notre site Internet, des informations relatives à la navigation de votre terminal sont susceptibles d'être enregistrées dans ces fichiers dits "Cookies". Ces derniers sont installés sur votre terminal, sous réserve des choix que vous auriez exprimés concernant les Cookies et que vous pouvez modifier à tout moment.

2. A quoi servent les cookies émis sur notre site ?

Seul l’émetteur d’un cookie est susceptible de lire ou de modifier les informations qui y sont contenues.
Les cookies utilisés sur notre site permettent :

3. Vos choix concernant les cookies

Vous disposez de différents moyens pour gérer les cookies. Tout paramétrage que vous pouvez entreprendre sera susceptible de modifier votre navigation sur notre site et sur Internet en général et vos conditions d'accès à certains services de notre site nécessitant l'utilisation de cookies. Vous pouvez à tout moment exprimer et modifier vos souhaits en matière de cookies, par les moyens décrits ci-dessous. L'accord sur les cookies L'enregistrement d'un cookie dans un terminal est essentiellement subordonné à la volonté de l'utilisateur du terminal, que celui-ci peut exprimer et modifier à tout moment et gratuitement à travers les choix qui lui sont offerts par son logiciel de navigation. Si vous avez accepté dans votre logiciel de navigation l'enregistrement de cookies dans votre terminal, les cookies intégrés dans les pages et contenus que vous avez consultés pourront être stockés temporairement dans un espace dédié de votre terminal. Ils y seront lisibles uniquement par leur émetteur.

Le refus des cookies Si vous refusez l'enregistrement de cookies dans votre terminal, ou si vous supprimez ceux qui y sont enregistrés, vous ne pourrez plus bénéficier d'un certain nombre de fonctionnalités qui sont néanmoins nécessaires pour naviguer dans certains espaces de notre site. Tel serait le cas si vous tentiez d'accéder à votre compte ou à votre abonnement qui nécessite de vous identifier. Tel serait également le cas lorsque nous, ou nos prestataires, ne pourrions pas reconnaître, à des fins de compatibilité technique, le type de navigateur utilisé par votre terminal, ses paramètres de langue et d'affichage ou le pays depuis lequel votre terminal semble connecté à Internet. Le cas échéant, nous déclinons toute responsabilité pour les conséquences liées au fonctionnement dégradé de nos services résultant de l'impossibilité pour nous d'enregistrer ou de consulter les cookies nécessaires à leur fonctionnement et que vous auriez refusés ou supprimés. Les choix offerts par votre logiciel de navigation Vous pouvez configurer votre logiciel de navigation de manière à ce que des cookies soient enregistrés dans votre terminal ou, au contraire, qu'ils soient rejetés, soit systématiquement, soit selon leur émetteur. Vous pouvez également configurer votre logiciel de navigation de manière à ce que l'acceptation ou le refus des cookies vous soient proposés ponctuellement, avant qu'un cookie soit susceptible d'être enregistré dans votre terminal. Pour la gestion des cookies et de vos choix, la configuration de chaque navigateur est différente. Elle est décrite dans le menu d'aide de votre navigateur, qui vous permettra de savoir de quelle manière modifier vos souhaits en matière de cookies. Selon votre navigateur, consultez le lien ci-dessous pour configurer votre navigateur et refuser les cookies :