179 lines
8.3 KiB
Python
179 lines
8.3 KiB
Python
# Copyright 2018 Red Hat, 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 mock
|
|
import sys
|
|
|
|
from osc_lib.tests import utils
|
|
import six
|
|
|
|
# Load the plugin init module for the plugin list and show commands
|
|
from tripleoclient import exceptions
|
|
from tripleoclient.v1 import tripleo_upgrade
|
|
|
|
|
|
class TestUpgrade(utils.TestCommand):
|
|
|
|
def setUp(self):
|
|
super(TestUpgrade, self).setUp()
|
|
|
|
# Get the command object to test
|
|
self.cmd = tripleo_upgrade.Upgrade(self.app, None)
|
|
|
|
python_version = sys.version_info[0]
|
|
self.ansible_playbook_cmd = "ansible-playbook-%s" % (python_version)
|
|
|
|
@mock.patch('tripleoclient.utils.'
|
|
'run_command_and_log', autospec=True)
|
|
@mock.patch('os.chdir')
|
|
@mock.patch('os.execvp')
|
|
def test_launch_ansible_upgrade(self, mock_execvp, mock_chdir, mock_run):
|
|
|
|
self.cmd._launch_ansible('/tmp', operation='upgrade')
|
|
mock_chdir.assert_called_once()
|
|
mock_run.assert_called_once_with(self.cmd.log, [
|
|
self.ansible_playbook_cmd, '-i', '/tmp/inventory.yaml',
|
|
'upgrade_steps_playbook.yaml',
|
|
'--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_post_upgrade(self, mock_execvp, mock_chdir,
|
|
mock_run):
|
|
self.cmd._launch_ansible('/tmp', operation='post-upgrade')
|
|
mock_chdir.assert_called_once()
|
|
mock_run.assert_called_once_with(self.cmd.log, [
|
|
self.ansible_playbook_cmd, '-i', '/tmp/inventory.yaml',
|
|
'post_upgrade_steps_playbook.yaml',
|
|
'--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',
|
|
autospec=True)
|
|
def test_take_action(self, mock_deploy):
|
|
verifylist = [
|
|
('local_ip', '127.0.0.1'),
|
|
('templates', '/tmp/thtroot'),
|
|
('stack', 'undercloud'),
|
|
('output_dir', '/my'),
|
|
]
|
|
|
|
parsed_args = self.check_parser(self.cmd,
|
|
['--local-ip', '127.0.0.1',
|
|
'--templates', '/tmp/thtroot',
|
|
'--stack', 'undercloud',
|
|
'--output-dir', '/my',
|
|
'-e', '/tmp/thtroot/puppet/foo.yaml',
|
|
'-e', '/tmp/thtroot//docker/bar.yaml',
|
|
'-e', '/tmp/thtroot42/notouch.yaml',
|
|
'-e', '~/custom.yaml',
|
|
'-e', 'something.yaml',
|
|
'-e', '../../../outside.yaml'],
|
|
verifylist)
|
|
|
|
self.cmd.take_action(parsed_args)
|
|
parsed_args.standalone = True
|
|
parsed_args.upgrade = True
|
|
mock_deploy.assert_called_with(self.cmd, parsed_args)
|
|
|
|
@mock.patch('tripleoclient.v1.tripleo_deploy.Deploy.take_action',
|
|
autospec=True)
|
|
@mock.patch('sys.stdin', spec=six.StringIO)
|
|
def test_take_action_prompt(self, mock_stdin, mock_deploy):
|
|
mock_stdin.isatty.return_value = True
|
|
mock_stdin.readline.return_value = 'y'
|
|
parsed_args = self.check_parser(self.cmd,
|
|
['--local-ip', '127.0.0.1',
|
|
'--templates', '/tmp/thtroot',
|
|
'--stack', 'undercloud',
|
|
'--output-dir', '/my',
|
|
'-e', '/tmp/thtroot/puppet/foo.yaml',
|
|
'-e', '/tmp/thtroot//docker/bar.yaml',
|
|
'-e', '/tmp/thtroot42/notouch.yaml',
|
|
'-e', '~/custom.yaml',
|
|
'-e', 'something.yaml',
|
|
'-e', '../../../outside.yaml'], [])
|
|
self.cmd.take_action(parsed_args)
|
|
parsed_args.standlone = True
|
|
parsed_args.upgrade = True
|
|
mock_deploy.assert_called_with(self.cmd, parsed_args)
|
|
|
|
@mock.patch('tripleoclient.v1.tripleo_deploy.Deploy',
|
|
autospec=True)
|
|
@mock.patch('sys.stdin', spec=six.StringIO)
|
|
@mock.patch('tripleoclient.utils.ansible_symlink')
|
|
def test_take_action_prompt_no(self, mock_slink, mock_stdin, mock_deploy):
|
|
mock_slink.side_effect = 'fake-cmd'
|
|
mock_stdin.isatty.return_value = True
|
|
mock_stdin.readline.return_value = 'n'
|
|
parsed_args = self.check_parser(self.cmd,
|
|
['--local-ip', '127.0.0.1',
|
|
'--templates', '/tmp/thtroot',
|
|
'--stack', 'undercloud',
|
|
'--output-dir', '/my',
|
|
'-e', '/tmp/thtroot/puppet/foo.yaml',
|
|
'-e', '/tmp/thtroot//docker/bar.yaml',
|
|
'-e', '/tmp/thtroot42/notouch.yaml',
|
|
'-e', '~/custom.yaml',
|
|
'-e', 'something.yaml',
|
|
'-e', '../../../outside.yaml'], [])
|
|
parsed_args.standlone = True
|
|
parsed_args.upgrade = True
|
|
self.assertRaises(exceptions.UndercloudUpgradeNotConfirmed,
|
|
self.cmd.take_action, parsed_args)
|
|
mock_stdin.readline.assert_called_with()
|
|
mock_deploy.assert_not_called()
|
|
|
|
@mock.patch('tripleoclient.v1.tripleo_deploy.Deploy',
|
|
autospec=True)
|
|
@mock.patch('sys.stdin', spec=six.StringIO)
|
|
@mock.patch('tripleoclient.utils.ansible_symlink')
|
|
def test_take_action_prompt_invalid_option(self, mock_slink, mock_stdin,
|
|
mock_deploy):
|
|
mock_slink.side_effect = 'fake-cmd'
|
|
mock_stdin.isatty.return_value = True
|
|
mock_stdin.readline.return_value = 'Dontwant'
|
|
parsed_args = self.check_parser(self.cmd,
|
|
['--local-ip', '127.0.0.1',
|
|
'--templates', '/tmp/thtroot',
|
|
'--stack', 'undercloud',
|
|
'--output-dir', '/my',
|
|
'-e', '/tmp/thtroot/puppet/foo.yaml',
|
|
'-e', '/tmp/thtroot//docker/bar.yaml',
|
|
'-e', '/tmp/thtroot42/notouch.yaml',
|
|
'-e', '~/custom.yaml',
|
|
'-e', 'something.yaml',
|
|
'-e', '../../../outside.yaml'], [])
|
|
parsed_args.standlone = True
|
|
parsed_args.upgrade = True
|
|
self.assertRaises(exceptions.UndercloudUpgradeNotConfirmed,
|
|
self.cmd.take_action, parsed_args)
|
|
mock_stdin.readline.assert_called_with()
|
|
mock_deploy.assert_not_called()
|