-
-
Notifications
You must be signed in to change notification settings - Fork 387
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
pylint error on decorated name
argument
#476
Comments
Ah, turns out the support for decorators in pylint is a bit lacking. If you read pylint-dev/pylint#259 you'll see that there's a work around. I will test this now. |
OK, so following that information, you do something like this in your
See this: https://github.com/PyCQA/pylint/blob/master/doc/whatsnew/2.4.rst What unfortunately happens is that you will get false negatives when you actually pass in incorrect arguments into the pyinfra decorated functions. Is flake8 fine with decorators? I'll leave this up to you as to what you do with it. |
So flake8 doesn't do type checking which has prevented this being an issue before! There's currently a PR/branch (#472) tracking implementation of type checking using mypy. The operation functions are particularly annoying as they all accept a list of global arguments, defined here which is a bit of a nightmare for typing. I think long run the right approach is to move these into the operation function definition itself, will need to deduplicate that with the deploy function also (possibly by way of a decorator decorator!). |
Not only mypy but also other static type checkers like pyright (as LSP server) will complain about the signature because they cannot process the decorator during static type checking. One thing worth considering is ParamSpec (PEP 612): see microsoft/pyright#774 and https://peps.python.org/pep-0612/ , but this does not allow introducing additional kwargs to a ParamSpec. One easy solution to this might be to add dummy @operation(is_idempotent=False)
-def shell(commands, state=None, host=None):
- ...
@operation(is_idempotent=False)
+def shell(commands, state=None, host=None, **kwargs):
+ ... Have you considered this? |
I wish this were included in v2.0 release, but still looking forward to it. |
Hm. I can't replicate this (the error) with either from typing import Generator, List
from pyinfra.api.operation import operation
@operation
def shell(commands: List[str]) -> Generator[str, None, None]:
for command in commands:
yield command
shell(
name="Run command",
commands=["echo hi"],
yes=False,
) This passes with both tools as the decorator seems to effectively disable all type checking on the function args as it interprets them as Regarding fixing typing properly in the future I had one idea - we could (ab)use stub files to force type checkers into including all the global arguments as valid types. Ie by generating (possibly as part of package install?) stub files alongside operation files that type annotate the op functions un-decorated; ie: def shell(
commands: list[str],
name: str | None,
_sudo: boolean = False,
...all the other global args,
) -> Generator[Command | str, None, None]: ... This would a) get around the Python 3.10 requirement for Annotations could simply be inlined everywhere in the codebase, including operations, and the stub generator would use these combined with the global arguments to generate stubs for operation modules. |
In my environments: python 3.9.7, pylint 2.13.5. It does give the error as follows (and so does pyright / VS Code, etc.). Looking at upstream issues, I don't think those checkers disable type checking on decorated functions yet as of now.
But I like the idea of using type stubs as well. pylint will still complain about |
pylint error on decorated
name
argumentDue to the way the
name
argument is injected into some functions with a decorator, such aspyinfra.operations.server.shell
, we get a pylint error like:To Reproduce
deploy.py
:pylint deploy.py
Expected behavior
No pylint errors
Meta
System: Linux Platform: Linux-5.8.11-1-MANJARO-x86_64-with-glibc2.2.5 Release: 5.8.11-1-MANJARO Machine: x86_64 pyinfra: v1.2.1 Executable: /home/user/workspace/common/venv/bin/pyinfra Python: 3.8.5 (CPython, GCC 10.2.0)
The text was updated successfully, but these errors were encountered: