mirror of https://github.com/ceph/ceph-ansible.git
ceph_pool: add idempotency to absent state
When using the "absent" state on a non existing pool then the ceph_pool module will fail and return a python traceback. Instead we should check if the pool exit or not and execute the pool deletion according to the result. The state changed is now set when the pool is actually deleted. This also disable add_file_common_args because we don't manipulate files with this module. Signed-off-by: Dimitri Savineau <dsavinea@redhat.com>pull/5846/head
parent
4808523403
commit
047a3e2653
|
@ -475,7 +475,6 @@ def run_module():
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=module_args,
|
argument_spec=module_args,
|
||||||
supports_check_mode=True,
|
supports_check_mode=True,
|
||||||
add_file_common_args=True,
|
|
||||||
)
|
)
|
||||||
|
|
||||||
# Gather module parameters in variables
|
# Gather module parameters in variables
|
||||||
|
@ -597,7 +596,13 @@ def run_module():
|
||||||
out = "Couldn't list pool(s) present on the cluster"
|
out = "Couldn't list pool(s) present on the cluster"
|
||||||
|
|
||||||
elif state == "absent":
|
elif state == "absent":
|
||||||
rc, cmd, out, err = exec_commands(module, remove_pool(cluster, name, user, user_key, container_image=container_image))
|
rc, cmd, out, err = exec_commands(module, check_pool_exist(cluster, name, user, user_key, container_image=container_image))
|
||||||
|
if rc == 0:
|
||||||
|
rc, cmd, out, err = exec_commands(module, remove_pool(cluster, name, user, user_key, container_image=container_image))
|
||||||
|
changed = True
|
||||||
|
else:
|
||||||
|
rc = 0
|
||||||
|
out = "Skipped, since pool {} doesn't exist".format(name)
|
||||||
|
|
||||||
|
|
||||||
exit_module(module=module, out=out, rc=rc, cmd=cmd, err=err, startd=startd, changed=changed)
|
exit_module(module=module, out=out, rc=rc, cmd=cmd, err=err, startd=startd, changed=changed)
|
||||||
|
|
Loading…
Reference in New Issue