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:
Artom Lifshitz 2024-08-30 09:56:16 -04:00
parent b65b7d4d3e
commit 2ea501c069

View File

@ -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)