stack event loops: handle get None result
We've seen at least one case in CI of `stack` being None when polling for stack events: <snip> File "openstack/cloud/_orchestration.py", line 185, in delete_stack event_utils.poll_for_events( File "openstack/orchestration/util/event_utils.py", line 109, in poll_for_events stack_status = stack['stack_status'] TypeError: 'NoneType' object is not subscriptable Handle this case with a simple if. Change-Id: Icce6e7b600125cf98e56d98e1c3df4177414398b
This commit is contained in:
parent
b65b7d4d3e
commit
2ea501c069
@ -106,11 +106,12 @@ def poll_for_events(
|
|||||||
if no_event_polls >= 2:
|
if no_event_polls >= 2:
|
||||||
# after 2 polls with no events, fall back to a stack get
|
# after 2 polls with no events, fall back to a stack get
|
||||||
stack = cloud.get_stack(stack_name, resolve_outputs=False)
|
stack = cloud.get_stack(stack_name, resolve_outputs=False)
|
||||||
stack_status = stack['stack_status']
|
if stack:
|
||||||
msg = msg_template % dict(name=stack_name, status=stack_status)
|
stack_status = stack['stack_status']
|
||||||
if stop_check(stack_status):
|
msg = msg_template % dict(name=stack_name, status=stack_status)
|
||||||
return stack_status, msg
|
if stop_check(stack_status):
|
||||||
# go back to event polling again
|
return stack_status, msg
|
||||||
no_event_polls = 0
|
# go back to event polling again
|
||||||
|
no_event_polls = 0
|
||||||
|
|
||||||
time.sleep(poll_period)
|
time.sleep(poll_period)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user