AFUP AFUP Day 2019 Baromètre Planète PHP

La parole est aux speakers : Samuel Roze

Jusqu’au Forum PHP 2018, retrouvez nos interviews de speakers pour mieux comprendre leur parcours et le sujet qu’ils aborderont lors de leur conférence !

La conférence

Comment j’ai commencé à aimer ce qu’ils appellent « design pattern »

Il arrive parfois que nous, développeurs, pensions qu’il n’est pas nécessaire de connaître ce qu’ils appellent les « design patterns » ou « patrons de conception ». Nous pensons parfois que nous n’avons pas besoin de cette théorie. Après des années d’expériences avec la faible maintenabilité de mon propre code et de celui de mes clients, j’ai exploré de nombreuses façons de découpler nos applications afin de créer des applications « enterprise ready » qui peuvent vivre pendant de nombreuses années. Via des exemples concrets, je vais vous présenter quelques design patterns qui peuvent vous aider à travailler sur une codebase propre, structurée et bien découplée.

Grace Hopper
25/10/2018
09:30-10:10

Le speaker

Samuel Roze
Samuel Roze
Passionné par la création et l’innovation, Samuel travailles dans le startup studio Kamet à Londres pour aider chaque startup a donner le meilleur sur le plan technique. Core-team member de Symfony et ApiPlatform, createur de ContinuousPipe et Tolerance il est particulièrement impliqué dans l’open-source.

Quels sont tes 3 design pattern préférés ?

Je dirais que cela dépend du contexte. Je n’ai pas de design pattern préféré, car ce sont juste des outils que j’utilise en fonction du cas d’utilisation plutôt qu’une liste de designs préférés. Ceci dit, celui que j’utilise le plus c’est le « Décorateur » que je trouve extrêmement puissant et très utile pour ajouter des fonctionnalités à un existant très simple. Typiquement sur une fonctionnalité de « retry » ou de logging: on pourrait l’ajouter à l’aide d’une boucle dans le code existant ou une ligne de code à de l’existant. C’est l’approche la plus simple mais elle n’est clairement pas réutilisable. À la place, on crée un décorateur qui permettrait d’avoir une fonctionnalité « plug-and-play », bien découplée et réutilisable.

Dans le titre de ta conférence tu indiques avoir commencé à aimer les design pattern. Est-ce que cela veut dire que tu ne les aimais pas avant ?

C’est plus ou moins vrai. Le contexte étant que j’ai commencé à développer avant d’aller dans une quelconque école d’informatique. Par conséquent, développer une application (web) n’était de mon point de vue pas très sorcier : pourquoi devrais-je apprendre tous ces aspects théoriques alors que franchement, mes applications marchent très bien sans? C’est un peu comme la philosophie à l’école: j’en voyais pas les applications pratiques.

Qu’est ce qui t’a fait basculer dans la recherche de pratiques « entreprises ready » ? Est-ce qu’il y a eu un déclencheur particulier ?

Je pense qu’il y a au moins 3 types de projets différents: les « expérimentations », que l’on « hack » de manière individuelle et restreinte pour tester une nouvelle technologie, les projets personnels longs termes qui visent à développer un nouveau “produit” et les longs termes qui impliquent un travail en équipe dans l’idée de concevoir un nouveau “concept/produit”, typiquement en entreprise.

Dans le premier cas, ça n’est pas un souci qu’il y ait du copier/coller un peu dans tous les sens et que notre application soit un sac de nœuds, on va probablement l’abandonner dans un coin. Mais si l’on décide de passer à l’étape suivante, dans le deuxième cas, c’est déjà plus contraignant : dans 3 mois, je ne me rappelle pas forcément où j’ai copié/collé ce bout de code pour le logging. Cette logique qui change le niveau d’erreur en fonction du contexte, ou je ne sais quoi d’autre… C’est là que l’on commence à avoir besoin de structure et donc d’utiliser des « patrons » de développement.

Le dernier cas est encore plus compliqué: pour faire en sorte qu’une équipe de développement puisse créer quelque chose sur le long terme il faut de la structure mais aussi une certaine modularité. Il faut pouvoir avoir des points d’extensions bien clairs à différents niveaux de l’application pour que tout le monde n’ait pas besoin d’avoir toute la base de code en tête pour être efficace dans son travail avec un très bon niveau de confiance. Et ces points d’extensions, c’est aussi les « patrons » de développement qui nous donneront de très bons indices!

Gandhi disait « Il ne faut pas souiller son patrimoine en multipliant les erreurs passées », c’est pour ça que je veux parler de ces « vieilles choses » pour que l’on puisse ne pas répéter ces vieilles erreurs de développement, et créer des applications maintenables, avec le moins de bugs possible et valables sur le long terme.

La conférence

Comment j’ai commencé à aimer ce qu’ils appellent « design pattern »

Il arrive parfois que nous, développeurs, pensions qu’il n’est pas nécessaire de connaître ce qu’ils appellent les « design patterns » ou « patrons de conception ». Nous pensons parfois que nous n’avons pas besoin de cette théorie. Après des années d’expériences avec la faible maintenabilité de mon propre code et de celui de mes clients, j’ai exploré de nombreuses façons de découpler nos applications afin de créer des applications « enterprise ready » qui peuvent vivre pendant de nombreuses années. Via des exemples concrets, je vais vous présenter quelques design patterns qui peuvent vous aider à travailler sur une codebase propre, structurée et bien découplée.

Grace Hopper
25/10/2018
09:30-10:10

Le speaker

Samuel Roze
Samuel Roze
Passionné par la création et l’innovation, Samuel travailles dans le startup studio Kamet à Londres pour aider chaque startup a donner le meilleur sur le plan technique. Core-team member de Symfony et ApiPlatform, createur de ContinuousPipe et Tolerance il est particulièrement impliqué dans l’open-source.

Autres interviews

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 :