
Problemo: Exception thrown if empty context is passed Fix: Make sure context key is not created if context variable is None Unit test added. Closes-Bug: #1286373 Change-Id: I8ab5691fd34ab98c6fd99fbd35281b5179bb0dd5
122 lines
4.2 KiB
Python
122 lines
4.2 KiB
Python
# -*- coding: utf-8 -*-
|
|
#
|
|
# Copyright 2013 - Mirantis, Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
import unittest2
|
|
|
|
from mistralclient.tests import base
|
|
|
|
# TODO: Later we need additional tests verifying all the errors etc.
|
|
|
|
EXECS = [
|
|
{
|
|
'id': "123",
|
|
'workbook_name': "my_workbook",
|
|
'target_task': 'my_task',
|
|
'state': 'RUNNING',
|
|
'context': """
|
|
{
|
|
"person": {
|
|
"first_name": "John",
|
|
"last_name": "Doe"
|
|
}
|
|
}
|
|
"""
|
|
}
|
|
]
|
|
|
|
|
|
class TestExecutions(base.BaseClientTest):
|
|
def test_create(self):
|
|
self.mock_http_post(json=EXECS[0])
|
|
|
|
ex = self.executions.create(EXECS[0]['workbook_name'],
|
|
EXECS[0]['target_task'],
|
|
EXECS[0]['context'])
|
|
|
|
self.assertIsNotNone(ex)
|
|
self.assertEqual(EXECS[0]['id'], ex.id)
|
|
self.assertEqual(EXECS[0]['workbook_name'], ex.workbook_name)
|
|
self.assertEqual(EXECS[0]['target_task'], ex.target_task)
|
|
self.assertEqual(EXECS[0]['state'], ex.state)
|
|
self.assertEqual(EXECS[0]['context'], ex.context)
|
|
|
|
def test_create_with_empty_context(self):
|
|
execs = EXECS[0].copy()
|
|
execs.pop('context')
|
|
self.mock_http_post(json=execs)
|
|
ex = self.executions.create(execs['workbook_name'],
|
|
execs['target_task'])
|
|
with self.assertRaises(AttributeError):
|
|
ex.context
|
|
|
|
@unittest2.expectedFailure
|
|
def test_create_failure1(self):
|
|
self.executions.create(EXECS[0]['workbook_name'],
|
|
EXECS[0]['target_task'],
|
|
"sdfsdf")
|
|
|
|
@unittest2.expectedFailure
|
|
def test_create_failure2(self):
|
|
self.executions.create(EXECS[0]['workbook_name'],
|
|
EXECS[0]['target_task'],
|
|
list('343', 'sdfsd'))
|
|
|
|
def test_update(self):
|
|
self.mock_http_put(json=EXECS[0])
|
|
|
|
ex = self.executions.update(EXECS[0]['workbook_name'],
|
|
EXECS[0]['id'],
|
|
EXECS[0]['state'])
|
|
|
|
self.assertIsNotNone(ex)
|
|
self.assertEqual(EXECS[0]['id'], ex.id)
|
|
self.assertEqual(EXECS[0]['workbook_name'], ex.workbook_name)
|
|
self.assertEqual(EXECS[0]['target_task'], ex.target_task)
|
|
self.assertEqual(EXECS[0]['state'], ex.state)
|
|
self.assertEqual(EXECS[0]['context'], ex.context)
|
|
|
|
def test_list(self):
|
|
self.mock_http_get(json={'executions': EXECS})
|
|
|
|
executions = self.executions.list(EXECS[0]['workbook_name'])
|
|
|
|
self.assertEqual(1, len(executions))
|
|
|
|
ex = executions[0]
|
|
|
|
self.assertEqual(EXECS[0]['id'], ex.id)
|
|
self.assertEqual(EXECS[0]['workbook_name'], ex.workbook_name)
|
|
self.assertEqual(EXECS[0]['target_task'], ex.target_task)
|
|
self.assertEqual(EXECS[0]['state'], ex.state)
|
|
self.assertEqual(EXECS[0]['context'], ex.context)
|
|
|
|
def test_get(self):
|
|
self.mock_http_get(json=EXECS[0])
|
|
|
|
ex = self.executions.get(EXECS[0]['workbook_name'], EXECS[0]['id'])
|
|
|
|
self.assertEqual(EXECS[0]['id'], ex.id)
|
|
self.assertEqual(EXECS[0]['workbook_name'], ex.workbook_name)
|
|
self.assertEqual(EXECS[0]['target_task'], ex.target_task)
|
|
self.assertEqual(EXECS[0]['state'], ex.state)
|
|
self.assertEqual(EXECS[0]['context'], ex.context)
|
|
|
|
def test_delete(self):
|
|
self.mock_http_delete(status_code=204)
|
|
|
|
# Just make sure it doesn't throw any exceptions.
|
|
self.executions.delete(EXECS[0]['workbook_name'], EXECS[0]['id'])
|