[:fr]La parole est aux speakers : Stéphane Hulard[:]

[:fr]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

Symfony/Messenger un composant à votre service !

Avec la sortie de Symfony 4.1 le 30 mai 2018, un nouveau composant officiel fait son entrée sur le marché : Messenger. Il s'agit d'une abstraction autour des files d'attente de message. Ce nouveau composant ouvre la porte à une nouvelle façon de travailler car les traitements asynchrones et la consommation des messages sont maintenant supportés nativement par Symfony.

Qu'est-ce que ça change ? Pourquoi un nouveau composant officiel ? Comment l'intégrer dans un projet ? Quels sont les connecteurs supportés ? Quels bénéfices dans la structure du code ?

Nous avons choisi de faire confiance à ce jeune composant et je vous invite à suivre nos pas à travers les exemples réels de notre implémentation.

Katherine Johnson
26/10/2018
09:30-10:10

Comment le composant symfony/messenger se situe-t-il par rapport à des initiatives comme queue-interop ?

C’est justement un des sujets que je vais aborder pendant la conférence. Le nouveau composant est sorti en compagnie d’un d’adapteur pour facilement s’interfacer avec les initiatives existantes. Pour être plus précis, je m’appuie sur le projet « php-enqueue” pour avoir accès à différents drivers (Redis, Kafka, SQS, …). Ce projet est une implémentation de « queue-interop ».

Pour autant ce n’est pas du tout obligatoire, Messenger est une brique donnant accès à la logique de bus de message. Libre à chacun ensuite d’utiliser les meilleurs outils pour les consommer !

(suite…)

[:fr]La parole est aux speakers : Vladyslav Riabchenko[:]

[:fr]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

SOLID : Les principes à l’origine du succès de Symfony et de vos applications

SOLID est un acronyme représentant cinq principes de bases de la programmation orientée objet permettant le développement de logiciels fiables, évolutifs et robustes. Le framework Symfony est un excellent support pour illustrer chacun de ces principes. Nous verrons ainsi que SOLID est à l’origine de sa flexibilité, sa fiabilité mais aussi de sa maintenabilité et son évolutivité. Nous verrons également comment appliquer ces principes pour améliorer son code métier et perfectionner l’architecture de son application.

Katherine Johnson
25/10/2018
15:15-15:55

Les principes SOLID sont-ils utilisables en entreprise ou est-ce une simple théorie ?

Lorsqu’on utilise le langage orienté objet tel que PHP on essaie de rester toujours en conformité avec SOLID. C’est d’autant plus visible quand il s’agit d’une bibliothèque réutilisable, d’un framework ou d’une logique métiers complexe.

Les principes SOLID aussi bien que les design patterns (e.g. ceux de GoF) sont issus de la pratique. Ils ont été extraits de l’expérience de création de milliers d’applications pour résumer les règles générales de bonne architecture. Dans le quotidien d’un développeur, SOLID favorise la création de modules réutilisables, flexibles, évolutifs et compréhensibles.

(suite…)

[:fr]La parole est aux speakers : Samuel Roze[:]

[:fr]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

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.

(suite…)

[:fr]La parole est aux speakers : Arnaud Langlade[:]

[:fr]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

Quelle différence y a-t-il entre le bon et le mauvais repository ?

Qu’est ce qu’un repository? Le pattern repository est l’un des pattern les plus utilisés dans nos applications. Bien que simple et pratique il est trop fréquemment mal employé : nos repositories sont plus souvent des entrepôts de requêtes SQL que des “vrais” repositories. Durant ce talk, nous verrons comment désigner un repository et gérer nos requêtes SQL.

Grace Hopper
26/10/2018
12:10-12:30

Tu nous parleras de repository : avant toute chose, pourrais-tu nous définir ce qu’est un repository ?

Un repository se comporte comme une collection d’objets : on peut lui ajouter, récupérer et parfois supprimer des objets. Il ne fonctionne qu’avec des objets du même type car on ne mélange pas des galinettes avec des renards, ça ne fait pas bon ménage ! Il a l’avantage de proposer aux développeurs une couche d’abstraction qui permet de ne plus se soucier de la persistance. En effet, il peut être implémenté de plusieurs façons possibles, il pourra très bien persister vos objets dans un fichier texte ou dans une base de données par exemple.

