From c3a76007d0821bed5c04dbc54aaff8d849fbcdab Mon Sep 17 00:00:00 2001 From: Felix Fontein Date: Wed, 6 Jul 2022 21:48:22 +0200 Subject: [PATCH] Rewrite the docker_volume_info module (#412) * Rewrite the docker_volume_info module. * Improve error messages. --- changelogs/fragments/412-docker-api.yml | 4 ++++ plugins/modules/docker_volume_info.py | 21 +++++++------------ .../targets/docker_volume_info/tasks/main.yml | 5 ++--- 3 files changed, 13 insertions(+), 17 deletions(-) create mode 100644 changelogs/fragments/412-docker-api.yml diff --git a/changelogs/fragments/412-docker-api.yml b/changelogs/fragments/412-docker-api.yml new file mode 100644 index 000000000..9e729fb72 --- /dev/null +++ b/changelogs/fragments/412-docker-api.yml @@ -0,0 +1,4 @@ +major_changes: + - "docker_volume_info - no longer uses the Docker SDK for Python. It requires ``requests`` to be installed, + and depending on the features used has some more requirements. If the Docker SDK for Python is installed, + these requirements are likely met (https://github.com/ansible-collections/community.docker/pull/412)." diff --git a/plugins/modules/docker_volume_info.py b/plugins/modules/docker_volume_info.py index 2f9993a77..c60808e12 100644 --- a/plugins/modules/docker_volume_info.py +++ b/plugins/modules/docker_volume_info.py @@ -23,15 +23,14 @@ - volume_name extends_documentation_fragment: -- community.docker.docker -- community.docker.docker.docker_py_1_documentation +- community.docker.docker.api_documentation author: - Felix Fontein (@felixfontein) requirements: - - "L(Docker SDK for Python,https://docker-py.readthedocs.io/en/stable/) >= 1.8.0" + - "Docker API >= 1.25" ''' EXAMPLES = ''' @@ -78,21 +77,16 @@ from ansible.module_utils.common.text.converters import to_native -try: - from docker.errors import DockerException, NotFound -except ImportError: - # missing Docker SDK for Python handled in ansible.module_utils.docker.common - pass - -from ansible_collections.community.docker.plugins.module_utils.common import ( +from ansible_collections.community.docker.plugins.module_utils.common_api import ( AnsibleDockerClient, RequestException, ) +from ansible_collections.community.docker.plugins.module_utils._api.errors import DockerException, NotFound def get_existing_volume(client, volume_name): try: - return client.inspect_volume(volume_name) + return client.get_json('/volumes/{0}', volume_name) except NotFound as dummy: return None except Exception as exc: @@ -107,7 +101,6 @@ def main(): client = AnsibleDockerClient( argument_spec=argument_spec, supports_check_mode=True, - min_docker_version='1.8.0', ) try: @@ -119,10 +112,10 @@ def main(): volume=volume, ) except DockerException as e: - client.fail('An unexpected docker error occurred: {0}'.format(to_native(e)), exception=traceback.format_exc()) + client.fail('An unexpected Docker error occurred: {0}'.format(to_native(e)), exception=traceback.format_exc()) except RequestException as e: client.fail( - 'An unexpected requests error occurred when Docker SDK for Python tried to talk to the docker daemon: {0}'.format(to_native(e)), + 'An unexpected requests error occurred when trying to talk to the Docker daemon: {0}'.format(to_native(e)), exception=traceback.format_exc()) diff --git a/tests/integration/targets/docker_volume_info/tasks/main.yml b/tests/integration/targets/docker_volume_info/tasks/main.yml index 1ee580f89..e7007b72c 100644 --- a/tests/integration/targets/docker_volume_info/tasks/main.yml +++ b/tests/integration/targets/docker_volume_info/tasks/main.yml @@ -67,8 +67,7 @@ - "'is too new. Maximum supported API version is' in docker_volume_inspect.stderr" when: docker_volume_inspect is failed - # Requirements for docker_volume - when: docker_py_version is version('1.10.0', '>=') and docker_api_version is version('1.25', '>=') + when: docker_api_version is version('1.25', '>=') - fail: msg="Too old docker / docker-py version to run docker_volume_info tests!" - when: not(docker_py_version is version('1.10.0', '>=') and docker_api_version is version('1.25', '>=')) and (ansible_distribution != 'CentOS' or ansible_distribution_major_version|int > 6) + when: not(docker_api_version is version('1.25', '>=')) and (ansible_distribution != 'CentOS' or ansible_distribution_major_version|int > 6)