Remove --heat-type=installed support

Remove support for using an undercloud installed Heat, as it no longer
needs to be supported.

Change-Id: I39150aa6771a32318ad2cbcd50b6dddcd97b4663
Signed-off-by: James Slagle <jslagle@redhat.com>
(cherry picked from commit 60d17b2fa1)
This commit is contained in:
James Slagle 2022-04-13 17:23:12 -04:00
parent 03ba5a6e64
commit f0a7f0bf96
3 changed files with 20 additions and 66 deletions

View File

@ -0,0 +1,5 @@
---
other:
- The --heat-type argument for openstack overcloud deploy no longer accepts a
value of "installed", as using an undercloud installed Heat to deploy the
overcloud is no longer supported.

View File

@ -181,11 +181,9 @@ class TestDeployOvercloud(fakes.TestDeployOvercloud):
orchestration_client.stacks.get.return_value = mock_stack orchestration_client.stacks.get.return_value = mock_stack
utils_fixture = deployment.UtilsFixture() utils_fixture = deployment.UtilsFixture()
self.useFixture(utils_fixture) self.useFixture(utils_fixture)
arglist = ['--templates', arglist = ['--templates']
'--heat-type', 'installed']
verifylist = [ verifylist = [
('templates', '/usr/share/openstack-tripleo-heat-templates/'), ('templates', '/usr/share/openstack-tripleo-heat-templates/'),
('heat_type', 'installed'),
] ]
clients = self.app.client_manager clients = self.app.client_manager
@ -219,7 +217,7 @@ class TestDeployOvercloud(fakes.TestDeployOvercloud):
'SnmpdReadonlyUserPassword': 'PASSWORD', 'SnmpdReadonlyUserPassword': 'PASSWORD',
'DeployIdentifier': 12345678, 'DeployIdentifier': 12345678,
'RootStackName': 'overcloud', 'RootStackName': 'overcloud',
'StackAction': 'UPDATE', 'StackAction': 'CREATE',
'UndercloudHostsEntries': [ 'UndercloudHostsEntries': [
'192.168.0.1 uc.ctlplane.localhost uc.ctlplane'], '192.168.0.1 uc.ctlplane.localhost uc.ctlplane'],
'CtlplaneNetworkAttributes': {}, 'CtlplaneNetworkAttributes': {},
@ -239,8 +237,6 @@ class TestDeployOvercloud(fakes.TestDeployOvercloud):
'parameter_defaults': expected_parameters} 'parameter_defaults': expected_parameters}
self.cmd.take_action(parsed_args) self.cmd.take_action(parsed_args)
self.assertTrue(orchestration_client.stacks.update.called)
mock_get_template_contents.assert_called_with( mock_get_template_contents.assert_called_with(
template_file=mock.ANY) template_file=mock.ANY)
@ -307,26 +303,15 @@ class TestDeployOvercloud(fakes.TestDeployOvercloud):
self.useFixture(utils_fixture) self.useFixture(utils_fixture)
utils_overcloud_fixture = deployment.UtilsOvercloudFixture() utils_overcloud_fixture = deployment.UtilsOvercloudFixture()
self.useFixture(utils_overcloud_fixture) self.useFixture(utils_overcloud_fixture)
arglist = ['--templates', '--no-cleanup', arglist = ['--templates', '--no-cleanup']
'--heat-type', 'installed']
verifylist = [ verifylist = [
('templates', '/usr/share/openstack-tripleo-heat-templates/'), ('templates', '/usr/share/openstack-tripleo-heat-templates/'),
('heat_type', 'installed'),
] ]
mock_stack_data.return_value = {'environment_parameters': {}, mock_stack_data.return_value = {'environment_parameters': {},
'heat_resource_tree': {}} 'heat_resource_tree': {}}
mock_tmpdir.return_value = self.tmp_dir.path mock_tmpdir.return_value = self.tmp_dir.path
clients = self.app.client_manager clients = self.app.client_manager
orchestration_client = clients.orchestration
mock_stack = fakes.create_tht_stack()
orchestration_client.stacks.get.side_effect = \
[None, mock_stack, mock_stack]
def _orch_clt_create(**kwargs):
orchestration_client.stacks.get.return_value = mock_stack
orchestration_client.stacks.create.side_effect = _orch_clt_create
clients.network.api.find_attr.return_value = { clients.network.api.find_attr.return_value = {
"id": "network id" "id": "network id"
@ -353,8 +338,6 @@ class TestDeployOvercloud(fakes.TestDeployOvercloud):
with mock.patch('builtins.open', mock_open_context): with mock.patch('builtins.open', mock_open_context):
self.cmd.take_action(parsed_args) self.cmd.take_action(parsed_args)
self.assertTrue(orchestration_client.stacks.create.called)
mock_get_template_contents.assert_called_with( mock_get_template_contents.assert_called_with(
template_file=mock.ANY) template_file=mock.ANY)
@ -516,16 +499,12 @@ class TestDeployOvercloud(fakes.TestDeployOvercloud):
utils_fixture = deployment.UtilsFixture() utils_fixture = deployment.UtilsFixture()
self.useFixture(utils_fixture) self.useFixture(utils_fixture)
arglist = ['--templates', '/home/stack/tripleo-heat-templates', arglist = ['--templates', '/home/stack/tripleo-heat-templates']
'--heat-type', 'installed']
verifylist = [ verifylist = [
('templates', '/home/stack/tripleo-heat-templates'), ('templates', '/home/stack/tripleo-heat-templates'),
('heat_type', 'installed'),
] ]
clients = self.app.client_manager clients = self.app.client_manager
orchestration_client = clients.orchestration
orchestration_client.stacks.get.return_value = fakes.create_tht_stack()
mock_events.return_value = [] mock_events.return_value = []
clients.network.api.find_attr.return_value = { clients.network.api.find_attr.return_value = {
@ -550,8 +529,6 @@ class TestDeployOvercloud(fakes.TestDeployOvercloud):
self.parameter_defaults_env_file) self.parameter_defaults_env_file)
self.cmd.take_action(parsed_args) self.cmd.take_action(parsed_args)
self.assertTrue(orchestration_client.stacks.update.called)
mock_get_template_contents.assert_called_with( mock_get_template_contents.assert_called_with(
template_file=mock.ANY) template_file=mock.ANY)

View File

@ -83,11 +83,6 @@ class DeployOvercloud(command.Command):
else: else:
parameters['DeployIdentifier'] = '' parameters['DeployIdentifier'] = ''
if args.heat_type != 'installed':
heat = None
else:
heat = self.orchestration_client
# Check for existing passwords file # Check for existing passwords file
password_params_path = os.path.join( password_params_path = os.path.join(
self.working_dir, self.working_dir,
@ -98,6 +93,7 @@ class DeployOvercloud(command.Command):
else: else:
passwords_env = None passwords_env = None
heat = None
password_params = plan_utils.generate_passwords( password_params = plan_utils.generate_passwords(
None, heat, args.stack, passwords_env=passwords_env) None, heat, args.stack, passwords_env=passwords_env)
@ -1029,13 +1025,13 @@ class DeployOvercloud(command.Command):
'--heat-type', '--heat-type',
action='store', action='store',
default='pod', default='pod',
choices=['installed', 'pod', 'container', 'native'], choices=['pod', 'container', 'native'],
help=_('The type of Heat process to use to execute ' help=_('The type of Heat process to use to execute '
'the deployment.\n' 'the deployment.\n'
'pod (Default): Use an ephemeral Heat pod.\n' 'pod (Default): Use an ephemeral Heat pod.\n'
'installed: Use the system installed Heat.\n' 'container (Experimental): Use an ephemeral Heat '
'container: Use an ephemeral Heat container.\n' 'container.\n'
'native: Use an ephemeral Heat process.') 'native (Experimental): Use an ephemeral Heat process.')
) )
parser.add_argument( parser.add_argument(
'--heat-container-api-image', '--heat-container-api-image',
@ -1164,34 +1160,13 @@ class DeployOvercloud(command.Command):
self.heat_launcher = None self.heat_launcher = None
stack = None stack = None
stack_create = None
start = time.time() start = time.time()
if parsed_args.heat_type == 'installed':
stack = utils.get_stack(self.orchestration_client,
parsed_args.stack)
stack_create = stack is None
if stack_create:
self.log.info("No stack found, "
"will be doing a stack create")
else:
self.log.info("Stack found, "
"will be doing a stack update")
new_tht_root, user_tht_root = \ new_tht_root, user_tht_root = \
self.create_template_dirs(parsed_args) self.create_template_dirs(parsed_args)
created_env_files = self.create_env_files( created_env_files = self.create_env_files(
stack, parsed_args, new_tht_root, user_tht_root) stack, parsed_args, new_tht_root, user_tht_root)
if parsed_args.heat_type != 'installed':
ephemeral_heat = True
else:
ephemeral_heat = False
self.log.warning(
("DEPRECATED: Using --heat-type=installed is deprecated "
"and will be removed in a future release."))
# full_deploy means we're doing a full deployment # full_deploy means we're doing a full deployment
# e.g., no --*-only args were passed # e.g., no --*-only args were passed
full_deploy = not (parsed_args.stack_only or parsed_args.setup_only or full_deploy = not (parsed_args.stack_only or parsed_args.setup_only or
@ -1222,7 +1197,6 @@ class DeployOvercloud(command.Command):
# running during later parts of overcloud deploy. # running during later parts of overcloud deploy.
try: try:
if do_stack: if do_stack:
if ephemeral_heat:
self.setup_ephemeral_heat(parsed_args) self.setup_ephemeral_heat(parsed_args)
self.deploy_tripleo_heat_templates( self.deploy_tripleo_heat_templates(
@ -1287,7 +1261,7 @@ class DeployOvercloud(command.Command):
) )
finally: finally:
if parsed_args.heat_type != 'installed' and self.heat_launcher: if self.heat_launcher:
self.log.info("Stopping ephemeral heat.") self.log.info("Stopping ephemeral heat.")
utils.kill_heat(self.heat_launcher) utils.kill_heat(self.heat_launcher)
utils.rm_heat(self.heat_launcher, backup_db=True) utils.rm_heat(self.heat_launcher, backup_db=True)
@ -1389,8 +1363,7 @@ class DeployOvercloud(command.Command):
self.log.error(e) self.log.error(e)
try: try:
if (parsed_args.heat_type != 'installed' and if parsed_args.config_download:
parsed_args.config_download):
# Create overcloud export # Create overcloud export
data = export.export_overcloud( data = export.export_overcloud(
self.working_dir, self.working_dir,
@ -1415,7 +1388,6 @@ class DeployOvercloud(command.Command):
print("Overcloud Deployed {0}".format(deploy_message)) print("Overcloud Deployed {0}".format(deploy_message))
try: try:
if parsed_args.heat_type != 'installed':
self.log.info("Stopping ephemeral heat.") self.log.info("Stopping ephemeral heat.")
utils.kill_heat(self.heat_launcher) utils.kill_heat(self.heat_launcher)
utils.rm_heat(self.heat_launcher, backup_db=True) utils.rm_heat(self.heat_launcher, backup_db=True)