(suite…)

[:fr]La parole est aux speakers : David Buchmann[:]

[:fr]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

Bash pour les développeurs et développeuses PHP

Des scripts de ligne de commande sont souvent utilisés pour automatiser des tâches, installations et opérations de déploiement. Étant des développeurs PHP, nous sommes habitués à une syntaxe surprenante et des concepts inconsistants, mais bash apporte ces problèmes à un tout nouveau niveau. Bash peut avoir l'air simple, mais le language est bizarre et plein des pièges. Je vais expliquer les concepts de base et constructions syntaxiques de bash, ainsi que vous avertir des erreurs fréquentes. Si je vais peut être vous faire peur avec bash, je vais aussi vous montrer comment utiliser PHP pour écrire des scripts pour la ligne de commande.

Katherine Johnson
25/10/2018
12:10-12:30

PHP étant très bon pour des petits scripts, quand doit-on plutôt utiliser bash selon toi?

L’inspiration pour cette conférence vient du travail avec mon équipe. On utilise bash principalement dans des scripts qui tournent sur les systèmes d’intégration continue. Bash est un outil présent sur tous les systèmes Linux et s’offre donc pour ce type d’opérations.

Bash permet très facilement de faire des opérations comme lancer des lignes de commande, copier des fichiers, etc. Mais bash a une syntaxe très … disons « particulière ». Lorsque j’ai commencé à regarder de plus près ce qu’on fait, j’ai trouvé plein des petits choses bizarres.

Dans ma conférence, je ne veux pas convaincre les gens d’utiliser bash pour leurs systèmes, mais démontrer les possibilités et expliquer les particularités. Quand on a de la logique non-trivial dans un script, je pense qu’on fait mieux de l’écrire dans un propre langage comme PHP.

(suite…)

[:fr]La parole est aux speakers : Matthias Noback[:]

[:fr]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

Beyond design patterns and principles - writing good OO code

Of course, you should read all you can about SOLID, Design patterns, Patterns of Enterprise Application Architecture, etc. Once you have a basic understanding of these topics you still have to write that code though, and write it well too! What is good code? Are there some guidelines, or rules of thumb, which you can follow while making your everyday coding decisions?

In this talk I’ll cover many of these coding guidelines, which aren’t usually covered by patterns or principles books. They should help you write better code and give you a richer vocabulary for reviewing other people’s code. Some of the subjects that we’ll discuss are: state, mutability, CQS, one-method objects, domain-first, API-driven, functional programming influences, object boundaries, (de)serialization, and many more!

Katherine Johnson
26/10/2018
14:30-15:10

You are a prolific author with 3 books on your belt, why do you write these books? Do you have a new book in preparation right now?

I like to write. In particular when I’m coding a lot, my « bucket of ideas » is overflowing, and I need to externalize it to keep a clear mind. There’s often no need to search for topics to write about, because my work as a developer and trainer already provides me with many relevant topics. Quite often a blog post starts off with someone asking a question during a training session. If someone has a question about something, I assume they are not alone; by explaining the answer in more detail on my blog, I like to believe that it answers this question for many people. Sometimes an article gets “triggered” by something I read on Twitter. A programming joke, or a piece of advice. Often this starts a little fire in me, and I want to explain in a post how « someone is wrong on the Internet ».

(suite…)

[:fr]La parole est aux speakers : Anne-Laure de Boissieu et Eric Daspet[:]

[:fr]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

Mentorat & parcours de reconversion : comment faciliter l’apprentissage ?

Il y a plus d’un an, j’exerçais un autre métier. Après beaucoup de motivation, d'apprentissage personnel et quelques mois de formation dans une école spécialisée dans reconversion professionnelle, je fais aujourd'hui du développement web.. Ma particularité ? J’ai eu la chance d’être “accompagnée” par un mentor, dès le début de mes démarches. J’étais la seule dans ma promo.

