python-tripleoclient/tripleoclient/tests/v1/test_overcloud_raid.py
Kevin Carter 6d56817524
Remove the mistral from the create_raid_configuration workflow
This change removes all of mistral from the create_raid_configuration
workflows by calling the new cleaning playbook.

Story: 2007212
Task: 38449

Depends-On: I51b1977b53995c93eb661f9ffa6d7cbad033ab75
Change-Id: If2f894316c3369432b16e07d68beee3a7d174b6a
Signed-off-by: Kevin Carter <kecarter@redhat.com>
2020-03-10 07:44:36 -05:00

127 lines
4.3 KiB
Python

# 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 json
import mock
import tempfile
from osc_lib.tests import utils as test_utils
from tripleoclient.tests.v1.baremetal import fakes
from tripleoclient.v1 import overcloud_raid
class TestCreateRAID(fakes.TestBaremetal):
def setUp(self):
super(TestCreateRAID, self).setUp()
self.cmd = overcloud_raid.CreateRAID(self.app, None)
self.workflow = self.app.client_manager.workflow_engine
self.conf = {
"logical_disks": [
{"foo": "bar"},
{"foo2": "bar2"}
]
}
tripleoclient = self.app.client_manager.tripleoclient
websocket = tripleoclient.messaging_websocket()
websocket.wait_for_messages.return_value = iter([
{'status': "SUCCESS",
'execution_id': 'IDID'}
])
self.websocket = websocket
execution = mock.MagicMock(
output=json.dumps({
"result": None
})
)
execution.id = "IDID"
self.workflow.executions.create.return_value = execution
playbook_runner = mock.patch(
'tripleoclient.utils.run_ansible_playbook',
autospec=True
)
playbook_runner.start()
self.addCleanup(playbook_runner.stop)
def test_ok(self):
conf = json.dumps(self.conf)
arglist = ['--node', 'uuid1', '--node', 'uuid2', conf]
verifylist = [
('node', ['uuid1', 'uuid2']),
('configuration', conf)
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
self.cmd.take_action(parsed_args)
def test_from_file(self):
with tempfile.NamedTemporaryFile('w+t') as fp:
json.dump(self.conf, fp)
fp.flush()
arglist = ['--node', 'uuid1', '--node', 'uuid2', fp.name]
verifylist = [
('node', ['uuid1', 'uuid2']),
('configuration', fp.name)
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
self.cmd.take_action(parsed_args)
def test_no_nodes(self):
arglist = ['{}']
verifylist = [
('configuration', '{}')
]
self.assertRaises(test_utils.ParserException, self.check_parser,
self.cmd, arglist, verifylist)
self.assertFalse(self.workflow.executions.create.called)
def test_not_yaml(self):
arglist = ['--node', 'uuid1', '--node', 'uuid2', ':']
verifylist = [
('node', ['uuid1', 'uuid2']),
('configuration', ':')
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
self.assertRaisesRegex(RuntimeError, 'cannot be parsed as YAML',
self.cmd.take_action, parsed_args)
self.assertFalse(self.workflow.executions.create.called)
def test_bad_type(self):
for conf in ('[]', '{logical_disks: 42}', '{logical_disks: [42]}'):
arglist = ['--node', 'uuid1', '--node', 'uuid2', conf]
verifylist = [
('node', ['uuid1', 'uuid2']),
('configuration', conf)
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
self.assertRaises(TypeError, self.cmd.take_action, parsed_args)
self.assertFalse(self.workflow.executions.create.called)
def test_bad_value(self):
conf = '{another_key: [{}]}'
arglist = ['--node', 'uuid1', '--node', 'uuid2', conf]
verifylist = [
('node', ['uuid1', 'uuid2']),
('configuration', conf)
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
self.assertRaises(ValueError, self.cmd.take_action, parsed_args)
self.assertFalse(self.workflow.executions.create.called)