Obtain overcloud nodes know subgroups from node name

Change-Id: I4b3c79dcde476e624dad5f7b05b5f08761a22bc4
This commit is contained in:
Federico Ressi 2020-06-17 10:10:50 +02:00
parent 3abe65653c
commit f3a63b2d7e
2 changed files with 58 additions and 13 deletions

View File

@ -15,7 +15,7 @@ from __future__ import absolute_import
import collections import collections
import socket import socket
import typing # noqa import typing
import weakref import weakref
@ -103,18 +103,19 @@ class OpenStackTopologyNode(object):
_docker_client = None _docker_client = None
_podman_client = None _podman_client = None
def __init__(self, topology, name, public_ip, ssh_client): def __init__(self, topology, name: str, public_ip,
ssh_client):
self._topology = weakref.ref(topology) self._topology = weakref.ref(topology)
self.name = name self.name: str = name
self.public_ip = public_ip self.public_ip = public_ip
self.ssh_client = ssh_client self.ssh_client = ssh_client
self.groups = set() self.groups: typing.Set[str] = set()
@property @property
def topology(self): def topology(self):
return self._topology() return self._topology()
def add_group(self, group): def add_group(self, group: str):
self.groups.add(group) self.groups.add(group)
@property @property
@ -211,7 +212,7 @@ class OpenStackTopology(tobiko.SharedFixture):
group='compute') group='compute')
def add_node(self, hostname=None, address=None, group=None, def add_node(self, hostname=None, address=None, group=None,
ssh_client=None): ssh_client=None) -> OpenStackTopologyNode:
name = hostname and node_name_from_hostname(hostname) or None name = hostname and node_name_from_hostname(hostname) or None
ips = set() ips = set()
if address: if address:

View File

@ -14,6 +14,7 @@
from __future__ import absolute_import from __future__ import absolute_import
import re import re
import typing
from oslo_log import log from oslo_log import log
@ -35,6 +36,9 @@ class TripleoTopology(topology.OpenStackTopology):
has_containers = True has_containers = True
# TODO: add more known subgrups here
known_subgroups: typing.List[str] = ['controller', 'compute']
def discover_nodes(self): def discover_nodes(self):
self.discover_undercloud_nodes() self.discover_undercloud_nodes()
self.discover_overcloud_nodes() self.discover_overcloud_nodes()
@ -55,16 +59,56 @@ class TripleoTopology(topology.OpenStackTopology):
node = self.add_node(address=config.hostname, node = self.add_node(address=config.hostname,
group='overcloud', group='overcloud',
ssh_client=ssh_client) ssh_client=ssh_client)
self.discover_overcloud_node_subgroups(node)
group = node.name.split('-', 1)[0]
if group == node.name:
LOG.warning("Unable to get node group name node name: %r",
node.name)
else:
self.add_node(hostname=node.name, group=group)
else: else:
super(TripleoTopology, self).discover_nodes() super(TripleoTopology, self).discover_nodes()
def discover_overcloud_node_subgroups(self, node):
# set of subgroups extracted from node name
subgroups: typing.Set[str] = set()
# extract subgroups names from node name
subgroups.update(subgroup
for subgroup in node.name.split('-')
if is_valid_overcloud_group_name(group_name=subgroup,
node_name=node.name))
# add all those known subgroups names that are contained in
# the node name (controller, compute, ...)
subgroups.update(subgroup
for subgroup in self.known_subgroups
if subgroup in node.name)
# bind node to discovered subgroups
if subgroups:
for subgroup in sorted(subgroups):
LOG.debug("Add node '%s' to subgroup '%s'", node.name,
subgroup)
self.add_node(hostname=node.name, group=subgroup)
else:
LOG.warning("Unable to obtain any node subgroup from node "
"name: '%s'", node.name)
return subgroups
def is_valid_overcloud_group_name(group_name: str, node_name: str = None):
if not group_name:
return False
if group_name in ['overcloud', node_name]:
return False
if is_number(group_name):
return False
return True
def is_number(text: str):
try:
float(text)
except ValueError:
return False
else:
return True
def setup_tripleo_topology(): def setup_tripleo_topology():
if undercloud.has_undercloud() or overcloud.has_overcloud(): if undercloud.has_undercloud() or overcloud.has_overcloud():