Aujourd’hui, nous venons tous les deux vous raconter cette expérience, vous faire changer d’avis sur ces écoles de reconversion, vous donner l’envie de découvrir cette facette qui diffère de la formation initiale que la plupart d’entre vous connaissent, et vous inciter à aider vous-même d’autres futurs développeurs et développeuses.

  • Est-ce facile de trouver son mentor ou son mentoré ? Comment s’y prendre ? Par quels réseaux passer ?
  • Ce qu’on gagne quand on est mentoré : confiance, soutien, aide à l’apprentissage, réseau, conseils ...
  • Comment accompagner un reconverti quand on est mentor ?
  • Qu’en retire-t-on, à devenir mentor ?
  • Quelles sont les difficultés ? Comment ça se passe ?
Katherine Johnson
25/10/2018
17:10-17:50

Anne-Laure, qu’est-ce qui t’a fait passer de la gestion de projet au développement ?

Lorsque j’étais chef de projet ou chargée de SEO, j’appréciais beaucoup travailler au contact des développeurs et chercher avec eux des solutions à apporter aux utilisateurs. Et je rêvais de savoir développer moi-même un programme qui me permettrait de répondre à mes besoins du quotidien.
À vrai dire, même si je pensais me reconvertir depuis longtemps, je n’osais pas me lancer car j’imaginais que ce n’était pas un métier à ma portée, étant donné que je ne venais pas d’une filière scientifique. Et puis un jour, je me suis jetée à l’eau : l’envie de changement était trop forte.

(suite…)

[:fr]La parole est aux speakers : Timothée Barray[:]

[:fr]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

La cuillère n'existe pas

Aujourd'hui la majorité des développeurs est d'accord sur 2 points :

  • Tester c'est important !
  • On n'a pas le temps de tester !

L'illusion de la 2e affirmation permet encore trop souvent de produire du code non couvert par des tests.

Pourtant le test de manière générale est un super concept qui va bien au delà de la simple "assurance" du travail effectué. Il est donc temps de se rendre à l'évidence, la cuillère n'existe pas ! (On commencera donc par là).

