AFUP Forum PHP 2020 Baromètre Planète PHP

La parole est aux speakers : Baptiste LANGLADE

Jusqu’à l’AFUP Day 2020, 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

Du test à la preuve : introduction au Property Based Testing

La plupart du temps nous écrivons nos tests unitaires ou fonctionnels en hardcodant les valeurs qui passent à travers notre code. Dans certains cas cela peut être suffisant, mais ce genre de test ne permet de valider notre code que pour les cas auxquel on a pensé. Le problème est que le monde dans lequel notre application va évoluer est chaotique, il est humainement impossible de prévoir toutes les formes que pourront prendre les données entrant notre système. Ayant pris connaissance de cette problématique on a commencé à utiliser des librairies comme Faker pour générer les données à notre place. Cependant cette solution ne permet de tester qu’un jeu de données à la fois. Entre alors en jeu le Property Based Testing. Celui-ci nous permet de valider un comportement en utilisant toutes les combinaisons possible des données d’entrée.

En ligne
24/06/2020
12:25-12:45

Lors du Forum PHP 2018 tu nous parlais de tester « le temps ». Est-ce que ton sujet aujourd’hui est une suite logique aux pistes que tu as évoquées à l’époque ?

Effectivement les deux sujets sont liés. Au Forum PHP 2018 j’évoquais en quoi « le temps » représente un état implicite (mais connu) dans nos applications, avec le Property Based Testing on va essayer de dénicher les implicites (inconnus) de nos applications.

Lorsque tu dois expliquer le concept de test unitaire à une personne qui le découvre, est-ce que tu expliques simultanément le Property Based Testing ou cela vient plutôt dans un second temps ?

Le Property Based Testing vient clairement dans un second temps car il implique d’avoir une réflexion sur le système de typage et un certain recul sur le code que l’on produit. Lorsqu’on commence à utiliser les tests unitaires, l’objectif premier à mon sens est de s’assurer que le code que l’on a écrit fonctionne pour les cas qu’on connait et se prémunir d’éventuelles futures régressions. Alors que le PBT va nous aider à tester des cas qu’on ne peut pas prévoir.

Est-ce que le Property Based Testing à changé ta façon de concevoir ton code ? En te poussant vers l’utilisation du Value Object par exemple ou en t’aidant à franchir des limites imposées par un test unitaire classique?

J’utilise les Value Object depuis quelques années maintenant mais l’année dernière j’ai commencé à remettre en question leur usage intensif car ils impliquent un surcoût à l’utilisation des fonctions pouvant dégrader l’expérience développeur. Cependant sur la même période j’ai utilisé de plus en plus le Property Based Testing ce qui m’a permis de me rendre compte de l’importance du typage et de la valeur des Value Object, qui permettent de réfléchir de façon de plus en plus abstraite à un système. Avoir ces « blocs » de haut-niveau simplifie également la lecture et l’écriture des tests, puisque ça permet de se concentrer plus sur le comportement que l’on veut tester.

Le speaker

Baptiste LANGLADE
Baptiste LANGLADE
Baptiste Langlade est un développeur PHP (certifié symfony2) passionné par indexer internet, Neo4j et le fonctionnement du cerveau.

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 :