Add test to require docs for action plugins. (#48376)
This commit is contained in:
parent
eec21a3d12
commit
1a3bf09f8a
3 changed files with 82 additions and 0 deletions
|
@ -0,0 +1,4 @@
|
|||
Sanity Tests » action-plugin-docs
|
||||
=================================
|
||||
|
||||
Each action plugin should have a matching module of the same name to provide documentation.
|
4
test/sanity/code-smell/action-plugin-docs.json
Normal file
4
test/sanity/code-smell/action-plugin-docs.json
Normal file
|
@ -0,0 +1,4 @@
|
|||
{
|
||||
"always": true,
|
||||
"output": "path-message"
|
||||
}
|
74
test/sanity/code-smell/action-plugin-docs.py
Executable file
74
test/sanity/code-smell/action-plugin-docs.py
Executable file
|
@ -0,0 +1,74 @@
|
|||
#!/usr/bin/env python
|
||||
"""Test to verify action plugins have an associated module to provide documentation."""
|
||||
|
||||
import os
|
||||
|
||||
|
||||
def main():
|
||||
"""Main entry point."""
|
||||
skip = set([
|
||||
'__init__', # action plugin base class, not an actual action plugin
|
||||
'net_base', # base class for other net_* action plugins which have a matching module
|
||||
'normal', # default action plugin for modules without a dedicated action plugin
|
||||
|
||||
# The following action plugins existed without modules to document them before this test was put in place.
|
||||
# They should either be removed, have a module added to document them, or have the exception documented here.
|
||||
'bigip',
|
||||
'bigiq',
|
||||
'ce_template',
|
||||
|
||||
# The following action plugins provide base classes for network platform specific modules to support `connection: local`.
|
||||
# Once we fully deprecate the use of connection local, the base classes will go away.
|
||||
'aireos',
|
||||
'aruba',
|
||||
'asa',
|
||||
'ce',
|
||||
'cnos',
|
||||
'dellos10',
|
||||
'dellos6',
|
||||
'dellos9',
|
||||
'enos',
|
||||
'eos',
|
||||
'ios',
|
||||
'iosxr',
|
||||
'ironware',
|
||||
'junos',
|
||||
'netconf',
|
||||
'nxos',
|
||||
'sros',
|
||||
'vyos',
|
||||
])
|
||||
|
||||
module_names = set()
|
||||
|
||||
for root, dirs, files in os.walk('lib/ansible/modules'):
|
||||
for filename in files:
|
||||
name, ext = os.path.splitext(filename)
|
||||
|
||||
if ext == '.py' and name != '__init__':
|
||||
if name.startswith('_'):
|
||||
name = name[1:]
|
||||
|
||||
module_names.add(name)
|
||||
|
||||
action_plugin_dir = 'lib/ansible/plugins/action'
|
||||
unused_skip = set(skip)
|
||||
|
||||
for filename in os.listdir(action_plugin_dir):
|
||||
name, ext = os.path.splitext(filename)
|
||||
|
||||
if ext == '.py' and name not in module_names:
|
||||
if name in skip:
|
||||
unused_skip.remove(name)
|
||||
continue
|
||||
|
||||
path = os.path.join(action_plugin_dir, filename)
|
||||
|
||||
print('%s: action plugin has no matching module to provide documentation' % path)
|
||||
|
||||
for filename in sorted(unused_skip):
|
||||
print("%s: remove '%s' from skip list since it does not exist" % ('test/sanity/code-smell/action-plugin-docs.py', filename))
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
main()
|
Loading…
Reference in a new issue