python-tripleoclient/tripleoclient/tests/test_export.py
Bogdan Dobrelya 28d15c2798 Also export OVN DBs IPs for multi-stack inputs
When cell computes do not have external_ids:ovn-remote configured
for OVN, it breaks.

Running manually:

ovs-vsctl set open . external_ids:ovn-remote="ssl:<ovn_dns_vip>:6642"

(or by DBs IPs) fixes it and ovn-controller connects the db and adds
the Chassis.

Fix multi-cell/multi-stack exports by also exporting ovn_dbs_node_ips.
So that when there is no ovn_dbs_vip data in hiera (i.e. no value for
t-h-t OVNDBsVirtualFixedIPs), there are still ovn_dbs_node_ips data to
have things configured properly for OVN on computes.

Change-Id: Ib49156d49a7f8e4544f5b73d15a4ad32dba77c98
Related: rhbz#2137904
Signed-off-by: Bogdan Dobrelya <bdobreli@redhat.com>
2022-12-06 16:12:21 +01:00

248 lines
9.9 KiB
Python

# Copyright 2019 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 os
from unittest import mock
from unittest import TestCase
from tripleoclient import export
from tripleoclient import utils
class TestExport(TestCase):
def setUp(self):
self.unlink_patch = mock.patch('os.unlink')
self.addCleanup(self.unlink_patch.stop)
self.unlink_patch.start()
self.mock_log = mock.Mock('logging.getLogger')
self.mock_open = mock.mock_open(read_data='{"an_key":"an_value"}')
ceph_inv = {
'DistributedComputeHCI': {
'hosts': {
'dcn0-distributedcomputehci-0': {
'foo_ip': '192.168.24.42'
},
'dcn0-distributedcomputehci-1': {
'foo_ip': '192.168.8.8'
}
}
},
'mons': {
'children': {
'DistributedComputeHCI': {}
}
}
}
self.mock_open_ceph_inv = mock.mock_open(read_data=str(ceph_inv))
ceph_global = {
'service_net_map': {
'ceph_mon_network': 'storage'
}
}
self.mock_open_ceph_global = mock.mock_open(read_data=str(ceph_global))
ceph_all = {
'cluster': 'dcn0',
'fsid': 'a5a22d37-e01f-4fa0-a440-c72585c7487f',
'keys': [
{'name': 'client.openstack'}
]
}
self.mock_open_ceph_all = mock.mock_open(read_data=str(ceph_all))
def _get_stack_saved_output_item(self, output_key, working_dir):
outputs = {
'EndpointMap': dict(em_key='em_value'),
'HostsEntry': 'hosts entry',
'GlobalConfig': dict(gc_key='gc_value'),
'AuthCloudName': 'central',
}
return outputs[output_key]
@mock.patch('tripleoclient.utils.get_stack_saved_output_item')
@mock.patch('tripleoclient.utils.os.path.exists',
autospec=True, reutrn_value=True)
def test_export_stack(self, mock_exists, mock_output_item):
mock_output_item.side_effect = self._get_stack_saved_output_item
working_dir = utils.get_default_working_dir('overcloud')
with mock.patch('tripleoclient.utils.open', self.mock_open):
data = export.export_stack(working_dir, "overcloud")
expected = \
{'AllNodesExtraMapData': {u'an_key': u'an_value'},
'AuthCloudName': 'central',
'EndpointMapOverride': {'em_key': 'em_value'},
'ExtraHostFileEntries': 'hosts entry',
'GlobalConfigExtraMapData': {'gc_key': 'gc_value'}}
self.assertEqual(expected, data)
self.mock_open.assert_called_once_with(
os.path.join(
os.environ.get('HOME'),
'config-download/overcloud/group_vars/overcloud.json'),
'r')
@mock.patch('tripleoclient.utils.get_stack_saved_output_item')
@mock.patch('tripleoclient.utils.os.path.exists',
autospec=True, reutrn_value=True)
def test_export_stack_auth_cloud_name_set(
self, mock_exists, mock_output_item):
mock_output_item.side_effect = self._get_stack_saved_output_item
working_dir = utils.get_default_working_dir('overcloud')
with mock.patch('tripleoclient.utils.open', self.mock_open):
data = export.export_stack(working_dir, "overcloud")
expected = \
{'AllNodesExtraMapData': {u'an_key': u'an_value'},
'AuthCloudName': 'central',
'EndpointMapOverride': {'em_key': 'em_value'},
'ExtraHostFileEntries': 'hosts entry',
'GlobalConfigExtraMapData': {'gc_key': 'gc_value'}}
self.assertEqual(expected, data)
self.mock_open.assert_called_once_with(
os.path.join(
os.environ.get('HOME'),
'config-download/overcloud/group_vars/overcloud.json'),
'r')
@mock.patch('tripleoclient.utils.get_stack_saved_output_item')
@mock.patch('tripleoclient.utils.os.path.exists',
autospec=True, reutrn_value=True)
def test_export_stack_should_filter(self, mock_exists, mock_stack_output):
working_dir = utils.get_default_working_dir('overcloud')
mock_stack_output.side_effect = self._get_stack_saved_output_item
self.mock_open = mock.mock_open(
read_data=('{"an_key":"an_value","ovn_dbs_vip":"vip",'
'"ovn_dbs_node_ips":[1,2]}'))
with mock.patch('builtins.open', self.mock_open):
data = export.export_stack(
working_dir, "overcloud", should_filter=True)
expected = \
{'AllNodesExtraMapData': {u'ovn_dbs_vip': u'vip',
u'ovn_dbs_node_ips': [1, 2]},
'AuthCloudName': 'central',
'EndpointMapOverride': {'em_key': 'em_value'},
'ExtraHostFileEntries': 'hosts entry',
'GlobalConfigExtraMapData': {'gc_key': 'gc_value'}}
self.assertEqual(expected, data)
self.mock_open.assert_called_once_with(
os.path.join(
os.environ.get('HOME'),
'config-download/overcloud/group_vars/overcloud.json'),
'r')
@mock.patch('tripleoclient.utils.os.path.exists',
autospec=True, reutrn_value=True)
def test_export_stack_cd_dir(self, mock_exists):
working_dir = utils.get_default_working_dir('overcloud')
with mock.patch('tripleoclient.utils.open', self.mock_open):
export.export_stack(working_dir, "overcloud",
config_download_dir='/foo')
self.mock_open.assert_called_with(
'/foo/overcloud/group_vars/overcloud.json', 'r')
@mock.patch('tripleoclient.export.LOG')
@mock.patch('tripleo_common.utils.plan.generate_passwords')
def test_export_passwords(self, mock_gen_pass, mock_log):
mock_passwords = {
'AdminPassword': 'A',
'RpcPassword': 'B',
'CephClientKey': 'cephkey',
'CephClusterFSID': 'cephkey',
'CephRgwKey': 'cephkey'}
mock_gen_pass.return_value = mock_passwords
expected_password_export = mock_passwords.copy()
working_dir = utils.get_default_working_dir('overcloud')
with mock.patch('builtins.open', mock.mock_open()):
data = export.export_passwords(working_dir, 'overcloud', False)
self.assertEqual(
expected_password_export,
data)
@mock.patch('tripleoclient.utils.get_stack_saved_output_item')
@mock.patch('tripleoclient.export.LOG')
@mock.patch('tripleo_common.utils.plan.generate_passwords')
def test_export_passwords_excludes(self, mock_gen_pass, mock_log,
mock_output_item):
mock_output_item.side_effect = self._get_stack_saved_output_item
mock_passwords = {
'AdminPassword': 'A',
'RpcPassword': 'B',
'CephClientKey': 'cephkey',
'CephClusterFSID': 'cephkey',
'CephRgwKey': 'cephkey'}
mock_gen_pass.return_value = mock_passwords
expected_password_export = {
'AdminPassword': 'A',
'RpcPassword': 'B'}
working_dir = utils.get_default_working_dir('overcloud')
with mock.patch('builtins.open', mock.mock_open()):
data = export.export_passwords(working_dir, 'overcloud')
self.assertEqual(expected_password_export, data)
def test_export_ceph_net_key(self):
with mock.patch('builtins.open', self.mock_open_ceph_global):
mon_key = export.export_ceph_net_key('dcn0',
config_download_dir='/foo')
self.assertEqual(mon_key, 'storage_ip')
self.mock_open_ceph_global.assert_called_once_with(
'/foo/dcn0/global_vars.yaml', 'r')
def test_export_storage_ips(self):
with mock.patch('builtins.open', self.mock_open_ceph_inv):
storage_ips = export.export_storage_ips('dcn0',
config_download_dir='/foo',
ceph_net_key='foo_ip')
self.assertEqual(storage_ips, ['192.168.24.42', '192.168.8.8'])
self.mock_open_ceph_inv.assert_called_once_with(
'/foo/dcn0/ceph-ansible/inventory.yml', 'r')
def test_export_ceph(self):
expected = {
'external_cluster_mon_ips': '192.168.24.42',
'keys': [
{'name': 'client.openstack'}
],
'ceph_conf_overrides': {
'client': {
'keyring': '/etc/ceph/dcn0.client.openstack.keyring'
}
},
'cluster': 'dcn0',
'fsid': 'a5a22d37-e01f-4fa0-a440-c72585c7487f',
'dashboard_enabled': False
}
with mock.patch('builtins.open', self.mock_open_ceph_all):
data = export.export_ceph('dcn0', 'openstack',
config_download_dir='/foo',
mon_ips=['192.168.24.42'],
config_download_files=['ceph-ansible'])
self.assertEqual(data, expected)
self.mock_open_ceph_all.assert_called_once_with(
'/foo/dcn0/ceph-ansible/group_vars/all.yml', 'r')