ansible-test action-plugin-docs sidecar (#83325)

Fix to have ansible-test sanity --test action-plugin-docs to check for
action plugin documentation inside a sidecar file rather than a Python
module.
pull/83432/head
Jordan Borean 6 months ago committed by GitHub
parent 6e8a7ed327
commit a9b902f579
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -0,0 +1,2 @@
bugfixes:
- ansible-test action-plugin-docs - Fix to check for sidecar documentation for action plugins

@ -0,0 +1,4 @@
shippable/posix/group3 # runs in the distro test containers
shippable/generic/group1 # runs in the default test container
context/controller
needs/target/collection

@ -0,0 +1,11 @@
# Copyright (c) 2024 Ansible Project
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
from __future__ import annotations
from ansible.plugins.action import ActionBase
class ActionModule(ActionBase):
def run(self, tmp, task_vars):
return {"changed": False}

@ -0,0 +1,11 @@
# Copyright (c) 2024 Ansible Project
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
from __future__ import annotations
from ansible.plugins.action import ActionBase
class ActionModule(ActionBase):
def run(self, tmp, task_vars):
return {"changed": False}

@ -0,0 +1,11 @@
# Copyright (c) 2024 Ansible Project
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
from __future__ import annotations
from ansible.plugins.action import ActionBase
class ActionModule(ActionBase):
def run(self, tmp, task_vars):
return {"changed": False}

@ -0,0 +1,19 @@
# Copyright (c) 2024 Ansible Project
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
DOCUMENTATION = r"""
---
module: with_py
short_description: Short description
description: Long description
options: {}
author:
- Ansible Core Team (@ansible)
"""
EXAMPLES = r"""
- name: Some example
ns.col.with_py:
"""
RETURNS = ""

@ -0,0 +1,16 @@
# Copyright (c) 2024 Ansible Project
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
DOCUMENTATION:
module: with_yaml
short_description: Short description
description: Long description
options: {}
author:
- Ansible Core Team (@ansible)
EXAMPLES: |
- name: Some example
ns.col.with_yaml:
RETURNS: {}

@ -0,0 +1,16 @@
# Copyright (c) 2024 Ansible Project
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
DOCUMENTATION:
module: with_yml
short_description: Short description
description: Long description
options: {}
author:
- Ansible Core Team (@ansible)
EXAMPLES: |
- name: Some example
ns.col.with_yml:
RETURNS: {}

@ -0,0 +1,9 @@
#!/usr/bin/env bash
set -eu
source ../collection/setup.sh
set -x
ansible-test sanity --test action-plugin-docs --color "${@}"

@ -7,7 +7,9 @@
"plugins/action/" "plugins/action/"
], ],
"extensions": [ "extensions": [
".py" ".py",
".yml",
".yaml"
], ],
"output": "path-message" "output": "path-message"
} }

@ -28,13 +28,13 @@ def main():
module_names.add(full_name) module_names.add(full_name)
for path in paths: for path in paths:
full_name = get_full_name(path, action_prefixes) full_name = get_full_name(path, action_prefixes, extensions=('.py',))
if full_name and full_name not in module_names: if full_name and full_name not in module_names:
print('%s: action plugin has no matching module to provide documentation' % path) print('%s: action plugin has no matching module to provide documentation' % path)
def get_full_name(path, prefixes): def get_full_name(path: str, prefixes: dict[str, bool], extensions: tuple[str] | None = None) -> str | None:
"""Return the full name of the plugin at the given path by matching against the given path prefixes, or None if no match is found.""" """Return the full name of the plugin at the given path by matching against the given path prefixes, or None if no match is found."""
for prefix, flat in prefixes.items(): for prefix, flat in prefixes.items():
if path.startswith(prefix): if path.startswith(prefix):
@ -45,13 +45,16 @@ def get_full_name(path, prefixes):
else: else:
full_name = relative_path full_name = relative_path
full_name = os.path.splitext(full_name)[0] full_name, file_ext = os.path.splitext(full_name)
name = os.path.basename(full_name) name = os.path.basename(full_name)
if name == '__init__': if name == '__init__':
return None return None
if extensions and file_ext not in extensions:
return None
if name.startswith('_'): if name.startswith('_'):
name = name[1:] name = name[1:]

Loading…
Cancel
Save