mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
improve changed result for race conditions
This commit is contained in:
parent
0c2e376d5e
commit
f79c9fb6ce
1 changed files with 16 additions and 6 deletions
|
@ -182,10 +182,11 @@ def create_monitor(api, monitor, template_attributes):
|
||||||
api.LocalLB.Monitor.create_template(templates=[{'template_name': monitor, 'template_type': TEMPLATE_TYPE}], template_attributes=[template_attributes])
|
api.LocalLB.Monitor.create_template(templates=[{'template_name': monitor, 'template_type': TEMPLATE_TYPE}], template_attributes=[template_attributes])
|
||||||
except bigsuds.OperationFailed, e:
|
except bigsuds.OperationFailed, e:
|
||||||
if "already exists" in str(e):
|
if "already exists" in str(e):
|
||||||
pass
|
return False
|
||||||
else:
|
else:
|
||||||
# genuine exception
|
# genuine exception
|
||||||
raise
|
raise
|
||||||
|
return True
|
||||||
|
|
||||||
|
|
||||||
def delete_monitor(api, monitor):
|
def delete_monitor(api, monitor):
|
||||||
|
@ -194,9 +195,12 @@ def delete_monitor(api, monitor):
|
||||||
api.LocalLB.Monitor.delete_template(template_names=[monitor])
|
api.LocalLB.Monitor.delete_template(template_names=[monitor])
|
||||||
except bigsuds.OperationFailed, e:
|
except bigsuds.OperationFailed, e:
|
||||||
# maybe it was deleted since we checked
|
# maybe it was deleted since we checked
|
||||||
if not "was not found" in str(e):
|
if "was not found" in str(e):
|
||||||
|
return False
|
||||||
|
else:
|
||||||
# genuine exception
|
# genuine exception
|
||||||
raise
|
raise
|
||||||
|
return True
|
||||||
|
|
||||||
def check_string_property(api, monitor, str_property):
|
def check_string_property(api, monitor, str_property):
|
||||||
|
|
||||||
|
@ -307,8 +311,11 @@ def main():
|
||||||
if state == 'absent':
|
if state == 'absent':
|
||||||
if monitor_exists:
|
if monitor_exists:
|
||||||
if not module.check_mode:
|
if not module.check_mode:
|
||||||
delete_monitor(api, monitor)
|
# possible race condition if same task
|
||||||
result['changed'] = True
|
# on other node deleted it first
|
||||||
|
result['changed'] = delete_monitor(api, monitor)
|
||||||
|
else:
|
||||||
|
result['changed'] = True
|
||||||
|
|
||||||
else:
|
else:
|
||||||
ipport = {'address_type': address_type,
|
ipport = {'address_type': address_type,
|
||||||
|
@ -353,10 +360,13 @@ def main():
|
||||||
result['changed'] = True
|
result['changed'] = True
|
||||||
|
|
||||||
elif not module.check_mode:
|
elif not module.check_mode:
|
||||||
create_monitor(api, monitor, template_attributes)
|
# possible race condition if same task
|
||||||
|
# on other node deleted it first
|
||||||
|
result['changed'] = create_monitor(api, monitor, template_attributes)
|
||||||
for str_property in template_string_properties:
|
for str_property in template_string_properties:
|
||||||
set_string_property(api, monitor, str_property)
|
set_string_property(api, monitor, str_property)
|
||||||
result['changed'] = True
|
for int_property in template_integer_properties:
|
||||||
|
set_integer_property(api, monitor, int_property)
|
||||||
else: # monitor does not exist and check mode
|
else: # monitor does not exist and check mode
|
||||||
result['changed'] = True
|
result['changed'] = True
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue