From 83c79bc89d5f451ff835ad2b57e36e2a4b0e29b2 Mon Sep 17 00:00:00 2001 From: Renat Akhmerov Date: Mon, 30 Jun 2014 16:01:54 +0700 Subject: [PATCH] Fixing Mistral HTTP action to take care of empty headers Change-Id: I420ba7ca4a14118d397440db6e2629dec539aee8 Closes-bug: #1335769 --- AUTHORS | 13 ++++++-- mistral/actions/std_actions.py | 1 + .../tests/unit/actions/test_action_factory.py | 32 ++++++++++++++++--- 3 files changed, 40 insertions(+), 6 deletions(-) diff --git a/AUTHORS b/AUTHORS index 32ce1cb38..761b75a22 100644 --- a/AUTHORS +++ b/AUTHORS @@ -1,4 +1,13 @@ -Renat Akhmerov -Nikolay Makhotkin Alexander Kuznetsov +Angus Salkeld +Dmitri Zimine +Kirill Izotov +Manas Kelshikar +Nikolay Mahotkin +Renat Akhmerov +Sergey Kolekonov +Sergey Murashov +Timur Nurlygayanov +Winson Chan + diff --git a/mistral/actions/std_actions.py b/mistral/actions/std_actions.py index 278a41d6d..6c8dca93f 100644 --- a/mistral/actions/std_actions.py +++ b/mistral/actions/std_actions.py @@ -163,6 +163,7 @@ class MistralHTTPAction(HTTPAction): timeout=None, allow_redirects=None, proxies=None): + headers = headers or {} headers.update({ 'Mistral-Workbook-Name': action_context['workbook_name'], 'Mistral-Execution-Id': action_context['execution_id'], diff --git a/mistral/tests/unit/actions/test_action_factory.py b/mistral/tests/unit/actions/test_action_factory.py index bf71037ae..b6c5d4a86 100644 --- a/mistral/tests/unit/actions/test_action_factory.py +++ b/mistral/tests/unit/actions/test_action_factory.py @@ -150,14 +150,38 @@ class ActionFactoryTest(base.BaseTest): self.assertEqual(task_params['headers'], action.headers) self.assertDictEqual(task_params['body'], json.loads(action.body)) - headers = task_params['headers'] + self.assertEqual(db_task['workbook_name'], + action.headers['Mistral-Workbook-Name']) + self.assertEqual(db_task['execution_id'], + action.headers['Mistral-Execution-Id']) + self.assertEqual(db_task['id'], + action.headers['Mistral-Task-Id']) + + def test_create_mistral_http_action_with_no_headers(self): + db_task = copy.copy(DB_TASK) + db_task['task_spec']['action'] = 'std.mistral_http' + + del db_task['parameters']['headers'] + + action = a_f.create_action(db_task) + + self.assertIsNotNone(action) + + task_params = db_task['parameters'] + + self.assertEqual(task_params['url'], action.url) + self.assertDictEqual(task_params['params'], action.params) + self.assertEqual(task_params['method'], action.method) + self.assertDictEqual(task_params['body'], json.loads(action.body)) + + self.assertIsNotNone(action.headers) self.assertEqual(db_task['workbook_name'], - headers['Mistral-Workbook-Name']) + action.headers['Mistral-Workbook-Name']) self.assertEqual(db_task['execution_id'], - headers['Mistral-Execution-Id']) + action.headers['Mistral-Execution-Id']) self.assertEqual(db_task['id'], - headers['Mistral-Task-Id']) + action.headers['Mistral-Task-Id']) def test_create_adhoc_action_with_openstack_context(self): db_task = copy.copy(DB_TASK_ADHOC)