mirror of
https://github.com/ansible-collections/community.general.git
synced 2025-10-04 15:34:01 -07:00
Upgrade more code-smell tests. (#36560)
* Enhance no-dict-* code-smell tests. * Enhance no-basestring code-smell test. * Enhance no-get-exception code-smell test. * Enhance empty-init code-smell test. * Enhance required-and-default-attribute test. * Remove unused code-smell test.
This commit is contained in:
parent
a4df4d33ac
commit
891f4f3b2d
23 changed files with 261 additions and 161 deletions
42
test/sanity/code-smell/no-get-exception.py
Executable file
42
test/sanity/code-smell/no-get-exception.py
Executable file
|
@ -0,0 +1,42 @@
|
|||
#!/usr/bin/env python
|
||||
|
||||
import os
|
||||
import re
|
||||
import sys
|
||||
|
||||
|
||||
def main():
|
||||
skip = set([
|
||||
'test/sanity/code-smell/%s' % os.path.basename(__file__),
|
||||
'lib/ansible/module_utils/pycompat24.py',
|
||||
'lib/ansible/module_utils/six/__init__.py',
|
||||
# the following files should be fixed and removed from this list
|
||||
'lib/ansible/modules/network/cloudengine/ce_file_copy.py',
|
||||
'lib/ansible/modules/network/panos/panos_dag_tags.py',
|
||||
'lib/ansible/modules/network/panos/panos_match_rule.py',
|
||||
'lib/ansible/modules/network/panos/panos_op.py',
|
||||
'lib/ansible/modules/system/sefcontext.py',
|
||||
])
|
||||
|
||||
basic_allow_once = True
|
||||
|
||||
for path in sys.argv[1:]:
|
||||
if path in skip:
|
||||
continue
|
||||
|
||||
with open(path, 'r') as path_fd:
|
||||
for line, text in enumerate(path_fd.readlines()):
|
||||
match = re.search(r'(get_exception)', text)
|
||||
|
||||
if match:
|
||||
if path == 'lib/ansible/module_utils/basic.py' and basic_allow_once:
|
||||
# basic.py is allowed to import get_exception for backwards compatibility but should not call it anywhere
|
||||
basic_allow_once = False
|
||||
continue
|
||||
|
||||
print('%s:%d:%d: do not use `get_exception`' % (
|
||||
path, line + 1, match.start(1) + 1))
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
main()
|
Loading…
Add table
Add a link
Reference in a new issue