Pass OS_CLOUD env when migrating to heat ephemeral.

In order for the undercloud-upgrade-ephemeral-heat.py to work properly
we need to specify the OS_CLOUD for the existing undercloud stack,
otherwise the invoked OpenStack commands won't be able to authenticate
properly.

This change makes use of the --cloud script's option to pass it into
each subprocess' invokation of an openstack command.

Change-Id: I0b05a05907c42abfabe9cb963da65ed1efb2d283
Resolves: rhbz#2040260
This commit is contained in:
Jose Luis Franco Arza 2022-01-17 11:45:38 +01:00
parent c8dea60ddb
commit ed560e46cf

View File

@ -254,7 +254,7 @@ def export_passwords(heat, stack, stack_dir):
os.chmod(passwords_path, 0o600) os.chmod(passwords_path, 0o600)
def export_networks(stack, stack_dir): def export_networks(stack, stack_dir, cloud):
"""Export networks from an existing stack and write network data file. """Export networks from an existing stack and write network data file.
:param stack: Stack name to query for networks :param stack: Stack name to query for networks
@ -262,6 +262,8 @@ def export_networks(stack, stack_dir):
:param stack_dir: Directory to save the generated network data file :param stack_dir: Directory to save the generated network data file
containing the stack network definitions. containing the stack network definitions.
:type stack_dir: str :type stack_dir: str
:param cloud: Cloud name used to send OpenStack commands
:type cloud: str
:return: None :return: None
:rtype: None :rtype: None
""" """
@ -271,11 +273,11 @@ def export_networks(stack, stack_dir):
% (stack, network_data_path)) % (stack, network_data_path))
subprocess.check_call(['openstack', 'overcloud', 'network', 'extract', subprocess.check_call(['openstack', 'overcloud', 'network', 'extract',
'--stack', stack, '--output', network_data_path, '--stack', stack, '--output', network_data_path,
'--yes']) '--yes'], env={'OS_CLOUD': cloud})
os.chmod(network_data_path, 0o600) os.chmod(network_data_path, 0o600)
def export_network_virtual_ips(stack, stack_dir): def export_network_virtual_ips(stack, stack_dir, cloud):
"""Export network virtual IPs from an existing stack and write network """Export network virtual IPs from an existing stack and write network
vip data file. vip data file.
@ -284,6 +286,8 @@ def export_network_virtual_ips(stack, stack_dir):
:param stack_dir: Directory to save the generated data file :param stack_dir: Directory to save the generated data file
containing the stack virtual IP definitions. containing the stack virtual IP definitions.
:type stack_dir: str :type stack_dir: str
:param cloud: Cloud name used to send OpenStack commands
:type cloud: str
:return: None :return: None
:rtype: None :rtype: None
""" """
@ -293,11 +297,11 @@ def export_network_virtual_ips(stack, stack_dir):
% (stack, vip_data_path)) % (stack, vip_data_path))
subprocess.check_call(['openstack', 'overcloud', 'network', 'vip', subprocess.check_call(['openstack', 'overcloud', 'network', 'vip',
'extract', '--stack', stack, '--output', 'extract', '--stack', stack, '--output',
vip_data_path, '--yes']) vip_data_path, '--yes'], env={'OS_CLOUD': cloud})
os.chmod(vip_data_path, 0o600) os.chmod(vip_data_path, 0o600)
def export_provisioned_nodes(heat, stack, stack_dir): def export_provisioned_nodes(heat, stack, stack_dir, cloud):
"""Export provisioned nodes from an existing stack and write baremetal """Export provisioned nodes from an existing stack and write baremetal
deployment definition file. deployment definition file.
@ -308,6 +312,8 @@ def export_provisioned_nodes(heat, stack, stack_dir):
:param stack_dir: Directory to save the generated data file :param stack_dir: Directory to save the generated data file
containing the stack baremetal deployment definitions. containing the stack baremetal deployment definitions.
:type stack_dir: str :type stack_dir: str
:param cloud: Cloud name used to send OpenStack commands
:type cloud: str
:return: None :return: None
:rtype: None :rtype: None
""" """
@ -321,7 +327,7 @@ def export_provisioned_nodes(heat, stack, stack_dir):
subprocess.check_call(['openstack', 'overcloud', 'node', 'extract', subprocess.check_call(['openstack', 'overcloud', 'node', 'extract',
'provisioned', '--stack', stack, '--roles-file', 'provisioned', '--stack', stack, '--roles-file',
roles_data_file, '--output', roles_data_file, '--output',
bm_deployment_path, '--yes']) bm_deployment_path, '--yes'], env={'OS_CLOUD': cloud})
os.chmod(bm_deployment_path, 0o600) os.chmod(bm_deployment_path, 0o600)
finally: finally:
os.remove(temp_file_path) os.remove(temp_file_path)
@ -370,9 +376,9 @@ def main():
for stack in stacks: for stack in stacks:
stack_dir = os.path.join(working_dir, stack) stack_dir = os.path.join(working_dir, stack)
export_networks(stack, stack_dir) export_networks(stack, stack_dir, args.cloud)
export_network_virtual_ips(stack, stack_dir) export_network_virtual_ips(stack, stack_dir, args.cloud)
export_provisioned_nodes(heat, stack, stack_dir) export_provisioned_nodes(heat, stack, stack_dir, args.cloud)
if database_exists(): if database_exists():
backup_dir = os.path.join( backup_dir = os.path.join(