Plutôt que de prouver la justesse d'un programme, on se contente souvent de tester le code en vérifiant qu'il se comporte correctement sur des entrées pour lesquelles le résultat est connu.
ITests unitaires
De l'écriture des spécifications à la validation d'un logiciel, chaque étape du développement est idéalement accompagnée d'une phase de tests. Nous nous intéressons ici aux tests unitaires dont l'objectif est de tester indépendamment chaque fonction.
Ces tests peuvent être conçus avant ou après la fonction à tester, éventuellement par une personne différente. Ils sont généralement exécutés aussi souvent que possible pour éviter les problèmes de régression.
Mot clé
Régression : ajout de bugs lors de modification du code.
Les tests unitaires doivent être les plus couvrants possible, c'est-à-dire envisager le plus de cas possibles (simples ou à problème). Chaque branche du code doit idéalement être testée.
IIOutils de test
Il existe plusieurs outils permettant de réaliser des tests unitaires : les assertions, les doctests, le module tiers pytest…
Les exemples suivants concernent une fonction fibo(n) qui calcule le terme n de la suite de Fibonacci (suite définie par , et, pour , ).
1 Assertions
Une assertion échoue si l'expression booléenne qui suit le mot clé assert est fausse. Si elle est vraie, l'exécution continue sans erreur. Une assertion permet donc de vérifier, par exemple, le retour d'une fonction. Dès qu'une assertion est fausse, l'exécution s'arrête (exception AssertionError).
Exemple :
2 Module doctest
Le module doctest permet d'intégrer des tests dans la docstring des fonctions. Les doctests sont repérées par la chaîne >>>. Écrire des doctests permet à la fois de réaliser des tests unitaires, mais aussi de documenter efficacement la fonction.
Exemple :
>> fibo(3); Ligne 6 : ; 2; Ligne 7 : ; >>> fibo(7); Ligne 8 : ; 13; Ligne 9 : ; """; Ligne 10 : ; # Texte de la fonction; " src="/modules-assets/images/PB_Bac_06461_NSIT_gene/PB_Bac_06461_NSIT_gene_p009-036_C01_Tab_47.png" />Les tests peuvent être validés depuis l'interpréteur Python (ici, un des tests a échoué) :
3 Module pytest
pytest permet de faire des tests plus complets (vérification qu'une exception est levée par exemple) et propose des diagnostics plus complets et plus explicites que les autres outils.
On peut démarrer l'utilisation de pytest par l'écriture de fonctions préfixées par test_ contenant chacune une assertion.
Exemple :
L'exécution des tests réalisés avec pytest montre un diagnostic plus précis des problèmes (non reproduit ici).