Enable Flake8 Docstring Errors
Flake8 currently ignores the following errors: H401: docstring should not start with a space H404: multi line docstring should start without a leading new line H405: multi line docstring summary not separated with an empty line Enable them for more consistent formatting of docstrings Change-Id: I385e28e9c6eca3c02a3def51ff64b00b7a63a853 Story: 2004515 Task: 30076 Signed-off-by: Eric Barrett <eric.barrett@windriver.com>
This commit is contained in:
parent
70bbb84587
commit
7c67589b1b
collectd-extensions/src
vm-topology/vm-topology/vm_topology/exec
@ -24,9 +24,7 @@ obj = ExampleObject()
|
||||
|
||||
# The config function - called once on collectd process startup
|
||||
def config_func(config):
|
||||
"""
|
||||
Configure the plugin
|
||||
"""
|
||||
"""Configure the plugin"""
|
||||
|
||||
for node in config.children:
|
||||
key = node.key.lower()
|
||||
|
@ -217,9 +217,7 @@ class PluginObject:
|
||||
database_setup_in_progress = False # connection mutex
|
||||
|
||||
def __init__(self, id, plugin):
|
||||
"""
|
||||
PluginObject Class constructor
|
||||
"""
|
||||
"""PluginObject Class constructor"""
|
||||
|
||||
# plugin specific static class members.
|
||||
self.id = id # alarm id ; 100.1??
|
||||
@ -272,27 +270,20 @@ class PluginObject:
|
||||
|
||||
# For plugins that have multiple instances like df (filesystem plugin)
|
||||
# we need to create an instance of this object for each one.
|
||||
# This dictionary is used to associate a instance with its object.
|
||||
# This dictionary is used to associate an instance with its object.
|
||||
self.instance_objects = {}
|
||||
|
||||
def _ilog(self, string):
|
||||
"""
|
||||
Create a collectd notifier info log with the specified string.
|
||||
"""
|
||||
"""Create a collectd notifier info log with the string param"""
|
||||
collectd.info('%s %s : %s' % (PLUGIN, self.plugin, string))
|
||||
|
||||
def _llog(self, string):
|
||||
"""
|
||||
Create a collectd notifier info log with the specified string
|
||||
if debug_lists is True.
|
||||
"""
|
||||
"""Create a collectd notifier info log with the string param if debug_lists"""
|
||||
if debug_lists:
|
||||
collectd.info('%s %s : %s' % (PLUGIN, self.plugin, string))
|
||||
|
||||
def _elog(self, string):
|
||||
"""
|
||||
Create a collectd notifier error log with the specified string.
|
||||
"""
|
||||
"""Create a collectd notifier error log with the string param"""
|
||||
collectd.error('%s %s : %s' % (PLUGIN, self.plugin, string))
|
||||
|
||||
##########################################################################
|
||||
@ -310,7 +301,7 @@ class PluginObject:
|
||||
##########################################################################
|
||||
|
||||
def _state_audit(self, location):
|
||||
""" Log the state of the specified object. """
|
||||
"""Log the state of the specified object"""
|
||||
|
||||
if self.id == ALARM_ID__CPU:
|
||||
_print_state()
|
||||
@ -346,7 +337,7 @@ class PluginObject:
|
||||
##########################################################################
|
||||
|
||||
def _manage_change(self, nObject):
|
||||
""" Log resource instance value on step state change. """
|
||||
"""Log resource instance value on step state change"""
|
||||
|
||||
# filter out messages to ignore ; notifications that have no value
|
||||
if "has not been updated for" in nObject.message:
|
||||
@ -495,9 +486,7 @@ class PluginObject:
|
||||
##########################################################################
|
||||
|
||||
def _severity_change(self, entity_id, severity):
|
||||
"""
|
||||
Check for a severity change
|
||||
"""
|
||||
"""Check for a severity change"""
|
||||
|
||||
if entity_id in self.warnings:
|
||||
self._llog(entity_id + " is already in warnings list")
|
||||
@ -561,9 +550,7 @@ class PluginObject:
|
||||
#########################################################################
|
||||
|
||||
def _manage_alarm(self, entity_id, severity):
|
||||
"""
|
||||
Manage the alarm severity lists and report state change.
|
||||
"""
|
||||
"""Manage the alarm severity lists and report state change"""
|
||||
|
||||
collectd.debug("%s manage alarm %s %s %s" %
|
||||
(PLUGIN,
|
||||
@ -675,10 +662,9 @@ class PluginObject:
|
||||
#
|
||||
##########################################################################
|
||||
def _get_instance_object(self, eid):
|
||||
"""
|
||||
Safely get an object from the self instance object list indexed
|
||||
by eid while locked.
|
||||
:param eid:
|
||||
"""Safely get an object from the self instance object dict while locked
|
||||
|
||||
:param eid: the index for the instance object dictionary
|
||||
:return: object or None
|
||||
"""
|
||||
|
||||
@ -707,10 +693,10 @@ class PluginObject:
|
||||
#
|
||||
##########################################################################
|
||||
def _add_instance_object(self, obj, eid):
|
||||
"""
|
||||
Update self instance_objects list while locked
|
||||
"""Update self instance_objects list while locked
|
||||
|
||||
:param obj: the object to add
|
||||
:param eid: indexed by this eid
|
||||
:param eid: index for instance_objects
|
||||
:return: nothing
|
||||
"""
|
||||
try:
|
||||
@ -734,9 +720,7 @@ class PluginObject:
|
||||
#
|
||||
##########################################################################
|
||||
def _copy_instance_object(self, object):
|
||||
"""
|
||||
Copy select members of self object to target object
|
||||
"""
|
||||
"""Copy select members of self object to target object"""
|
||||
|
||||
object.resource_name = self.resource_name
|
||||
object.instance_name = self.instance_name
|
||||
@ -802,9 +786,7 @@ class PluginObject:
|
||||
#
|
||||
##########################################################################
|
||||
def _create_instance_objects(self):
|
||||
"""
|
||||
Create, initialize and add an instance object to this/self plugin
|
||||
"""
|
||||
"""Create, initialize and add an instance object to this/self plugin"""
|
||||
|
||||
# Create the File System subordinate instance objects.
|
||||
if self.id == ALARM_ID__DF:
|
||||
@ -880,9 +862,7 @@ PLUGINS = {
|
||||
|
||||
|
||||
def _get_base_object(alarm_id):
|
||||
"""
|
||||
Get the alarm object for the specified alarm id.
|
||||
"""
|
||||
"""Get the alarm object for the specified alarm id"""
|
||||
for plugin in PLUGIN_NAME_LIST:
|
||||
if PLUGINS[plugin].id == alarm_id:
|
||||
return PLUGINS[plugin]
|
||||
@ -890,9 +870,7 @@ def _get_base_object(alarm_id):
|
||||
|
||||
|
||||
def _get_object(alarm_id, eid):
|
||||
"""
|
||||
Get the plugin object for the specified alarm id and eid
|
||||
"""
|
||||
"""Get the plugin object for the specified alarm id and eid"""
|
||||
|
||||
base_obj = _get_base_object(alarm_id)
|
||||
if len(base_obj.instance_objects):
|
||||
@ -905,9 +883,7 @@ def _get_object(alarm_id, eid):
|
||||
|
||||
|
||||
def _build_entity_id(plugin, plugin_instance):
|
||||
"""
|
||||
Builds an entity id string based on the collectd notification object.
|
||||
"""
|
||||
"""Builds an entity id string based on the collectd notification object"""
|
||||
|
||||
inst_error = False
|
||||
|
||||
@ -968,8 +944,6 @@ def _build_entity_id(plugin, plugin_instance):
|
||||
|
||||
|
||||
def _get_df_mountpoints():
|
||||
"""
|
||||
"""
|
||||
|
||||
conf_file = PLUGIN_PATH + 'df.conf'
|
||||
if not os.path.exists(conf_file):
|
||||
@ -996,9 +970,7 @@ def _get_df_mountpoints():
|
||||
|
||||
|
||||
def _print_obj(obj):
|
||||
"""
|
||||
Print a single object
|
||||
"""
|
||||
"""Print a single object"""
|
||||
base_object = False
|
||||
for plugin in PLUGIN_NAME_LIST:
|
||||
if PLUGINS[plugin] == obj:
|
||||
@ -1045,9 +1017,7 @@ def _print_obj(obj):
|
||||
|
||||
|
||||
def _print_state(obj=None):
|
||||
"""
|
||||
Print the current object state
|
||||
"""
|
||||
"""Print the current object state"""
|
||||
try:
|
||||
objs = []
|
||||
if obj is None:
|
||||
@ -1069,9 +1039,7 @@ def _print_state(obj=None):
|
||||
|
||||
|
||||
def _database_setup(database):
|
||||
"""
|
||||
Setup the influx database for collectd resource samples
|
||||
"""
|
||||
"""Setup the influx database for collectd resource samples"""
|
||||
|
||||
collectd.info("%s setting up influxdb:%s database" %
|
||||
(PLUGIN, database))
|
||||
@ -1144,9 +1112,7 @@ def _database_setup(database):
|
||||
|
||||
|
||||
def _clear_alarm_for_missing_filesystems():
|
||||
"""
|
||||
Clear alarmed file systems that are no longer mounted or present
|
||||
"""
|
||||
"""Clear alarmed file systems that are no longer mounted or present"""
|
||||
|
||||
# get the DF (filesystem plugin) base object.
|
||||
df_base_obj = PLUGINS[PLUGIN__DF]
|
||||
|
@ -343,7 +343,6 @@ class NetworkObject:
|
||||
#
|
||||
######################################################################
|
||||
def manage_iface_alarm(self):
|
||||
""" """
|
||||
# Single Link Config
|
||||
if self.link_two.name is None:
|
||||
if self.link_one.state == LINK_DOWN:
|
||||
@ -527,7 +526,7 @@ def this_hosts_alarm(hostname, eid):
|
||||
#
|
||||
##########################################################################
|
||||
def clear_alarms(alarm_id_list):
|
||||
""" Clear alarm state of all plugin alarms. """
|
||||
"""Clear alarm state of all plugin alarms"""
|
||||
found = False
|
||||
for alarm_id in alarm_id_list:
|
||||
alarms = api.get_faults_by_id(alarm_id)
|
||||
|
@ -76,9 +76,7 @@ def log_meminfo(plugin, name, meminfo):
|
||||
|
||||
|
||||
def config_func(config):
|
||||
"""
|
||||
Configure the memory usage plugin
|
||||
"""
|
||||
"""Configure the memory usage plugin"""
|
||||
|
||||
for node in config.children:
|
||||
key = node.key.lower()
|
||||
|
@ -79,9 +79,7 @@ PLUGIN__EXAMPLE = 'example'
|
||||
class collectdMtceNotifierObject:
|
||||
|
||||
def __init__(self, port):
|
||||
"""
|
||||
collectdMtceNotifierObject Class constructor
|
||||
"""
|
||||
"""collectdMtceNotifierObject Class constructor"""
|
||||
# default maintenance port
|
||||
self.port = port
|
||||
self.addr = None
|
||||
@ -119,9 +117,7 @@ obj = collectdMtceNotifierObject(MTCE_CMD_RX_PORT)
|
||||
|
||||
|
||||
def _get_active_controller_ip():
|
||||
"""
|
||||
Get the active controller host IP
|
||||
"""
|
||||
"""Get the active controller host IP"""
|
||||
|
||||
try:
|
||||
obj.addr = socket.getaddrinfo('controller', None)[0][4][0]
|
||||
@ -134,9 +130,7 @@ def _get_active_controller_ip():
|
||||
|
||||
|
||||
def _df_instance_to_path(df_inst):
|
||||
"""
|
||||
Convert a df instance name to a mountpoint
|
||||
"""
|
||||
"""Convert a df instance name to a mountpoint"""
|
||||
|
||||
# df_root is not a dynamic file system. Ignore that one.
|
||||
if df_inst == 'df_root':
|
||||
@ -148,9 +142,7 @@ def _df_instance_to_path(df_inst):
|
||||
|
||||
# This function removes degraded file systems that are no longer present.
|
||||
def _clear_degrade_for_missing_filesystems():
|
||||
"""
|
||||
Remove degraded file systems that are no longer mounted or present.
|
||||
"""
|
||||
"""Remove degraded file systems that are no longer mounted or present"""
|
||||
|
||||
for df_inst in obj.degrade_list:
|
||||
|
||||
@ -178,9 +170,7 @@ def _clear_degrade_for_missing_filesystems():
|
||||
# val = port number
|
||||
#
|
||||
def config_func(config):
|
||||
"""
|
||||
Configure the maintenance degrade notifier plugin.
|
||||
"""
|
||||
"""Configure the maintenance degrade notifier plugin"""
|
||||
|
||||
collectd.debug('%s config function' % PLUGIN)
|
||||
for node in config.children:
|
||||
@ -200,9 +190,7 @@ def config_func(config):
|
||||
|
||||
# Collectd calls this function on startup.
|
||||
def init_func():
|
||||
"""
|
||||
Collectd Mtce Notifier Initialization Function
|
||||
"""
|
||||
"""Collectd Mtce Notifier Initialization Function"""
|
||||
|
||||
obj.host = os.uname()[1]
|
||||
collectd.info("%s %s:%s sending to mtce port %d" %
|
||||
@ -221,9 +209,7 @@ def init_func():
|
||||
# 4. send mtcAgent the degrade state message.
|
||||
#
|
||||
def notifier_func(nObject):
|
||||
"""
|
||||
Collectd Mtce Notifier Handler Function
|
||||
"""
|
||||
"""Collectd Mtce Notifier Handler Function"""
|
||||
|
||||
# Create the resource name from the notifier object.
|
||||
# format: <plugin name>_<plugin_instance_name>
|
||||
|
@ -254,10 +254,7 @@ def _clear_base_alarm():
|
||||
###############################################################################
|
||||
|
||||
def _remove_ip_from_unreachable_list(ip):
|
||||
"""
|
||||
Remove an IP address from the unreachable list and
|
||||
clear any NTP alarm that might be asserted for it.
|
||||
"""
|
||||
"""Remove an IP address from the unreachable list and clear its NTP alarms"""
|
||||
|
||||
# remove from unreachable list if its there
|
||||
if ip and ip in obj.unreachable_servers:
|
||||
@ -299,7 +296,7 @@ def _remove_ip_from_unreachable_list(ip):
|
||||
###############################################################################
|
||||
|
||||
def _add_ip_to_ntpq_server_list(ip):
|
||||
""" Add this IP to the list of servers that ntpq reports against. """
|
||||
"""Add this IP to the list of servers that ntpq reports against"""
|
||||
|
||||
if ip not in obj.server_list_ntpq:
|
||||
obj.server_list_ntpq.append(ip)
|
||||
@ -433,7 +430,7 @@ def _is_controller(ip):
|
||||
###############################################################################
|
||||
|
||||
def _is_uuid_like(val):
|
||||
"""Returns validation of a value as a UUID."""
|
||||
"""Returns validation of a value as a UUID"""
|
||||
try:
|
||||
return str(uuid.UUID(val)) == val
|
||||
except (TypeError, ValueError, AttributeError):
|
||||
|
@ -280,7 +280,7 @@ class PluginObject(object):
|
||||
|
||||
|
||||
def is_uuid_like(val):
|
||||
"""Returns validation of a value as a UUID.
|
||||
"""Returns validation of a value as a UUID
|
||||
|
||||
For our purposes, a UUID is a canonical form string:
|
||||
aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa
|
||||
|
@ -70,7 +70,7 @@ obj = pc.PluginObject(PLUGIN, "")
|
||||
|
||||
# Raise Remote Logging Server Alarm
|
||||
def raise_alarm():
|
||||
""" Raise Remote Logging Server Alarm. """
|
||||
"""Raise Remote Logging Server Alarm"""
|
||||
|
||||
repair = 'Ensure Remote Log Server IP is reachable from '
|
||||
repair += 'Controller through OAM interface; otherwise '
|
||||
|
@ -107,14 +107,15 @@ LIBVIRT_REAP_SEC = LIBVIRT_TIMEOUT_SEC + 2.0
|
||||
|
||||
# Define a context manager to suppress stdout and stderr.
|
||||
class suppress_stdout_stderr(object):
|
||||
'''
|
||||
A context manager for doing a "deep suppression" of stdout and stderr in
|
||||
Python, i.e. will suppress all print, even if the print originates in a
|
||||
"""Context manager for doing a "deep suppression" of stdout and stderr
|
||||
|
||||
i.e. will suppress all print, even if the print originates in a
|
||||
compiled C/Fortran sub-function.
|
||||
|
||||
This will not suppress raised exceptions, since exceptions are printed
|
||||
to stderr just before a script exits, and after the context manager has
|
||||
exited (at least, I think that is why it lets exceptions through).
|
||||
'''
|
||||
"""
|
||||
def __init__(self):
|
||||
# Open a pair of null files
|
||||
self.null_fds = [os.open(os.devnull, os.O_RDWR) for x in range(2)]
|
||||
@ -140,9 +141,7 @@ def atoi(text):
|
||||
|
||||
|
||||
def natural_keys(text):
|
||||
'''
|
||||
alist.sort(key=natural_keys) sorts in human order
|
||||
'''
|
||||
"""alist.sort(key=natural_keys) sorts in human order"""
|
||||
return [atoi(c) for c in re.split('(\d+)', text)]
|
||||
|
||||
|
||||
@ -253,6 +252,7 @@ def help_text_epilog():
|
||||
|
||||
class ChoiceOpt(cfg.Opt):
|
||||
r"""Option with List(String) type
|
||||
|
||||
Option with ``type`` :class:`oslo_config.types.List`
|
||||
:param name: the option's name
|
||||
:param choices: Optional sequence of either valid values or tuples of valid
|
||||
@ -269,9 +269,7 @@ class ChoiceOpt(cfg.Opt):
|
||||
|
||||
|
||||
def parse_arguments(debug, show):
|
||||
"""
|
||||
Parse command line arguments.
|
||||
"""
|
||||
"""Parse command line arguments"""
|
||||
|
||||
# Initialize all debug flags to False
|
||||
define_debug_flags(debug)
|
||||
@ -357,7 +355,7 @@ def parse_arguments(debug, show):
|
||||
|
||||
|
||||
def configure_logging(logger, level=logging.DEBUG):
|
||||
""" Configure logger streams and format. """
|
||||
"""Configure logger streams and format"""
|
||||
logger.setLevel(level)
|
||||
ch = logging.StreamHandler(sys.stdout)
|
||||
ch.setLevel(level)
|
||||
@ -368,8 +366,10 @@ def configure_logging(logger, level=logging.DEBUG):
|
||||
|
||||
|
||||
def _translate_keys(collection, convert):
|
||||
""" For a collection of elements, translate _info field names
|
||||
into human-readable names based on a list of conversion tuples.
|
||||
"""translate elements _info field names into human-readable names
|
||||
|
||||
:param collection: dictionary containing the elements to be translated
|
||||
:param convert: list of conversion tuples
|
||||
"""
|
||||
for k, item in collection.items():
|
||||
keys = list(item.__dict__.keys())
|
||||
@ -384,7 +384,7 @@ def _translate_keys(collection, convert):
|
||||
|
||||
|
||||
def _translate_extended_states(collection):
|
||||
""" Return human readable power-state string. """
|
||||
"""Return human readable power-state string"""
|
||||
power_states = [
|
||||
'NOSTATE', # 0x00
|
||||
'Running', # 0x01
|
||||
@ -408,7 +408,7 @@ def _translate_extended_states(collection):
|
||||
|
||||
|
||||
def _translate_virDomainState(state):
|
||||
""" Return human readable virtual domain state string. """
|
||||
"""Return human readable virtual domain state string"""
|
||||
states = {}
|
||||
states[0] = 'NOSTATE'
|
||||
states[1] = 'Running'
|
||||
@ -423,7 +423,7 @@ def _translate_virDomainState(state):
|
||||
|
||||
|
||||
def _translate_virVcpuState(state):
|
||||
""" Return human readable virtual vpu state string. """
|
||||
"""Return human readable virtual vpu state string"""
|
||||
states = {}
|
||||
states[0] = 'Offline'
|
||||
states[1] = 'Running'
|
||||
@ -433,7 +433,7 @@ def _translate_virVcpuState(state):
|
||||
|
||||
|
||||
def _mask_to_cpulist(mask=0):
|
||||
""" Create cpulist from mask, list in socket-core-thread enumerated order.
|
||||
"""Create cpulist from mask, list in socket-core-thread enumerated order
|
||||
|
||||
:param extended: extended info
|
||||
:param mask: cpuset mask
|
||||
@ -452,11 +452,11 @@ def _mask_to_cpulist(mask=0):
|
||||
|
||||
|
||||
def string_to_cpulist(cpus_str=''):
|
||||
''' Convert a string representation to cpulist
|
||||
"""Convert a string representation to cpulist
|
||||
|
||||
:param cpus_str: string containing list cpus, eg., 1,2,6-7
|
||||
:returns cpulist
|
||||
'''
|
||||
"""
|
||||
|
||||
# Create list of excluded cpus by parsing excluded_cpulist_str,
|
||||
# example: 1,2,6-7
|
||||
@ -480,7 +480,8 @@ def string_to_cpulist(cpus_str=''):
|
||||
|
||||
|
||||
def list_to_range(L=None):
|
||||
""" Convert a list into a string of comma separate ranges.
|
||||
"""Convert a list into a string of comma separate ranges
|
||||
|
||||
E.g., [1,2,3,8,9,15] is converted to '1-3,8-9,15'
|
||||
"""
|
||||
if L is None:
|
||||
@ -491,8 +492,9 @@ def list_to_range(L=None):
|
||||
|
||||
|
||||
def range_to_list(csv_range=None):
|
||||
""" Convert a string of comma separate ranges into an expanded list of
|
||||
integers. E.g., '1-3,8-9,15' is converted to [1,2,3,8,9,15]
|
||||
"""Convert a string of comma separate ranges into an expanded list of ints
|
||||
|
||||
E.g., '1-3,8-9,15' is converted to [1,2,3,8,9,15]
|
||||
"""
|
||||
if not csv_range:
|
||||
return []
|
||||
@ -525,9 +527,9 @@ def libvirt_domain_info_worker(tuple_hosts):
|
||||
|
||||
|
||||
def do_libvirt_domain_info(tuple_hosts):
|
||||
"""
|
||||
Connect to libvirt for specified host, and retrieve per-domain information
|
||||
including cpu affinity per vcpu.
|
||||
"""Connect to libvirt for specified host, and retrieve per-domain information
|
||||
|
||||
The information includes cpu affinity per vcpu.
|
||||
"""
|
||||
(host) = tuple_hosts
|
||||
domains = {}
|
||||
@ -683,9 +685,7 @@ def print_debug_info(tenants=None, regions=None,
|
||||
topologies=None, topologies_idx=None, topologies_sib=None,
|
||||
computes_cell=None,
|
||||
debug=None, show=None):
|
||||
"""
|
||||
Print debug information - pretty formatting of various data structures
|
||||
"""
|
||||
"""Print debug information - pretty formatting of various data structures"""
|
||||
pp = pprint.PrettyPrinter(indent=2)
|
||||
|
||||
if True in debug.values():
|
||||
@ -779,7 +779,7 @@ def print_debug_info(tenants=None, regions=None,
|
||||
|
||||
|
||||
def define_debug_flags(debug):
|
||||
""" Define dictionary of debug flags. """
|
||||
"""Define dictionary of debug flags"""
|
||||
opts = ['all',
|
||||
'creds',
|
||||
'hypervisors',
|
||||
@ -800,7 +800,7 @@ def define_debug_flags(debug):
|
||||
|
||||
|
||||
def define_options():
|
||||
""" Define several groupings with lists of show options. """
|
||||
"""Define several groupings with lists of show options"""
|
||||
L_opts = ['brief',
|
||||
'all',
|
||||
]
|
||||
@ -826,7 +826,7 @@ def define_options():
|
||||
|
||||
def define_option_flags(show, options=None,
|
||||
L_opts=None, L_brief=None, L_details=None, L_other=None):
|
||||
""" Define dictionary of option flags. """
|
||||
"""Define dictionary of option flags"""
|
||||
if options is None:
|
||||
options = []
|
||||
if L_opts is None:
|
||||
@ -864,8 +864,7 @@ def print_all_tables(tenants=None,
|
||||
images_in_use=None,
|
||||
server_groups_in_use=None,
|
||||
debug=None, show=None):
|
||||
""" Print all summary tables using PrettyTable.
|
||||
"""
|
||||
"""Print all summary tables using PrettyTable"""
|
||||
# Print list of aggregates
|
||||
if show['aggregates']:
|
||||
print()
|
||||
@ -1413,8 +1412,7 @@ def print_all_tables(tenants=None,
|
||||
|
||||
|
||||
def _get_host_id(tenant_id=None, host_name=None):
|
||||
""" Routine defined in nova/api/openstack/compute/views/servers.py .
|
||||
"""
|
||||
"""Routine defined in nova/api/openstack/compute/views/servers.py"""
|
||||
sha_hash = hashlib.sha224(tenant_id + host_name)
|
||||
return sha_hash.hexdigest()
|
||||
|
||||
@ -1425,7 +1423,7 @@ def start_process():
|
||||
|
||||
|
||||
def get_info_and_display(show=None):
|
||||
""" Get information from various sources (keystone, nova, libvirt).
|
||||
"""Get information from various sources (keystone, nova, libvirt)
|
||||
|
||||
Display the following information in table format.
|
||||
- nova view of hypervisors and servers
|
||||
|
Loading…
Reference in New Issue
Block a user