Et maintenant le mouvement "software craftsmanship" avec des patterns comme CQRS, Event Sourcing et de manière générale le DDD rend le travail de test encore plus simple. (C'est le 2e effet kiss cool trop souvent oublié, on enchainera dessus). Exemples et méthodologie au menu !

On se rendra alors compte au fil de la présentation qu'en fait un test rapporte de l'argent et que le problème de temps ne le sera plus une fois que vous l'aurez expliqué à vos managers !

Grace Hopper
26/10/2018
10:15-10:55

Ta présentation portera plutôt sur les raisons de faire un test. Quels sont les outils que tu utilises pour tester ?

La communication c’est l’outil numéro un 😉 Et si cette phrase vous interpelle et que vous pensez que docker ça ne marchera jamais n’hésitez pas à venir faire un tour lors de ma présentation !

Mais pour répondre à la question, l’outil qui a changé un peu la donne à mon avis, c’est Behat. Le courant BDD est vraiment une approche qui m’a conquis il y a pas mal d’années maintenant. Et pourtant son réel potentiel est encore trop peu utilisé à mon sens. En tout cas ce n’est pas loin d’être la première dépendance que j’installe sur un nouveau projet.

À côté, j’utilise beaucoup atoum pour des tests unitaires, que j’ai toujours préféré à phpunit. Même si aujourd’hui il faut avouer que le fossé entre les 2 est clairement réduit. Et sur certains projets plus récents, c’est maintenant PHPSpec qui m’a convaincu ! Vraiment un super outil qui complète parfaitement Behat pour le coup.

Il faut se dire que dans le monde PHP on a beaucoup de chance car les outils autour des tests sont de très bonne facture et c’est loin d’être le cas dans tous les langages. Du coup peu importe l’outil, il y a le choix, il faut surtout se concentrer sur la démarche du test et c’est clairement ce point que je voulais aborder dans ma présentation.

(suite…)

[:fr]La parole est aux speakers : Pascal Martin[:]

[:fr]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

Docker en prod ? Oui, avec Kubernetes !

Kubernetes. À en croire certains articles, c’est une solution miracle. Développeurs, vous avez peut-être entendu ce mot ? C’est l’outil qui vous permettra de déployer du Docker en production ! Parce qu’autant utiliser Docker en dev c’est facile, autant en prod…

Mais qu’est-ce que Kubernetes ? Quelles possibilités si intéressantes nous fournit cet orchestrateur de conteneurs ? Pods, nodes, deployments, services, ou auto-scaling et health checks : autant de primitives et de fonctionnalités que vous allez découvrir et adorer, y compris en tant que développeurs !

Après avoir présenté ces bases, je vous proposerai un retour d’expérience sur la migration vers Kubernetes que nous sommes en train d’effectuer pour 6play.fr. Comment développeurs et sysadmins se répartissent-ils les tâches ? Avons-nous dû adapter nos applications PHP ? Quelles difficultés avons-nous rencontrées, quels compromis avons-nous acceptés et quelle route nous reste-t-il à parcourir ?

Katherine Johnson
26/10/2018
10:15-10:55

Docker en production : sur quels types de projets l’utilisez vous ?

Nous avons plusieurs dizaines d’API (PHP 7.x, symfony 3 et 4), un front office décliné pour plusieurs pays (node.js et React.js) et quelques back-offices (PHP 7.x, symfony ou ZF, vue.js).

Nous utilisons actuellement Docker sur une partie des API en PHP et les autres migreront de notre hébergement on-prem vers Kubernetes dans les prochains mois. Nous sommes également en cours de bascule pour le front office.
Les back-offices, où nous n’avons pas de trafic important ni fluctuant, migreront l’an prochain, une fois le reste terminé.

Le trafic sur nos applications est saisonnier et nous constatons tous les soirs un pic de charge extrêmement brutal. La souplesse d’un hébergement « cloud » est intéressante pour répondre à cette demande, et Kubernetes est aujourd’hui l’orchestrateur de choix.

(suite…)

[:fr]La parole est aux speakers : Frédéric Bouchery[:]

[:fr]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

Pour vraiment comprendre le Machine Learning quand on y connaît rien !

Et si on oubliait toute la littérature existante sur le Machine Learning, les grands principes, les formules mathématiques avec des symboles étranges ! Nous vous proposons de vous initier à cette science en partant de cas très concrets, simples et compréhensible pour tous. Classification, régression, supports de vecteur, TF-IDF, réseaux de neurones, etc., tous ces termes ne devraient plus avoir de secret pour vous ensuite.

Grace Hopper
26/10/2018
11:25-12:05

Le machine learning est un sujet tendance. Comment vois-tu l’avenir du machine learning ?

En fait, le grand public entend surtout parler d’Intelligence Artificielle, alors que nous autres informaticiens parlons surtout de Machine Learning. Pourtant, ces deux terminologies ne sont pas des synonymes. Le Machine Learning est une branche de l’Intelligence Artificielle, et il est bien plus proche de nos besoins actuels que la création d’une entité qui penserait par elle même et rechercherait une certaine Sarah Connor.

Le Machine Learning n’est pas un « buzz word », ou une technologie à la mode comme l’a été la télévision 3D! Ce n’est d’ailleurs pas une technologie, mais une science très ancienne qui fait beaucoup parler d’elle car nos capacités informatiques permettent de faire des choses qui étaient jusqu’alors impossibles.

C’est d’ailleurs amusant de constater que depuis que l’on peut faire ces choses très gourmandes en calcul, comme analyser des images ou des vidéos pour identifier des comportements, trouver des personnes, des objets, etc, que les gens s’intéressent au machine learning et mettent en action des algorithmes simples qu’ils auraient pu réaliser depuis de nombreuses années. Du coup, on découvre énormément d’applications au machine learning, et ceux qui n’en feront pas dans un avenir très proche, seront vite limités dans leur capacité d’innovation et dans l’évolution de leur business. Le train est en marche et il est encore temps de monter dedans avant qu’il n’aille trop vite.

(suite…)