|
|
|
@ -36,73 +36,73 @@ class TestOvercloudUpdatePrepare(fakes.TestOvercloudUpdatePrepare):
|
|
|
|
|
self.mock_uuid4 = uuid4_patcher.start()
|
|
|
|
|
self.addCleanup(self.mock_uuid4.stop)
|
|
|
|
|
|
|
|
|
|
@mock.patch('tripleoclient.v1.overcloud_deploy.DeployOvercloud.'
|
|
|
|
|
'_get_ctlplane_attrs', autospec=True, return_value={})
|
|
|
|
|
@mock.patch('tripleoclient.utils.ensure_run_as_normal_user')
|
|
|
|
|
@mock.patch('tripleoclient.utils.prompt_user_for_confirmation',
|
|
|
|
|
return_value=True)
|
|
|
|
|
@mock.patch('tripleoclient.v1.overcloud_deploy.DeployOvercloud.'
|
|
|
|
|
'_get_undercloud_host_entry', autospec=True,
|
|
|
|
|
return_value='192.168.0.1 uc.ctlplane.localhost uc.ctlplane')
|
|
|
|
|
@mock.patch('tripleoclient.v1.overcloud_update.UpdatePrepare.log',
|
|
|
|
|
autospec=True)
|
|
|
|
|
@mock.patch('six.moves.builtins.open')
|
|
|
|
|
@mock.patch('os.path.abspath')
|
|
|
|
|
@mock.patch('yaml.safe_load')
|
|
|
|
|
@mock.patch('shutil.copytree', autospec=True)
|
|
|
|
|
@mock.patch('six.moves.builtins.open')
|
|
|
|
|
@mock.patch('tripleoclient.v1.overcloud_deploy.DeployOvercloud.'
|
|
|
|
|
'take_action', autospec=True)
|
|
|
|
|
def test_update_out(self, mock_deploy, mock_open, mock_copy, mock_yaml,
|
|
|
|
|
mock_abspath, mock_logger,
|
|
|
|
|
mock_get_undercloud_host_entry,
|
|
|
|
|
mock_confirm, mock_usercheck,
|
|
|
|
|
mock_get_ctlplane_attrs):
|
|
|
|
|
def test_update_failed(self, mock_deploy, mock_copy, mock_yaml,
|
|
|
|
|
mock_abspath, mock_open,
|
|
|
|
|
mock_confirm, mock_usercheck):
|
|
|
|
|
mock_deploy.side_effect = exceptions.DeploymentError()
|
|
|
|
|
mock_yaml.return_value = {'fake_container': 'fake_value'}
|
|
|
|
|
|
|
|
|
|
argslist = ['--stack', 'overcloud', '--templates']
|
|
|
|
|
|
|
|
|
|
argslist = ['--stack', 'overcloud', '--templates', ]
|
|
|
|
|
verifylist = [
|
|
|
|
|
('stack', 'overcloud'),
|
|
|
|
|
('templates', constants.TRIPLEO_HEAT_TEMPLATES),
|
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
parsed_args = self.check_parser(self.cmd, argslist, verifylist)
|
|
|
|
|
|
|
|
|
|
with mock.patch('os.path.exists') as mock_exists, \
|
|
|
|
|
mock.patch('os.path.isfile') as mock_isfile:
|
|
|
|
|
mock_exists.return_value = True
|
|
|
|
|
mock_isfile.return_value = True
|
|
|
|
|
self.cmd.take_action(parsed_args)
|
|
|
|
|
self.assertRaises(exceptions.DeploymentError,
|
|
|
|
|
self.cmd.take_action, parsed_args)
|
|
|
|
|
mock_usercheck.assert_called_once()
|
|
|
|
|
mock_deploy.assert_called_once()
|
|
|
|
|
|
|
|
|
|
@mock.patch('tripleoclient.utils.get_ctlplane_attrs', autospec=True,
|
|
|
|
|
return_value={})
|
|
|
|
|
@mock.patch('tripleoclient.utils.ensure_run_as_normal_user')
|
|
|
|
|
@mock.patch('tripleoclient.utils.prompt_user_for_confirmation',
|
|
|
|
|
return_value=True)
|
|
|
|
|
@mock.patch('six.moves.builtins.open')
|
|
|
|
|
@mock.patch('tripleoclient.v1.overcloud_deploy.DeployOvercloud.'
|
|
|
|
|
'_get_undercloud_host_entry', autospec=True,
|
|
|
|
|
return_value='192.168.0.1 uc.ctlplane.localhost uc.ctlplane')
|
|
|
|
|
@mock.patch('tripleoclient.v1.overcloud_update.UpdatePrepare.log',
|
|
|
|
|
autospec=True)
|
|
|
|
|
@mock.patch('os.path.abspath')
|
|
|
|
|
@mock.patch('yaml.safe_load')
|
|
|
|
|
@mock.patch('shutil.copytree', autospec=True)
|
|
|
|
|
@mock.patch('six.moves.builtins.open')
|
|
|
|
|
@mock.patch('tripleoclient.v1.overcloud_deploy.DeployOvercloud.'
|
|
|
|
|
'take_action', autospec=True)
|
|
|
|
|
def test_update_failed(self, mock_deploy, mock_copy, mock_yaml,
|
|
|
|
|
mock_abspath, mock_open,
|
|
|
|
|
mock_confirm, mock_usercheck):
|
|
|
|
|
mock_deploy.side_effect = exceptions.DeploymentError()
|
|
|
|
|
def test_update_out(self, mock_deploy, mock_open, mock_copy, mock_yaml,
|
|
|
|
|
mock_abspath, mock_logger,
|
|
|
|
|
mock_get_undercloud_host_entry,
|
|
|
|
|
mock_confirm, mock_usercheck,
|
|
|
|
|
mock_get_ctlplane_attrs):
|
|
|
|
|
mock_yaml.return_value = {'fake_container': 'fake_value'}
|
|
|
|
|
argslist = ['--stack', 'overcloud', '--templates', ]
|
|
|
|
|
|
|
|
|
|
argslist = ['--stack', 'overcloud', '--templates']
|
|
|
|
|
|
|
|
|
|
verifylist = [
|
|
|
|
|
('stack', 'overcloud'),
|
|
|
|
|
('templates', constants.TRIPLEO_HEAT_TEMPLATES),
|
|
|
|
|
]
|
|
|
|
|
parsed_args = self.check_parser(self.cmd, argslist, verifylist)
|
|
|
|
|
|
|
|
|
|
parsed_args = self.check_parser(self.cmd, argslist, verifylist)
|
|
|
|
|
with mock.patch('os.path.exists') as mock_exists, \
|
|
|
|
|
mock.patch('os.path.isfile') as mock_isfile:
|
|
|
|
|
mock_exists.return_value = True
|
|
|
|
|
mock_isfile.return_value = True
|
|
|
|
|
self.assertRaises(exceptions.DeploymentError,
|
|
|
|
|
self.cmd.take_action, parsed_args)
|
|
|
|
|
self.cmd.take_action(parsed_args)
|
|
|
|
|
mock_usercheck.assert_called_once()
|
|
|
|
|
mock_deploy.assert_called_once()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class TestOvercloudUpdateRun(fakes.TestOvercloudUpdateRun):
|
|
|
|
|