IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Méthodes Discussion :

Dans quel cas devrait-on utiliser le développement piloté par les tests ?


Sujet :

Méthodes

  1. #1
    Expert éminent sénior

    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2014
    Messages
    194
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Septembre 2014
    Messages : 194
    Points : 12 291
    Points
    12 291
    Par défaut Dans quel cas devrait-on utiliser le développement piloté par les tests ?
    Dans quel cas devrait-on utiliser le développement piloté par les tests ?
    « le TDD est un outil, pas une religion », déclare un développeur

    Thomas Bandt, développeur et entrepreneur, a récemment écrit un billet de blog où il se demande pourquoi les gens qui parlent du développement dirigé par les tests (TDD : Test Driven Development) se partagent souvent en deux groupes : « les fondamentalistes qui exigent qu’aucune ligne de code ne doive être écrite sans un test, et les renieurs, ceux qui se refusent carrément à utiliser le TDD ».

    Dans son article, il raconte son expérience personnelle, où il avait réalisé plusieurs projets, dont certains, avec un développement TDD, et d’autres sans TDD. Ce qu’il avait remarqué, c’est qu’aucun de ces projets n’avait échoué. « Pour que les choses soient testables, vous avez besoin de plus d'infrastructures et souvent un niveau d'abstraction plus élevé, même pour les choses les plus simples ». Toutefois, ceci même s’il est souhaitable dans certains cas complexes, n’est pas justifié pour les projets simples et moins ambitieux, continu-t-il.

    Il explique ce point de vue par le rapport coût-bénéfice : « en couvrant des choses simples comme une action de contrôleur ASP.NET MVC qui retourne simplement une vue, ou une directive AngularJS qui vient manipuler un élément DOM, la valeur que vous obtenez en retour pour vos tests automatisés est beaucoup trop faible par rapport à l'énorme effort que vous avez à faire au lieu de simplement tester manuellement », surtout lorsque cela implique de « refactoriser le code d’un test à cause d’un changement de conception ».

    Selon lui, il faudrait utiliser le développement piloté par les tests uniquement lorsque l’on veut valider des algorithmes ou des parties critiques d’une application, ou lorsqu’on a des dépendances dont on n’a pas confiance ou qu’on ne connaît pas encore comme, par exemple, une API tierce ou un nouveau provider de base de données.

    « Je pense que s’était Steve Sanderson qui avait déclaré sur son blog qu'il utilisait les tests seulement lorsqu’il ne pouvait pas analyser [son code] facilement pour trouver un bug », déclare Thomas Bandt, « et je pense qu'il a raison » finit-il par avouer.

    Source : Blog de Thomas Bandt

    Et vous ?

    Que pensez-vous du TDD ?

    Êtes-vous d’accord avec l’avis de Thomas Bandt ?

  2. #2
    Rédacteur/Modérateur

    Avatar de yahiko
    Homme Profil pro
    Développeur
    Inscrit en
    Juillet 2013
    Messages
    1 424
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Juillet 2013
    Messages : 1 424
    Points : 8 710
    Points
    8 710
    Billets dans le blog
    43
    Par défaut
    Une fois n'est pas coutume, je crois qu'il existe une rubrique plus appropriée pour un tel sujet : http://www.developpez.net/forums/f40...ement-best-of/

  3. #3
    Membre habitué
    Inscrit en
    Juillet 2007
    Messages
    67
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 67
    Points : 131
    Points
    131
    Par défaut
    Je suis tout à fait d'accord.
    J'ai fais parti d'une boîte où il fallait tester chaque fonction de chaque classe, on y passait un temps fou, et je pense que le gain était négligeable.
    Les tests n'explosaient que lorsqu'on changeait (volontairement) des choses, et ne finissaient que par nous ralentir (énormément).
    (On travaillait avec un FrameWork MVC aussi).

    Néanmoins, il faut des tests, mais sur les calculs, les parties importantes, là où on n'a pas le droit à l'erreur.

    Mais pour en revenir aux TDD... Je pense du coup qu'avoir une méthodologie seulement pour une partie du dév. et une autre façon de faire pour le reste est suicidaire.
    Donc le TDD ne peut s'appliquer que sur une appli. où l'on teste toutes les fonctionnalités.

    Donc c'est bien pour toutes les applis sensibles, (calculs importants, vies, sécurité etc... en jeu),
    Maintenant pour faire une appli de gestion Web par exemple, même assez poussée, je pense que le TDD est une perte de temps effectivement (même si il faut faire des tests, en maîtrisant sérieusement leur étendue).

    Après c'est une question de moyens aussi.

  4. #4
    Membre habitué
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2007
    Messages
    86
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2007
    Messages : 86
    Points : 130
    Points
    130
    Par défaut
    En faite j'ai plus l'impression que tu lances un débat sur 'Test' ou 'pas test' en gros doit t'on atteindre les 100% de couverture ou non. Et non pas TDD vs Tests classiques, ce qui est comme même assez différent.

    Personnellement, je suis partisan du TDD et de la couverture à 100%, Le TDD est difficile à mettre en application pour une personne inexpérimenté et impose certaines contraintes d'architecture logicielle, mais une fois dans le bain le test devient rapide à réaliser, il permet de cadrer et d'accélérer le développement. De plus le test fait office de 'contrat' avec le chef de projet.

    On se sent ensuite plus en sécurité quand on réutilise des composants, ou bien que l'on fait des montées de versions de librairie, nul besoin de retester l'application 'à la main' en entier à chaque modification, cela prend 2 minutes.

  5. #5
    Membre confirmé
    Profil pro
    Expert technique .NET
    Inscrit en
    Août 2007
    Messages
    272
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Expert technique .NET

    Informations forums :
    Inscription : Août 2007
    Messages : 272
    Points : 530
    Points
    530
    Par défaut
    Heu, il n'y aurait pas un gros amalgame entre les tests en général, le TDD et les tests unitaires en particulier, là ?

    Pour la partie ASP.NET MVC, il ne faut pas tester chaque fonction, c'est évident : là, ce sont des tests d'interface qu'il faut, alors que lui sous-entend d'utiliser des tests unitaires.

    « Je pense que s’était Steve Sanderson qui avait déclaré sur son blog qu'il utilisait les tests seulement lorsqu’il ne pouvait pas analyser [son code] facilement pour trouver un bug », déclare Thomas Bandt, « et je pense qu'il a raison » finit-il par avouer.
    Faux : le but des tests est d'assurer la non-régression, donc ça n'a pas grand-chose à voir avec la capacité à analyser le code. Là, nous sommes plutôt dans la qualité de code que dans sa couverture.

    On retrouve ici, selon moi, le même problème que celui qui agite l'Agile actuellement : des gens pas forcément compétents sont à l'origine d'abus (en l’occurrence, le tout-tester avec des tests unitaires), sans vraiment savoir de quoi ils parlent, et entraînent une vague de dénigrement de processus ou méthodes qui sont pourtant extrêmement utiles et efficients. Ce sont ces abus qu'il faut chasser, pas l'ensemble de la méthodologie.

  6. #6
    Membre habitué Avatar de JacNar6
    Homme Profil pro
    Développeur Java/Java EE/Android
    Inscrit en
    Mai 2012
    Messages
    163
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Développeur Java/Java EE/Android

    Informations forums :
    Inscription : Mai 2012
    Messages : 163
    Points : 134
    Points
    134
    Par défaut
    Citation Envoyé par Bono_BX Voir le message
    « Je pense que s’était Steve Sanderson qui avait déclaré sur son blog qu'il utilisait les tests seulement lorsqu’il ne pouvait pas analyser [son code] facilement pour trouver un bug », déclare Thomas Bandt, « et je pense qu'il a raison » finit-il par avouer.
    Faux : le but des tests est d'assurer la non-régression, donc ça n'a pas grand-chose à voir avec la capacité à analyser le code. Là, nous sommes plutôt dans la qualité de code que dans sa couverture.
    Je ne comprends pas! Qu'est ce qui est faut? B raconte son expérience et l'appui par une expérience de A, toi tu dis faux. Donne plutôt les limites de leurs expériences.

    Secondo:
    le but des tests est d'assurer la non-régression
    J'ai aussi envie de crier Faux . Mais je te laisse une chance de t'expliquer

    La non-régression suppose une phase d'évolution ou de mise à jour d'un logiciel, ou même une certaine étape dans le processus de développement! Et là on veut se rassurer que tout ce qui fonctionnait continue de bien fonctionner. Mais ça aussi ce n'est qu'un nom que l'on donne aux tests à un stade précis du cycle de vie d'un logiciel. Avant le test de non-régression, il y a les tests unitaires (et biens d'autres) pour se rassurer que les fonctionnalités développées donnent les résultats attendus. assurer la non-régression est l'un des buts des tests, mais pas le but.

    J'espère qu'il n'y aura pas une chaîne de Faux

    Pour finir, il y a ce que l'on appelle en agriculture des expériences paysannes; parlant des paysans qui n'ont aucune formation professionnelle mais qui à force de cultiver de la tomate par exemple (ce qu'ils ont appris dans le tas, question de se débrouiller et d'avoir un gagne pain) finissent par apprendre et à obtenir des super récoltes dans des contextes où des ingénieurs agronomes qualifiés et diplômés échoueront. L'expérience de quelqu'un d'autre peut toujours nous apporter quelques choses, inutile de jouer au connaisseur et de s'enfermer dans une approche par ce qu'on l'a apprise à l'école ou par ce qu'on l'a expérimenté.

  7. #7
    Membre confirmé
    Profil pro
    Expert technique .NET
    Inscrit en
    Août 2007
    Messages
    272
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Expert technique .NET

    Informations forums :
    Inscription : Août 2007
    Messages : 272
    Points : 530
    Points
    530
    Par défaut
    « Je pense que s’était Steve Sanderson qui avait déclaré sur son blog qu'il utilisait les tests seulement lorsqu’il ne pouvait pas analyser [son code] facilement pour trouver un bug », déclare Thomas Bandt, « et je pense qu'il a raison » finit-il par avouer.
    Faux : le but des tests est d'assurer la non-régression, donc ça n'a pas grand-chose à voir avec la capacité à analyser le code. Là, nous sommes plutôt dans la qualité de code que dans sa couverture.
    Je ne comprends pas! Qu'est ce qui est faut? B raconte son expérience et l'appui par une expérience de A, toi tu dis faux. Donne plutôt les limites de leurs expériences.
    (Ca fait beaucoup de citation dans des citations )
    Le "Faux" se rapporte à "il a raison" (sinon ça n'aurait effectivement aucun sens). L'explication suit : il n'utilise pas les tests pour ce qu'ils sont faits. Il obtient peut-être des résultats ainsi, mais ce n'est pas un bon argument pour le sujet de la discussion.

    J'ai aussi envie de crier Faux . Mais je te laisse une chance de t'expliquer

    La non-régression suppose une phase d'évolution ou de mise à jour d'un logiciel, ou même une certaine étape dans le processus de développement! Et là on veut se rassurer que tout ce qui fonctionnait continue de bien fonctionner. Mais ça aussi ce n'est qu'un nom que l'on donne aux tests à un stade précis du cycle de vie d'un logiciel. Avant le test de non-régression, il y a les tests unitaires (et biens d'autres) pour se rassurer que les fonctionnalités développées donnent les résultats attendus. assurer la non-régression est l'un des buts des tests, mais pas le but.
    Depuis quand les tests unitaires ne font pas parti des tests de non régression ? Ta remarque illustre parfaitement ce que je disais : il y a amalgame et incompréhension entre tests unitaires, tests en général et TDD. Mais j’avoue ne pas avoir bien compris ce que tu as écris, c'est u peu touffu. Peux-tu le reformuler, s'il-te-plaît ?

    Pour finir, il y a ce que l'on appelle en agriculture des expériences paysannes; parlant des paysans qui n'ont aucune formation professionnelle mais qui à force de cultiver de la tomate par exemple (ce qu'ils ont appris dans le tas, question de se débrouiller et d'avoir un gagne pain) finissent par apprendre et à obtenir des super récoltes dans des contextes où des ingénieurs agronome qualifiées et diplômés échoueront. L'expérience de quelqu'un d'autre peux toujours nous apporter quelques choses, inutile de jouer au connaisseur et de s'enfermer dans une approche par ce qu'on l'a apprise à l'école ou par ce qu'on l'a expérimenté.
    Ca tombe bien, je parle justement d'expérience, et c'est pour cela que je fais la différence entre les différents types de test (et que je dis par exemple qu'il ne faut pas faire de TU sur du MVC). Et pour reprendre ton exemple agricole, si une personne cultive des pommes de terre comme des tomates, elle n'obtiendra pas grand-chose, peu importe qu'elle soit ingénieur agronome ou qu'elle apprenne par l'expérience. Personnellement, on ne m'a jamais appris à faire des tests unitaires ou d'interface à l'école, tout ce que je sais à ce sujet, je l'ai appris sur le tas.
    Il ne faut certes pas s'enfermer dans une approche (encore fois, confer ma remarque sur le MVC), mais il faut aussi savoir prendre ce qu'il y a de bon dans les méthodes, car elles résultent elles aussi ... de l'expérience et de l'apprentissage de ceux qui les ont mise en place. Bref, avoir l'esprit critique (sans vouloir t'insulter, c'est une remarque générale).

  8. #8
    Membre habitué Avatar de JacNar6
    Homme Profil pro
    Développeur Java/Java EE/Android
    Inscrit en
    Mai 2012
    Messages
    163
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Développeur Java/Java EE/Android

    Informations forums :
    Inscription : Mai 2012
    Messages : 163
    Points : 134
    Points
    134
    Par défaut
    Citation Envoyé par Bono_BX Voir le message
    Depuis quand les tests unitaires ne font pas parti des tests de non régression ? Ta remarque illustre parfaitement ce que je disais : il y a amalgame et incompréhension entre tests unitaires, tests en général et TDD. Mais j’avoue ne pas avoir bien compris ce que tu as écris, c'est u peu touffu. Peux-tu le reformuler, s'il-te-plaît ?(sans vouloir t'insulter, c'est une remarque générale).
    Ce que je voulais dire est que, test unitaire par exemple n'implique pas forcement test de non-régression; Pour moi non-régression suppose quelque chose qui marchait déjà, et après une mise à jour ou une évolution, on se rassure que l'on a rien bousculé. Cependant l'on peut faire des tests pour s'assurer que le bout de code que l'on vient d'écrire marche et là je ne pense pas que l'on puisse parler de non-régression; mais je sais que dans test de le non-régression on peut inclure les unitaires et tous les autres.

    Citation Envoyé par Bono_BX Voir le message
    sans vouloir t'insulter, c'est une remarque générale
    Je te crois sur parole chère ami, surtout que j'ai rien vu d'injurieux et je sais avoir encore beaucoup à apprendre des TDD!

  9. #9
    Membre chevronné
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Septembre 2013
    Messages
    485
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2013
    Messages : 485
    Points : 2 151
    Points
    2 151
    Par défaut
    Je rajouterai un petit point pour parler de tests en TDD et de non-régression.

    J'utilise assez souvent le TDD dans mon développement.
    C'est donc l'écriture de mes tests qui m'induit l'architecture et le développement de ma nouvelle fonctionnalité.
    Donc, déjà, mes tests ne sont pas là pour tester quelqu’une des moindres fonctions de mon nouveau bloque fonctionnel, mais le comportement nominal et au limite de celui-ci vu de l’extérieur (c'est à dire des autres couches du logiciel)
    J'écris mes tests en pensant: quelle service doit faire mon module/ma classe/ma fonction pour le reste de l'application.

    Je peux bien sur factoriser mon bloque en question, sans devoir impacter fortement mes tests
    Et c'est même dans ce cas que mes tests qui était à l'origine fait pour m'aider à développer mon nouveau service devienne des tests de non-régression.
    Je suis dans un cas où je reste à fonctionnalité constante mais que je modifie mon algorithme (pour plus de visibilité, pour plus de performance, pour mettre à jours un framework, ...)
    De même, si je modifie des bibliothèques génériques à mon application, l'ensemble de mes tests me garantissent que je ne fait pas de régression.
    Mes anciens tests me servent alors de garde-fou pour tout évolution sur ce point

    Dans la même logique, on peut mettre en place des tests d’intégration pour vérifier sur des scénario simples que les différents bloques fonctionnent bien ensemble.
    C'est même tests d'intégrations deviennent également des test de non-régression lorsque l'on souhaite améliorer l'architecture entre les différents bloques ou en modifier un en profondeur.

    Par contre, je pense que certain vois les tests de non-régression comme des tests à posteriori.
    En effet, dans le cas de code "legacy" (pour pas dire du code tout-pourri-codé-par-quelqu'un-qui-n'est-plus-là-et-que-personne-ne-veux-remplacer) il est interessant de pouvoir à posterieuri ajouter quelque scénario de tests afin de vérifier la non régression de certain scénario ou de contrôler la correction d'ancien bug.
    Mais on est plus dans une logique de maintenance logiciel que de développement.

  10. #10
    Membre émérite
    Inscrit en
    Janvier 2011
    Messages
    805
    Détails du profil
    Informations personnelles :
    Localisation : Autre

    Informations forums :
    Inscription : Janvier 2011
    Messages : 805
    Points : 2 919
    Points
    2 919
    Par défaut
    A la réflexion, ça va plus vite de dire dans quelles occasions je ne fais pas de TDD (tests unitaires ou autre échelle)

    • Prototypage rapide en mode "proof of concept"

    • Code boilerplate, répétitif et sans grande logique (mais c'est souvent un signal d'alarme pour mieux factoriser ou générer ce code)

    • Couche UI

    • Legacy code (évidemment)


    J'en profite pour rappeler que TDD comporte une étape de refactoring que tout le monde oublie, mais qui est très efficace en combinaison avec les tests...

    Je trouve un peu réducteur d'opposer TDD à "pas de tests du tout". Le débat soulevé par le blog est plutôt "quand faire des tests automatisés ?"

  11. #11
    Membre habitué Avatar de JacNar6
    Homme Profil pro
    Développeur Java/Java EE/Android
    Inscrit en
    Mai 2012
    Messages
    163
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Développeur Java/Java EE/Android

    Informations forums :
    Inscription : Mai 2012
    Messages : 163
    Points : 134
    Points
    134
    Par défaut
    Citation Envoyé par Laurent 1973 Voir le message
    Je rajouterai un petit point pour parler de tests en TDD et de non-régression.

    J'utilise assez souvent le TDD dans mon développement.
    C'est donc l'écriture de mes tests qui m'induit l'architecture et le développement de ma nouvelle fonctionnalité.
    Donc, déjà, mes tests ne sont pas là pour tester quelqu’une des moindres fonctions de mon nouveau bloque fonctionnel, mais le comportement nominal et au limite de celui-ci vu de l’extérieur (c'est à dire des autres couches du logiciel)
    J'écris mes tests en pensant: quelle service doit faire mon module/ma classe/ma fonction pour le reste de l'application.

    Je peux bien sur factoriser mon bloque en question, sans devoir impacter fortement mes tests
    Et c'est même dans ce cas que mes tests qui était à l'origine fait pour m'aider à développer mon nouveau service devienne des tests de non-régression.
    Je suis dans un cas où je reste à fonctionnalité constante mais que je modifie mon algorithme (pour plus de visibilité, pour plus de performance, pour mettre à jours un framework, ...)
    De même, si je modifie des bibliothèques génériques à mon application, l'ensemble de mes tests me garantissent que je ne fait pas de régression.
    Mes anciens tests me servent alors de garde-fou pour tout évolution sur ce point

    Dans la même logique, on peut mettre en place des tests d’intégration pour vérifier sur des scénario simples que les différents bloques fonctionnent bien ensemble.
    C'est même tests d'intégrations deviennent également des test de non-régression lorsque l'on souhaite améliorer l'architecture entre les différents bloques ou en modifier un en profondeur.
    Merci d'avoir si bien expliqué ce que je pensais réellement

  12. #12
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    35
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 35
    Points : 67
    Points
    67
    Par défaut
    Ca aurait pu être intéressant si le mec avait capté que l'objectif de TDD n'est pas de tester son code...
    Mais bon... les idées reçues ont la vie dure...

  13. #13
    Expert éminent
    Avatar de _skip
    Homme Profil pro
    Développeur d'applications
    Inscrit en
    Novembre 2005
    Messages
    2 898
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur d'applications
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 898
    Points : 7 752
    Points
    7 752
    Par défaut
    Je pense que la pièce centrale de son argument est justement le fameux "rapport coût-bénéfice".
    Celui-là même qui m'a poussé a fortement délaisser les tests unitaires au profit des tests d'intégration qui sont moins souvent intrusifs et moins rapidement invalidés par les opérations de refactoring. C'est particulièrement le cas quand on utilise des sources de données, il est parfois utile de pouvoir tester toutes les couches de son code par des appels haut niveau.

Discussions similaires

  1. [PHPUnit] Développement piloté par les tests
    Par Invité dans le forum Bibliothèques et frameworks
    Réponses: 2
    Dernier message: 12/11/2013, 13h19
  2. Réponses: 9
    Dernier message: 26/01/2012, 10h33
  3. développement piloté par les tests pour un jeu vidéo
    Par Mindiell dans le forum Méthodes Agiles
    Réponses: 1
    Dernier message: 06/08/2009, 10h28
  4. Développement piloté par les tests avec PHPUnit
    Par Invité dans le forum Bibliothèques et frameworks
    Réponses: 0
    Dernier message: 18/11/2008, 19h53

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo