docker_service: parse scale parameter correctly to 2.7 (#47239)
* fix: Parse docker_service scale parameter to int (#45508) * Changelog: add fragment for docker_service scale fix
This commit is contained in:
parent
429c8f50fe
commit
28ed7f722e
2 changed files with 13 additions and 3 deletions
|
@ -0,0 +1,2 @@
|
|||
bugfixes:
|
||||
- docker_service - correctly parse string values for the `scale` parameter https://github.com/ansible/ansible/pull/45508
|
|
@ -1009,17 +1009,25 @@ class ContainerManager(DockerBaseClass):
|
|||
scale=0
|
||||
)
|
||||
containers = service.containers(stopped=True)
|
||||
if len(containers) != self.scale[service.name]:
|
||||
scale = self.parse_scale(service.name)
|
||||
if len(containers) != scale:
|
||||
result['changed'] = True
|
||||
service_res['scale'] = self.scale[service.name] - len(containers)
|
||||
service_res['scale'] = scale - len(containers)
|
||||
if not self.check_mode:
|
||||
try:
|
||||
service.scale(int(self.scale[service.name]))
|
||||
service.scale(scale)
|
||||
except Exception as exc:
|
||||
self.client.fail("Error scaling %s - %s" % (service.name, str(exc)))
|
||||
result['actions'].append(service_res)
|
||||
return result
|
||||
|
||||
def parse_scale(self, service_name):
|
||||
try:
|
||||
return int(self.scale[service_name])
|
||||
except ValueError:
|
||||
self.client.fail("Error scaling %s - expected int, got %s",
|
||||
service_name, str(type(self.scale[service_name])))
|
||||
|
||||
|
||||
def main():
|
||||
argument_spec = dict(
|
||||
|
|
Loading…
Reference in a new issue