From d2de450e7f93dbb2533f37e13a481033ef4822a5 Mon Sep 17 00:00:00 2001 From: rabi Date: Fri, 11 Aug 2017 16:37:48 +0530 Subject: [PATCH] Fix race in ZaqarEventSinkTest.test_events Change-Id: I46378492a21c186de89b5af04e2d973432e38bff Closes-Bug: #1679969 --- .../functional/test_event_sinks.py | 37 ++++++++++++------- 1 file changed, 23 insertions(+), 14 deletions(-) diff --git a/heat_integrationtests/functional/test_event_sinks.py b/heat_integrationtests/functional/test_event_sinks.py index 5d9f566bea..a7e75795af 100644 --- a/heat_integrationtests/functional/test_event_sinks.py +++ b/heat_integrationtests/functional/test_event_sinks.py @@ -14,6 +14,7 @@ import uuid from zaqarclient.queues.v1 import client as zaqarclient +from heat_integrationtests.common import test from heat_integrationtests.functional import functional_base @@ -54,17 +55,25 @@ resources: zaqar = zaqarclient.Client(conf=conf, version=1.1) queue = zaqar.queue(queue_id) - messages = list(queue.messages()) - self.assertEqual(4, len(messages)) - types = [m.body['type'] for m in messages] - self.assertEqual(['os.heat.event'] * 4, types) - resources = set([m.body['payload']['resource_name'] for m in messages]) - self.assertEqual(set([stack_name, 'test_resource']), resources) - stack_ids = [m.body['payload']['stack_id'] for m in messages] - self.assertEqual([stack_id] * 4, stack_ids) - statuses = [m.body['payload']['resource_status'] for m in messages] - statuses.sort() - self.assertEqual( - ['COMPLETE', 'COMPLETE', 'IN_PROGRESS', 'IN_PROGRESS'], statuses) - actions = [m.body['payload']['resource_action'] for m in messages] - self.assertEqual(['CREATE'] * 4, actions) + + def validate_messages(): + messages = list(queue.messages()) + if len(messages) < 4: + return False + + types = [m.body['type'] for m in messages] + self.assertEqual(['os.heat.event'] * 4, types) + resources = set([m.body['payload'][ + 'resource_name'] for m in messages]) + self.assertEqual(set([stack_name, 'test_resource']), resources) + stack_ids = [m.body['payload']['stack_id'] for m in messages] + self.assertEqual([stack_id] * 4, stack_ids) + statuses = [m.body['payload']['resource_status'] for m in messages] + statuses.sort() + self.assertEqual(['COMPLETE', 'COMPLETE', + 'IN_PROGRESS', 'IN_PROGRESS'], statuses) + actions = [m.body['payload']['resource_action'] for m in messages] + self.assertEqual(['CREATE'] * 4, actions) + return True + + self.assertTrue(test.call_until_true(20, 0, validate_messages))