test: Update regex for required and default in FieldAttributes (#84209)

Fixes: #61460

Signed-off-by: Abhijeet Kasurde <akasurde@redhat.com>
pull/84506/head
Abhijeet Kasurde 1 year ago committed by GitHub
parent db44fc58ec
commit f72aa1dc0c
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -1,19 +1,25 @@
from __future__ import annotations
import re
import ast
import pathlib
import sys
def main():
for path in sys.argv[1:] or sys.stdin.read().splitlines():
with open(path, 'r') as path_fd:
for line, text in enumerate(path_fd.readlines()):
match = re.search(r'(FieldAttribute.*(default|required).*(default|required))', text)
class CallVisitor(ast.NodeVisitor):
def __init__(self, path: str) -> None:
self.path = path
def visit_Call(self, node: ast.Call) -> None:
if isinstance(node.func, ast.Name) and node.func.id.endswith("FieldAttribute"):
if len([kw for kw in node.keywords if kw.arg in ("default", "required")]) > 1:
print(f"{self.path}:{node.lineno}:{node.col_offset}: use only one of `default` or `required` with `{node.func.id}`")
if match:
print('%s:%d:%d: use only one of `default` or `required` with `FieldAttribute`' % (
path, line + 1, match.start(1) + 1))
def main() -> None:
for path in sys.argv[1:] or sys.stdin.read().splitlines():
tree = ast.parse(pathlib.Path(path).read_text(), path)
CallVisitor(path).visit(tree)
if __name__ == '__main__':
if __name__ == "__main__":
main()

@ -50,7 +50,6 @@ lib/ansible/module_utils/six/__init__.py pylint:unidiomatic-typecheck
lib/ansible/module_utils/six/__init__.py replace-urlopen
lib/ansible/module_utils/urls.py replace-urlopen
lib/ansible/parsing/yaml/objects.py pylint:arguments-renamed
lib/ansible/playbook/collectionsearch.py required-and-default-attributes # https://github.com/ansible/ansible/issues/61460
lib/ansible/playbook/role/include.py pylint:arguments-renamed
lib/ansible/plugins/action/normal.py action-plugin-docs # default action plugin for modules without a dedicated action plugin
lib/ansible/plugins/cache/base.py ansible-doc!skip # not a plugin, but a stub for backwards compatibility

Loading…
Cancel
Save