Remove redundancy in _launch_ansible* methods.
This patch tries to reuse the same function _launch_ansible for the multiple ansible executions in tripleo_deploy.py by passing a list with the arguments to be used by the ansible-playbook command. Change-Id: Iad2c9b82478ae05d68fcfd5880270105c68abefb
This commit is contained in:
parent
828cfe02bb
commit
28702d18be
@ -86,3 +86,15 @@ CTLPLANE_DHCP_START_DEFAULT = ['192.168.24.5']
|
|||||||
CTLPLANE_DHCP_END_DEFAULT = ['192.168.24.24']
|
CTLPLANE_DHCP_END_DEFAULT = ['192.168.24.24']
|
||||||
CTLPLANE_INSPECTION_IPRANGE_DEFAULT = '192.168.24.100,192.168.24.120'
|
CTLPLANE_INSPECTION_IPRANGE_DEFAULT = '192.168.24.100,192.168.24.120'
|
||||||
CTLPLANE_GATEWAY_DEFAULT = '192.168.24.1'
|
CTLPLANE_GATEWAY_DEFAULT = '192.168.24.1'
|
||||||
|
|
||||||
|
# Ansible parameters used for the actions being
|
||||||
|
# executed during tripleo deploy/upgrade.
|
||||||
|
DEPLOY_ANSIBLE_ACTIONS = {
|
||||||
|
'deploy': 'deploy_steps_playbook.yaml',
|
||||||
|
'upgrade': 'upgrade_steps_playbook.yaml --skip-tags '
|
||||||
|
'validation',
|
||||||
|
'post-upgrade': 'post_upgrade_steps_playbook.yaml '
|
||||||
|
'--skip-tags validation',
|
||||||
|
'online-upgrade': 'external_upgrade_steps_playbook.yaml '
|
||||||
|
'--tags online_upgrade',
|
||||||
|
}
|
||||||
|
@ -841,12 +841,32 @@ class TestDeployUndercloud(TestPluginV1):
|
|||||||
@mock.patch('os.execvp')
|
@mock.patch('os.execvp')
|
||||||
def test_launch_ansible_deploy(self, mock_execvp, mock_chdir, mock_run):
|
def test_launch_ansible_deploy(self, mock_execvp, mock_chdir, mock_run):
|
||||||
|
|
||||||
self.cmd._launch_ansible_deploy('/tmp')
|
self.cmd._launch_ansible('/tmp')
|
||||||
mock_chdir.assert_called_once()
|
mock_chdir.assert_called_once()
|
||||||
mock_run.assert_called_once_with(self.cmd.log, [
|
mock_run.assert_called_once_with(self.cmd.log, [
|
||||||
self.ansible_playbook_cmd, '-i', '/tmp/inventory.yaml',
|
self.ansible_playbook_cmd, '-i', '/tmp/inventory.yaml',
|
||||||
'deploy_steps_playbook.yaml'])
|
'deploy_steps_playbook.yaml'])
|
||||||
|
|
||||||
|
@mock.patch('tripleoclient.utils.'
|
||||||
|
'run_command_and_log', autospec=True)
|
||||||
|
@mock.patch('os.chdir')
|
||||||
|
@mock.patch('os.execvp')
|
||||||
|
def test_launch_ansible_with_args(self, mock_execvp, mock_chdir, mock_run):
|
||||||
|
|
||||||
|
args = ['deploy_steps_playbook.yaml', '--skip-tags',
|
||||||
|
'validation']
|
||||||
|
self.cmd._launch_ansible('/tmp', args, operation='deploy')
|
||||||
|
mock_chdir.assert_called_once()
|
||||||
|
mock_run.assert_called_once_with(self.cmd.log, [
|
||||||
|
self.ansible_playbook_cmd, '-i', '/tmp/inventory.yaml',
|
||||||
|
'deploy_steps_playbook.yaml', '--skip-tags', 'validation'])
|
||||||
|
|
||||||
|
@mock.patch('os.execvp')
|
||||||
|
def test_launch_ansible_invalid_op(self, mock_execvp):
|
||||||
|
|
||||||
|
self.assertRaises(exceptions.DeploymentError, self.cmd._launch_ansible,
|
||||||
|
'/tmp', operation='unploy')
|
||||||
|
|
||||||
@mock.patch('tripleo_common.image.kolla_builder.'
|
@mock.patch('tripleo_common.image.kolla_builder.'
|
||||||
'container_images_prepare_multi')
|
'container_images_prepare_multi')
|
||||||
def test_prepare_container_images(self, mock_cipm):
|
def test_prepare_container_images(self, mock_cipm):
|
||||||
@ -884,7 +904,7 @@ class TestDeployUndercloud(TestPluginV1):
|
|||||||
@mock.patch('tripleoclient.v1.tripleo_deploy.Deploy.'
|
@mock.patch('tripleoclient.v1.tripleo_deploy.Deploy.'
|
||||||
'_create_install_artifact', return_value='/tmp/foo.tar.bzip2')
|
'_create_install_artifact', return_value='/tmp/foo.tar.bzip2')
|
||||||
@mock.patch('tripleoclient.v1.tripleo_deploy.Deploy.'
|
@mock.patch('tripleoclient.v1.tripleo_deploy.Deploy.'
|
||||||
'_launch_ansible_deploy', return_value=0)
|
'_launch_ansible', return_value=0)
|
||||||
@mock.patch('tripleoclient.v1.tripleo_deploy.Deploy.'
|
@mock.patch('tripleoclient.v1.tripleo_deploy.Deploy.'
|
||||||
'_cleanup_working_dirs')
|
'_cleanup_working_dirs')
|
||||||
@mock.patch('tripleoclient.v1.tripleo_deploy.Deploy.'
|
@mock.patch('tripleoclient.v1.tripleo_deploy.Deploy.'
|
||||||
|
@ -41,7 +41,7 @@ class TestUpgrade(utils.TestCommand):
|
|||||||
@mock.patch('os.execvp')
|
@mock.patch('os.execvp')
|
||||||
def test_launch_ansible_upgrade(self, mock_execvp, mock_chdir, mock_run):
|
def test_launch_ansible_upgrade(self, mock_execvp, mock_chdir, mock_run):
|
||||||
|
|
||||||
self.cmd._launch_ansible_upgrade('/tmp')
|
self.cmd._launch_ansible('/tmp', operation='upgrade')
|
||||||
mock_chdir.assert_called_once()
|
mock_chdir.assert_called_once()
|
||||||
mock_run.assert_called_once_with(self.cmd.log, [
|
mock_run.assert_called_once_with(self.cmd.log, [
|
||||||
self.ansible_playbook_cmd, '-i', '/tmp/inventory.yaml',
|
self.ansible_playbook_cmd, '-i', '/tmp/inventory.yaml',
|
||||||
@ -54,14 +54,26 @@ class TestUpgrade(utils.TestCommand):
|
|||||||
@mock.patch('os.execvp')
|
@mock.patch('os.execvp')
|
||||||
def test_launch_ansible_post_upgrade(self, mock_execvp, mock_chdir,
|
def test_launch_ansible_post_upgrade(self, mock_execvp, mock_chdir,
|
||||||
mock_run):
|
mock_run):
|
||||||
|
self.cmd._launch_ansible('/tmp', operation='post-upgrade')
|
||||||
self.cmd._launch_ansible_post_upgrade('/tmp')
|
|
||||||
mock_chdir.assert_called_once()
|
mock_chdir.assert_called_once()
|
||||||
mock_run.assert_called_once_with(self.cmd.log, [
|
mock_run.assert_called_once_with(self.cmd.log, [
|
||||||
self.ansible_playbook_cmd, '-i', '/tmp/inventory.yaml',
|
self.ansible_playbook_cmd, '-i', '/tmp/inventory.yaml',
|
||||||
'post_upgrade_steps_playbook.yaml',
|
'post_upgrade_steps_playbook.yaml',
|
||||||
'--skip-tags', 'validation'])
|
'--skip-tags', 'validation'])
|
||||||
|
|
||||||
|
@mock.patch('tripleoclient.utils.'
|
||||||
|
'run_command_and_log', autospec=True)
|
||||||
|
@mock.patch('os.chdir')
|
||||||
|
@mock.patch('os.execvp')
|
||||||
|
def test_launch_ansible_online_upgrade(self, mock_execvp, mock_chdir,
|
||||||
|
mock_run):
|
||||||
|
self.cmd._launch_ansible('/tmp', operation='online-upgrade')
|
||||||
|
mock_chdir.assert_called_once()
|
||||||
|
mock_run.assert_called_once_with(self.cmd.log, [
|
||||||
|
self.ansible_playbook_cmd, '-i', '/tmp/inventory.yaml',
|
||||||
|
'external_upgrade_steps_playbook.yaml',
|
||||||
|
'--tags', 'online_upgrade'])
|
||||||
|
|
||||||
@mock.patch('tripleoclient.v1.tripleo_deploy.Deploy.take_action',
|
@mock.patch('tripleoclient.v1.tripleo_deploy.Deploy.take_action',
|
||||||
autospec=True)
|
autospec=True)
|
||||||
def test_take_action(self, mock_deploy):
|
def test_take_action(self, mock_deploy):
|
||||||
|
@ -866,43 +866,21 @@ class Deploy(command.Command):
|
|||||||
return self.tmp_ansible_dir
|
return self.tmp_ansible_dir
|
||||||
|
|
||||||
# Never returns, calls exec()
|
# Never returns, calls exec()
|
||||||
def _launch_ansible_deploy(self, ansible_dir):
|
def _launch_ansible(self, ansible_dir, list_args=None, operation="deploy"):
|
||||||
self.log.warning(_('** Running ansible deploy tasks **'))
|
|
||||||
os.chdir(ansible_dir)
|
|
||||||
playbook_inventory = os.path.join(ansible_dir, 'inventory.yaml')
|
|
||||||
cmd = [self.ansible_playbook_cmd, '-i', playbook_inventory,
|
|
||||||
'deploy_steps_playbook.yaml']
|
|
||||||
self.log.debug('Running Ansible Deploy tasks: %s' % (' '.join(cmd)))
|
|
||||||
return utils.run_command_and_log(self.log, cmd)
|
|
||||||
|
|
||||||
def _launch_ansible_upgrade(self, ansible_dir):
|
if list_args is None:
|
||||||
self.log.warning('** Running ansible upgrade tasks **')
|
if operation not in constants.DEPLOY_ANSIBLE_ACTIONS.keys():
|
||||||
os.chdir(ansible_dir)
|
self.log.error(_('Operation %s is not allowed') % operation)
|
||||||
playbook_inventory = os.path.join(ansible_dir, 'inventory.yaml')
|
raise exceptions.DeploymentError('Invalid operation to run in '
|
||||||
cmd = [self.ansible_playbook_cmd, '-i', playbook_inventory,
|
'ansible.')
|
||||||
'upgrade_steps_playbook.yaml', '--skip-tags', 'validation']
|
list_args = constants.DEPLOY_ANSIBLE_ACTIONS[operation].split()
|
||||||
self.log.debug('Running Ansible Upgrade tasks: %s' % (' '.join(cmd)))
|
|
||||||
return utils.run_command_and_log(self.log, cmd)
|
|
||||||
|
|
||||||
def _launch_ansible_post_upgrade(self, ansible_dir):
|
self.log.warning(_('** Running ansible %s tasks **') % operation)
|
||||||
self.log.warning('** Running ansible post-upgrade tasks **')
|
|
||||||
os.chdir(ansible_dir)
|
os.chdir(ansible_dir)
|
||||||
playbook_inventory = os.path.join(ansible_dir, 'inventory.yaml')
|
playbook_inventory = os.path.join(ansible_dir, 'inventory.yaml')
|
||||||
cmd = [self.ansible_playbook_cmd, '-i', playbook_inventory,
|
cmd = [self.ansible_playbook_cmd, '-i', playbook_inventory] + list_args
|
||||||
'post_upgrade_steps_playbook.yaml', '--skip-tags', 'validation']
|
self.log.debug('Running Ansible %s tasks: %s' % (operation, ' '
|
||||||
self.log.debug('Running Ansible Post Upgrade '
|
.join(cmd)))
|
||||||
'tasks: %s' % (' '.join(cmd)))
|
|
||||||
return utils.run_command_and_log(self.log, cmd)
|
|
||||||
|
|
||||||
def _launch_ansible_online_upgrade(self, ansible_dir):
|
|
||||||
self.log.warning('** Running ansible online upgrade tasks **')
|
|
||||||
os.chdir(ansible_dir)
|
|
||||||
playbook_inventory = os.path.join(ansible_dir, 'inventory.yaml')
|
|
||||||
cmd = [self.ansible_playbook_cmd, '-i', playbook_inventory,
|
|
||||||
'external_upgrade_steps_playbook.yaml', '--tags',
|
|
||||||
'online_upgrade']
|
|
||||||
self.log.debug('Running Ansible Online Upgrade '
|
|
||||||
'tasks: %s' % (' '.join(cmd)))
|
|
||||||
return utils.run_command_and_log(self.log, cmd)
|
return utils.run_command_and_log(self.log, cmd)
|
||||||
|
|
||||||
def get_parser(self, prog_name):
|
def get_parser(self, prog_name):
|
||||||
@ -1276,19 +1254,22 @@ class Deploy(command.Command):
|
|||||||
if not parsed_args.output_only:
|
if not parsed_args.output_only:
|
||||||
if parsed_args.upgrade:
|
if parsed_args.upgrade:
|
||||||
# Run Upgrade tasks before the deployment
|
# Run Upgrade tasks before the deployment
|
||||||
rc = self._launch_ansible_upgrade(self.ansible_dir)
|
rc = self._launch_ansible(self.ansible_dir,
|
||||||
|
operation='upgrade')
|
||||||
if rc != 0:
|
if rc != 0:
|
||||||
raise exceptions.DeploymentError('Upgrade failed')
|
raise exceptions.DeploymentError('Upgrade failed')
|
||||||
rc = self._launch_ansible_deploy(self.ansible_dir)
|
rc = self._launch_ansible(self.ansible_dir)
|
||||||
if rc != 0:
|
if rc != 0:
|
||||||
raise exceptions.DeploymentError('Deployment failed')
|
raise exceptions.DeploymentError('Deployment failed')
|
||||||
if parsed_args.upgrade:
|
if parsed_args.upgrade:
|
||||||
# Run Post Upgrade tasks after the deployment
|
# Run Post Upgrade tasks after the deployment
|
||||||
rc = self._launch_ansible_post_upgrade(self.ansible_dir)
|
rc = self._launch_ansible(self.ansible_dir,
|
||||||
|
operation='post-upgrade')
|
||||||
if rc != 0:
|
if rc != 0:
|
||||||
raise exceptions.DeploymentError('Post Upgrade failed')
|
raise exceptions.DeploymentError('Post Upgrade failed')
|
||||||
# Run Online Upgrade tasks after the deployment
|
# Run Online Upgrade tasks after the deployment
|
||||||
rc = self._launch_ansible_online_upgrade(self.ansible_dir)
|
rc = self._launch_ansible(self.ansible_dir,
|
||||||
|
operation='online-upgrade')
|
||||||
if rc != 0:
|
if rc != 0:
|
||||||
raise exceptions.DeploymentError(
|
raise exceptions.DeploymentError(
|
||||||
'Online Upgrade failed')
|
'Online Upgrade failed')
|
||||||
|
Loading…
x
Reference in New Issue
Block a user