AFUP Forum PHP 2019 Baromètre Planète PHP

La parole est aux speakers : Adrien Lucas

Jusqu’au Forum PHP 2019, 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

Le TDD dans la vraie vie avec Panther

Panther est un tout nouveau composant Symfony dont l'objectif est de vous simplifier l'écriture des tests d'intégration et des tests end-to-end !

Dans ce talk vous découvrirez I. qu'est-ce que la pyramide des tests et en quoi Panther est l'outil idéal pour homogénéiser sa suite de tests ; II. en quoi consiste la pratique du TDD et comment doit-elle être adaptée pour correspondre aux problématiques d'une application web ; III. à quoi ressemblent ces pratiques sur un projet réel et quelles charges leur mise en place peut-elle coûter ; IV. quelles pistes peuvent être explorées pour améliorer nos suites de tests et bénéficier de toujours plus d'assurance qualité.

Grace Hopper
25/10/2019
10:15-10:55

Panther s’impose progressivement comme un outil de test de référence : en quoi celui-ci aide-t-il à écrire des tests de meilleure qualité et quelles sont les raisons qui t’ont poussé à l’utiliser ?

Panther est un projet membre de l’écosystème Symfony, avec tout ce que cela implique en termes de “promessede rétrocompatibilité, de sérieux sur la qualité de code et d’une communauté parmi les plus bienveillantes de l’Open Source.

Il a ainsi pour principal avantage de s’inspirer au maximum des API existantes, en étendant et en implémentant des interfaces et des classes tierces, notamment celles du FrameworkBundle et des composants BrowserKit et DomCrawler.

Un développeur déjà familiarisé avec la pratique des tests automatisés sur des applications Symfony ne sera pas perdu face à une suite de tests propulsée par Panther.

Nous avons régulièrement de nouveaux outils pour faire du TDD, de l’analyse de code, etc. As-tu quelques pistes pour faire un choix par rapport à un contexte donné ?

La qualité de code est devenue une préoccupation majeure dans la réalisation d’un projet web avec PHP, ce qui n’était pas vraiment le cas il y a encore quelques années. C’est une excellente nouvelle pour tous les acteurs de la filière, même si cela implique l’adoption de nouvelles pratiques (notamment le TDD) pouvant paraître contre-intuitives au premier abord. De plus, le “surcoût” généré par ces pratiques pourrait même sembler contre-productif aux décideurs.

En effet, les pratiques liées à la qualité de code sont souvent perçues par les « non-tech » comme étant des postes de dépenses dont le ROI n’est pas facilement calculable, voire pire, dont les bénéfices sont uniquement techniques, sans impacts sur le métier. Au final, cette démarche peut sembler n’être qu’un caprice de technicien… Il faut donc être le plus efficient possible dans la mise en oeuvre de sa démarche d’assurance qualité.

Panther s’impose comme une solution idéale pour maîtriser et minimiser les coûts de démarrage et de maintenance de notre “test suite”. Cette surcouche du WebTestCase de Symfony – qui est lui-même basé sur le TestCase de PhpUnit – permet aux développeurs déjà expérimentés de trouver rapidement leurs marques. Et les plus “novices” en la matière peuvent aller à l’essentiel, tout en capitalisant sur un outil unique, à la fois simple et puissant (comme c’est souvent le cas dans l’écosystème Symfony) !

Dans le cadre de tes missions de coach tu as probablement souvent été dans une situation d’évangélisation de la notion de test. Est-ce qu’à contrario tu as déjà été confronté à des situations où tu penses que cela était « surtesté », un peu comme on peut voir parfois de la « surachitecture » ?

J’ai plus souvent rencontré de la “surarchitecture” que du « surtest ». Pourtant, le fait de maintenir la couverture de tests d’une application à un niveau suffisamment exhaustif permet, entre autres, de ne pas réinventer la roue et d’éviter les violations du principe KISS.

A contrario, une application ayant une couverture “excessive” pourrait se révéler trop rigide, les coûts de maintenance et d’évolution pourraient devenir exagérés par rapport aux bénéfices apportés. L’une des compétences les plus importantes à maîtriser dans la pratique des tests automatisés est de savoir quoi tester !

C’est face à cette problématique que le TDD démontre son efficacité en proposant un « cadre de travail » suffisamment précis et strict. Ce cadre et ses principes vont guider la pratique : ils permettent de s’assurer que les lignes de code écrites soient bien couvertes par des tests, et, inversement, que les tests soient écrits seulement si ils sont réellement nécessaires à l’application.

Le speaker

Adrien LUCAS
Adrien LUCAS
Expert Symfony et coach OOP pour Smile. Ex-SensioLabs.

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 :