Maison >développement back-end >Tutoriel Python >Avantages, inconvénients et dangers de PyLint
Tirez le meilleur parti de PyLint.
Frapper au tableau : PyLint est en fait plutôt bon !
« PyLint peut vous sauver la vie » est une exagération, mais pas autant qu'on pourrait le penser. PyLint peut vous éviter des défauts très difficiles à trouver et complexes. Au pire, cela ne fait que gagner du temps d’exécution des tests. Au mieux, cela vous aide à éviter des erreurs complexes en production.
Je suis gêné de dire à quel point c'est courant. Les noms de tests sont toujours tellement bizarres : personne ne se soucie du nom, et souvent un nom naturel ne peut pas être trouvé. Par exemple, le code suivant :
def test_add_small():# Math, am I right?assert 1 + 1 == 3def test_add_large():assert 5 + 6 == 11def test_add_small():assert 1 + 10 == 11
Le test prend effet :
collected 2 items test.py .. 2 passed
Mais voici le problème : si vous remplacez le nom d'un test, le framework de test ignorera volontiers le test !
En réalité, ces fichiers peuvent contenir des centaines de lignes, et la personne qui ajoute le nouveau test peut ne pas connaître tous les noms. Tout semble bien jusqu'à ce que l'on examine de plus près le résultat du test.
Le pire, c'est l'ajout de tests couverts, les dommages causés par les tests couverts et les effets d'entraînementpeuvent prendre des jours, des mois, voire des années à découvrir.
Comme un bon ami, PyLint peut vous aider.
test.py:8:0: E0102: function already defined line 1 (function-redefined)
Tout comme la sitcom des années 90, plus vous en apprenez sur PyLint, plus vous recevez de questions. Voici le code habituel d'un programme de modélisation boursière :
"""Inventory abstractions"""import attrs@attrs.defineclass Laptop:"""A laptop"""ident: strcpu: str
Mais PyLint semble avoir ses propres opinions (probablement formées dans les années 90) et n'a pas peur de les énoncer comme des faits :
$ pylint laptop.py | sed -n '/^laptop/s/[^ ]*: //p'R0903: Too few public methods (0/2) (too-few-public-methods)
Y avez-vous déjà pensé dans un Ajouter vos propres opinions non fondées à un outil utilisé par des millions de personnes ? PyLint compte 12 millions de téléchargements par mois.
"Si vous êtes trop pointilleux, les gens annuleront le chèque" — Il s'agit du numéro 6987 de PyLint GitHub, soulevé le 3 juillet 2022
C'est une attitude envers l'ajout d'un test qui peut avoir de nombreux faux positifs .. “ Hmm”.
PyLint est génial, mais vous devez y faire attention. Pour que PyLint fonctionne pour vous, voici les trois choses que je recommande :
Épinglez la version de PyLint que vous utilisez pour éviter toute surprise !
Définissez dans votre .toml
fichier :
[project.optional-dependencies]pylint = ["pylint"]
Définissez en code :
from unittest import mock
Cela correspond au code suivant :
# noxfile.py...@nox.session(python=VERSIONS[-1])def refresh_deps(session):"""Refresh the requirements-*.txt files"""session.install("pip-tools")for deps in [..., "pylint"]:session.run("pip-compile","--extra",deps,"pyproject.toml","--output-file",f"requirements-{deps}.txt",)
Désactivez toutes les vérifications, puis activez celles qui, selon vous, ont un faux positif taux élevé. (Pas seulement le ratio faux négatifs/faux positifs !)
# noxfile.py...@nox.session(python="3.10")def lint(session):files = ["src/", "noxfile.py"]session.install("-r", "requirements-pylint.txt")session.install("-e", ".")session.run("pylint","--disable=all",*(f"--enable={checker}" for checker in checkers)"src",)
Voici les dames que j'aime. Améliorez la cohérence du projet et évitez les erreurs évidentes.
checkers = ["missing-class-docstring","missing-function-docstring","missing-module-docstring","function-redefined",]
Vous pouvez simplement utiliser PyLint pour les bonnes parties. Exécutez-le dans CI pour plus de cohérence et utilisez des vérificateurs courants.
Supprimez la mauvaise partie : vérificateur désactivé par défaut.
Évitez les pièces dangereuses : Version corrigée pour éviter les surprises.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!