From 9caaf7b109ddb5e23473a64d39a4fc399217f664 Mon Sep 17 00:00:00 2001 From: Felix Fontein Date: Mon, 26 Nov 2018 14:53:01 +0100 Subject: [PATCH] docker_container: fix init option idempotency with old docker-py versions (#49078) * Don't check options for idempotency which are not supported. This check should be superfluous if every option would adhere to the convention that options not specified should have value None. Unfortunately, some options (such as init) which correspond to container properties have an explicit default set. --- .../fragments/49078-docker_container-min-version-fix.yml | 3 +++ lib/ansible/modules/cloud/docker/docker_container.py | 7 +++++-- 2 files changed, 8 insertions(+), 2 deletions(-) create mode 100644 changelogs/fragments/49078-docker_container-min-version-fix.yml diff --git a/changelogs/fragments/49078-docker_container-min-version-fix.yml b/changelogs/fragments/49078-docker_container-min-version-fix.yml new file mode 100644 index 0000000000..1d788f0738 --- /dev/null +++ b/changelogs/fragments/49078-docker_container-min-version-fix.yml @@ -0,0 +1,3 @@ +bugfixes: +- "docker_container - fix idempotency problems with docker-py caused by previous ``init`` idempotency fix." +- "docker_container - fix interplay of docker-py version check with argument_spec validation improvements." diff --git a/lib/ansible/modules/cloud/docker/docker_container.py b/lib/ansible/modules/cloud/docker/docker_container.py index 2b6c42dc33..4254b16a44 100644 --- a/lib/ansible/modules/cloud/docker/docker_container.py +++ b/lib/ansible/modules/cloud/docker/docker_container.py @@ -1854,6 +1854,9 @@ class Container(DockerBaseClass): differences = DifferenceTracker() for key, value in config_mapping.items(): + minimal_version = self.parameters.client.option_minimal_versions.get(key, {}) + if not minimal_version.get('supported', True): + continue compare = self.parameters.client.comparisons[self.parameters_map.get(key, key)] self.log('check differences %s %s vs %s (%s)' % (key, getattr(self.parameters, key), str(value), compare)) if getattr(self.parameters, key, None) is not None: @@ -2290,7 +2293,7 @@ class ContainerManager(DockerBaseClass): if image_different: self.diff['image_different'] = True self.log("differences") - self.log(differences, pretty_print=True) + self.log(differences.get_legacy_docker_container_diffs(), pretty_print=True) image_to_use = self.parameters.image if not image_to_use and container and container.Image: image_to_use = container.Image @@ -2740,7 +2743,7 @@ class AnsibleDockerClientContainer(AnsibleDockerClient): # Helper function to detect whether any specified network uses ipv4_address or ipv6_address def detect_ipvX_address_usage(): for network in self.module.params.get("networks") or []: - if 'ipv4_address' in network or 'ipv6_address' in network: + if network.get('ipv4_address') is not None or network.get('ipv6_address') is not None: return True return False