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
2bc3391ae1
commit
cb0b2ffe1e
@ -15,6 +15,7 @@ LOG = logging.getLogger(__name__)
|
|||||||
|
|
||||||
def osd_pool_set_quota(ceph_api, pool_name, max_bytes=0, max_objects=0):
|
def osd_pool_set_quota(ceph_api, pool_name, max_bytes=0, max_objects=0):
|
||||||
"""Set the quota for an OSD pool_name
|
"""Set the quota for an OSD pool_name
|
||||||
|
|
||||||
Setting max_bytes or max_objects to 0 will disable that quota param
|
Setting max_bytes or max_objects to 0 will disable that quota param
|
||||||
:param pool_name: OSD pool_name
|
:param pool_name: OSD pool_name
|
||||||
:param max_bytes: maximum bytes for OSD pool_name
|
:param max_bytes: maximum bytes for OSD pool_name
|
||||||
@ -112,6 +113,7 @@ def osd_pool_create(ceph_api, pool_name, pg_num, pgp_num):
|
|||||||
|
|
||||||
def osd_pool_delete(ceph_api, pool_name):
|
def osd_pool_delete(ceph_api, pool_name):
|
||||||
"""Delete an osd pool
|
"""Delete an osd pool
|
||||||
|
|
||||||
:param pool_name: pool name
|
:param pool_name: pool name
|
||||||
"""
|
"""
|
||||||
response, body = ceph_api.osd_pool_delete(
|
response, body = ceph_api.osd_pool_delete(
|
||||||
|
@ -48,9 +48,7 @@ def start_polling():
|
|||||||
|
|
||||||
|
|
||||||
def handle_exception(exc_type, exc_value, exc_traceback):
|
def handle_exception(exc_type, exc_value, exc_traceback):
|
||||||
"""
|
"""Exception handler to log any uncaught exceptions"""
|
||||||
Exception handler to log any uncaught exceptions
|
|
||||||
"""
|
|
||||||
logging.error("Uncaught exception",
|
logging.error("Uncaught exception",
|
||||||
exc_info=(exc_type, exc_value, exc_traceback))
|
exc_info=(exc_type, exc_value, exc_traceback))
|
||||||
sys.__excepthook__(exc_type, exc_value, exc_traceback)
|
sys.__excepthook__(exc_type, exc_value, exc_traceback)
|
||||||
@ -60,9 +58,7 @@ def handle_exception(exc_type, exc_value, exc_traceback):
|
|||||||
# CLASSES
|
# CLASSES
|
||||||
###################
|
###################
|
||||||
class LogMgmtDaemon():
|
class LogMgmtDaemon():
|
||||||
""" Daemon process representation of
|
"""Daemon process representation of the /var/log monitoring program"""
|
||||||
the /var/log monitoring program
|
|
||||||
"""
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
# Daemon-specific init
|
# Daemon-specific init
|
||||||
self.stdin_path = '/dev/null'
|
self.stdin_path = '/dev/null'
|
||||||
|
@ -24,9 +24,7 @@ obj = ExampleObject()
|
|||||||
|
|
||||||
# The config function - called once on collectd process startup
|
# The config function - called once on collectd process startup
|
||||||
def config_func(config):
|
def config_func(config):
|
||||||
"""
|
"""Configure the plugin"""
|
||||||
Configure the plugin
|
|
||||||
"""
|
|
||||||
|
|
||||||
for node in config.children:
|
for node in config.children:
|
||||||
key = node.key.lower()
|
key = node.key.lower()
|
||||||
|
@ -217,9 +217,7 @@ class PluginObject:
|
|||||||
database_setup_in_progress = False # connection mutex
|
database_setup_in_progress = False # connection mutex
|
||||||
|
|
||||||
def __init__(self, id, plugin):
|
def __init__(self, id, plugin):
|
||||||
"""
|
"""PluginObject Class constructor"""
|
||||||
PluginObject Class constructor
|
|
||||||
"""
|
|
||||||
|
|
||||||
# plugin specific static class members.
|
# plugin specific static class members.
|
||||||
self.id = id # alarm id ; 100.1??
|
self.id = id # alarm id ; 100.1??
|
||||||
@ -272,27 +270,20 @@ class PluginObject:
|
|||||||
|
|
||||||
# For plugins that have multiple instances like df (filesystem plugin)
|
# For plugins that have multiple instances like df (filesystem plugin)
|
||||||
# we need to create an instance of this object for each one.
|
# 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 = {}
|
self.instance_objects = {}
|
||||||
|
|
||||||
def _ilog(self, string):
|
def _ilog(self, string):
|
||||||
"""
|
"""Create a collectd notifier info log with the string param"""
|
||||||
Create a collectd notifier info log with the specified string.
|
|
||||||
"""
|
|
||||||
collectd.info('%s %s : %s' % (PLUGIN, self.plugin, string))
|
collectd.info('%s %s : %s' % (PLUGIN, self.plugin, string))
|
||||||
|
|
||||||
def _llog(self, string):
|
def _llog(self, string):
|
||||||
"""
|
"""Create a collectd notifier info log with the string param if debug_lists"""
|
||||||
Create a collectd notifier info log with the specified string
|
|
||||||
if debug_lists is True.
|
|
||||||
"""
|
|
||||||
if debug_lists:
|
if debug_lists:
|
||||||
collectd.info('%s %s : %s' % (PLUGIN, self.plugin, string))
|
collectd.info('%s %s : %s' % (PLUGIN, self.plugin, string))
|
||||||
|
|
||||||
def _elog(self, string):
|
def _elog(self, string):
|
||||||
"""
|
"""Create a collectd notifier error log with the string param"""
|
||||||
Create a collectd notifier error log with the specified string.
|
|
||||||
"""
|
|
||||||
collectd.error('%s %s : %s' % (PLUGIN, self.plugin, string))
|
collectd.error('%s %s : %s' % (PLUGIN, self.plugin, string))
|
||||||
|
|
||||||
##########################################################################
|
##########################################################################
|
||||||
@ -310,7 +301,7 @@ class PluginObject:
|
|||||||
##########################################################################
|
##########################################################################
|
||||||
|
|
||||||
def _state_audit(self, location):
|
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:
|
if self.id == ALARM_ID__CPU:
|
||||||
_print_state()
|
_print_state()
|
||||||
@ -346,7 +337,7 @@ class PluginObject:
|
|||||||
##########################################################################
|
##########################################################################
|
||||||
|
|
||||||
def _manage_change(self, nObject):
|
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
|
# filter out messages to ignore ; notifications that have no value
|
||||||
if "has not been updated for" in nObject.message:
|
if "has not been updated for" in nObject.message:
|
||||||
@ -495,9 +486,7 @@ class PluginObject:
|
|||||||
##########################################################################
|
##########################################################################
|
||||||
|
|
||||||
def _severity_change(self, entity_id, severity):
|
def _severity_change(self, entity_id, severity):
|
||||||
"""
|
"""Check for a severity change"""
|
||||||
Check for a severity change
|
|
||||||
"""
|
|
||||||
|
|
||||||
if entity_id in self.warnings:
|
if entity_id in self.warnings:
|
||||||
self._llog(entity_id + " is already in warnings list")
|
self._llog(entity_id + " is already in warnings list")
|
||||||
@ -561,9 +550,7 @@ class PluginObject:
|
|||||||
#########################################################################
|
#########################################################################
|
||||||
|
|
||||||
def _manage_alarm(self, entity_id, severity):
|
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" %
|
collectd.debug("%s manage alarm %s %s %s" %
|
||||||
(PLUGIN,
|
(PLUGIN,
|
||||||
@ -675,10 +662,9 @@ class PluginObject:
|
|||||||
#
|
#
|
||||||
##########################################################################
|
##########################################################################
|
||||||
def _get_instance_object(self, eid):
|
def _get_instance_object(self, eid):
|
||||||
"""
|
"""Safely get an object from the self instance object dict while locked
|
||||||
Safely get an object from the self instance object list indexed
|
|
||||||
by eid while locked.
|
:param eid: the index for the instance object dictionary
|
||||||
:param eid:
|
|
||||||
:return: object or None
|
:return: object or None
|
||||||
"""
|
"""
|
||||||
|
|
||||||
@ -707,10 +693,10 @@ class PluginObject:
|
|||||||
#
|
#
|
||||||
##########################################################################
|
##########################################################################
|
||||||
def _add_instance_object(self, obj, eid):
|
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 obj: the object to add
|
||||||
:param eid: indexed by this eid
|
:param eid: index for instance_objects
|
||||||
:return: nothing
|
:return: nothing
|
||||||
"""
|
"""
|
||||||
try:
|
try:
|
||||||
@ -734,9 +720,7 @@ class PluginObject:
|
|||||||
#
|
#
|
||||||
##########################################################################
|
##########################################################################
|
||||||
def _copy_instance_object(self, object):
|
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.resource_name = self.resource_name
|
||||||
object.instance_name = self.instance_name
|
object.instance_name = self.instance_name
|
||||||
@ -802,9 +786,7 @@ class PluginObject:
|
|||||||
#
|
#
|
||||||
##########################################################################
|
##########################################################################
|
||||||
def _create_instance_objects(self):
|
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.
|
# Create the File System subordinate instance objects.
|
||||||
if self.id == ALARM_ID__DF:
|
if self.id == ALARM_ID__DF:
|
||||||
@ -880,9 +862,7 @@ PLUGINS = {
|
|||||||
|
|
||||||
|
|
||||||
def _get_base_object(alarm_id):
|
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:
|
for plugin in PLUGIN_NAME_LIST:
|
||||||
if PLUGINS[plugin].id == alarm_id:
|
if PLUGINS[plugin].id == alarm_id:
|
||||||
return PLUGINS[plugin]
|
return PLUGINS[plugin]
|
||||||
@ -890,9 +870,7 @@ def _get_base_object(alarm_id):
|
|||||||
|
|
||||||
|
|
||||||
def _get_object(alarm_id, eid):
|
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)
|
base_obj = _get_base_object(alarm_id)
|
||||||
if len(base_obj.instance_objects):
|
if len(base_obj.instance_objects):
|
||||||
@ -905,9 +883,7 @@ def _get_object(alarm_id, eid):
|
|||||||
|
|
||||||
|
|
||||||
def _build_entity_id(plugin, plugin_instance):
|
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
|
inst_error = False
|
||||||
|
|
||||||
@ -968,8 +944,6 @@ def _build_entity_id(plugin, plugin_instance):
|
|||||||
|
|
||||||
|
|
||||||
def _get_df_mountpoints():
|
def _get_df_mountpoints():
|
||||||
"""
|
|
||||||
"""
|
|
||||||
|
|
||||||
conf_file = PLUGIN_PATH + 'df.conf'
|
conf_file = PLUGIN_PATH + 'df.conf'
|
||||||
if not os.path.exists(conf_file):
|
if not os.path.exists(conf_file):
|
||||||
@ -996,9 +970,7 @@ def _get_df_mountpoints():
|
|||||||
|
|
||||||
|
|
||||||
def _print_obj(obj):
|
def _print_obj(obj):
|
||||||
"""
|
"""Print a single object"""
|
||||||
Print a single object
|
|
||||||
"""
|
|
||||||
base_object = False
|
base_object = False
|
||||||
for plugin in PLUGIN_NAME_LIST:
|
for plugin in PLUGIN_NAME_LIST:
|
||||||
if PLUGINS[plugin] == obj:
|
if PLUGINS[plugin] == obj:
|
||||||
@ -1045,9 +1017,7 @@ def _print_obj(obj):
|
|||||||
|
|
||||||
|
|
||||||
def _print_state(obj=None):
|
def _print_state(obj=None):
|
||||||
"""
|
"""Print the current object state"""
|
||||||
Print the current object state
|
|
||||||
"""
|
|
||||||
try:
|
try:
|
||||||
objs = []
|
objs = []
|
||||||
if obj is None:
|
if obj is None:
|
||||||
@ -1069,9 +1039,7 @@ def _print_state(obj=None):
|
|||||||
|
|
||||||
|
|
||||||
def _database_setup(database):
|
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" %
|
collectd.info("%s setting up influxdb:%s database" %
|
||||||
(PLUGIN, database))
|
(PLUGIN, database))
|
||||||
@ -1144,9 +1112,7 @@ def _database_setup(database):
|
|||||||
|
|
||||||
|
|
||||||
def _clear_alarm_for_missing_filesystems():
|
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.
|
# get the DF (filesystem plugin) base object.
|
||||||
df_base_obj = PLUGINS[PLUGIN__DF]
|
df_base_obj = PLUGINS[PLUGIN__DF]
|
||||||
|
@ -343,7 +343,6 @@ class NetworkObject:
|
|||||||
#
|
#
|
||||||
######################################################################
|
######################################################################
|
||||||
def manage_iface_alarm(self):
|
def manage_iface_alarm(self):
|
||||||
""" """
|
|
||||||
# Single Link Config
|
# Single Link Config
|
||||||
if self.link_two.name is None:
|
if self.link_two.name is None:
|
||||||
if self.link_one.state == LINK_DOWN:
|
if self.link_one.state == LINK_DOWN:
|
||||||
@ -527,7 +526,7 @@ def this_hosts_alarm(hostname, eid):
|
|||||||
#
|
#
|
||||||
##########################################################################
|
##########################################################################
|
||||||
def clear_alarms(alarm_id_list):
|
def clear_alarms(alarm_id_list):
|
||||||
""" Clear alarm state of all plugin alarms. """
|
"""Clear alarm state of all plugin alarms"""
|
||||||
found = False
|
found = False
|
||||||
for alarm_id in alarm_id_list:
|
for alarm_id in alarm_id_list:
|
||||||
alarms = api.get_faults_by_id(alarm_id)
|
alarms = api.get_faults_by_id(alarm_id)
|
||||||
|
@ -76,9 +76,7 @@ def log_meminfo(plugin, name, meminfo):
|
|||||||
|
|
||||||
|
|
||||||
def config_func(config):
|
def config_func(config):
|
||||||
"""
|
"""Configure the memory usage plugin"""
|
||||||
Configure the memory usage plugin
|
|
||||||
"""
|
|
||||||
|
|
||||||
for node in config.children:
|
for node in config.children:
|
||||||
key = node.key.lower()
|
key = node.key.lower()
|
||||||
|
@ -79,9 +79,7 @@ PLUGIN__EXAMPLE = 'example'
|
|||||||
class collectdMtceNotifierObject:
|
class collectdMtceNotifierObject:
|
||||||
|
|
||||||
def __init__(self, port):
|
def __init__(self, port):
|
||||||
"""
|
"""collectdMtceNotifierObject Class constructor"""
|
||||||
collectdMtceNotifierObject Class constructor
|
|
||||||
"""
|
|
||||||
# default maintenance port
|
# default maintenance port
|
||||||
self.port = port
|
self.port = port
|
||||||
self.addr = None
|
self.addr = None
|
||||||
@ -119,9 +117,7 @@ obj = collectdMtceNotifierObject(MTCE_CMD_RX_PORT)
|
|||||||
|
|
||||||
|
|
||||||
def _get_active_controller_ip():
|
def _get_active_controller_ip():
|
||||||
"""
|
"""Get the active controller host IP"""
|
||||||
Get the active controller host IP
|
|
||||||
"""
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
obj.addr = socket.getaddrinfo('controller', None)[0][4][0]
|
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):
|
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.
|
# df_root is not a dynamic file system. Ignore that one.
|
||||||
if df_inst == 'df_root':
|
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.
|
# This function removes degraded file systems that are no longer present.
|
||||||
def _clear_degrade_for_missing_filesystems():
|
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:
|
for df_inst in obj.degrade_list:
|
||||||
|
|
||||||
@ -178,9 +170,7 @@ def _clear_degrade_for_missing_filesystems():
|
|||||||
# val = port number
|
# val = port number
|
||||||
#
|
#
|
||||||
def config_func(config):
|
def config_func(config):
|
||||||
"""
|
"""Configure the maintenance degrade notifier plugin"""
|
||||||
Configure the maintenance degrade notifier plugin.
|
|
||||||
"""
|
|
||||||
|
|
||||||
collectd.debug('%s config function' % PLUGIN)
|
collectd.debug('%s config function' % PLUGIN)
|
||||||
for node in config.children:
|
for node in config.children:
|
||||||
@ -200,9 +190,7 @@ def config_func(config):
|
|||||||
|
|
||||||
# Collectd calls this function on startup.
|
# Collectd calls this function on startup.
|
||||||
def init_func():
|
def init_func():
|
||||||
"""
|
"""Collectd Mtce Notifier Initialization Function"""
|
||||||
Collectd Mtce Notifier Initialization Function
|
|
||||||
"""
|
|
||||||
|
|
||||||
obj.host = os.uname()[1]
|
obj.host = os.uname()[1]
|
||||||
collectd.info("%s %s:%s sending to mtce port %d" %
|
collectd.info("%s %s:%s sending to mtce port %d" %
|
||||||
@ -221,9 +209,7 @@ def init_func():
|
|||||||
# 4. send mtcAgent the degrade state message.
|
# 4. send mtcAgent the degrade state message.
|
||||||
#
|
#
|
||||||
def notifier_func(nObject):
|
def notifier_func(nObject):
|
||||||
"""
|
"""Collectd Mtce Notifier Handler Function"""
|
||||||
Collectd Mtce Notifier Handler Function
|
|
||||||
"""
|
|
||||||
|
|
||||||
# Create the resource name from the notifier object.
|
# Create the resource name from the notifier object.
|
||||||
# format: <plugin name>_<plugin_instance_name>
|
# format: <plugin name>_<plugin_instance_name>
|
||||||
|
@ -254,10 +254,7 @@ def _clear_base_alarm():
|
|||||||
###############################################################################
|
###############################################################################
|
||||||
|
|
||||||
def _remove_ip_from_unreachable_list(ip):
|
def _remove_ip_from_unreachable_list(ip):
|
||||||
"""
|
"""Remove an IP address from the unreachable list and clear its NTP alarms"""
|
||||||
Remove an IP address from the unreachable list and
|
|
||||||
clear any NTP alarm that might be asserted for it.
|
|
||||||
"""
|
|
||||||
|
|
||||||
# remove from unreachable list if its there
|
# remove from unreachable list if its there
|
||||||
if ip and ip in obj.unreachable_servers:
|
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):
|
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:
|
if ip not in obj.server_list_ntpq:
|
||||||
obj.server_list_ntpq.append(ip)
|
obj.server_list_ntpq.append(ip)
|
||||||
@ -433,7 +430,7 @@ def _is_controller(ip):
|
|||||||
###############################################################################
|
###############################################################################
|
||||||
|
|
||||||
def _is_uuid_like(val):
|
def _is_uuid_like(val):
|
||||||
"""Returns validation of a value as a UUID."""
|
"""Returns validation of a value as a UUID"""
|
||||||
try:
|
try:
|
||||||
return str(uuid.UUID(val)) == val
|
return str(uuid.UUID(val)) == val
|
||||||
except (TypeError, ValueError, AttributeError):
|
except (TypeError, ValueError, AttributeError):
|
||||||
|
@ -280,7 +280,7 @@ class PluginObject(object):
|
|||||||
|
|
||||||
|
|
||||||
def is_uuid_like(val):
|
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:
|
For our purposes, a UUID is a canonical form string:
|
||||||
aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa
|
aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa
|
||||||
|
@ -70,7 +70,7 @@ obj = pc.PluginObject(PLUGIN, "")
|
|||||||
|
|
||||||
# Raise Remote Logging Server Alarm
|
# Raise Remote Logging Server Alarm
|
||||||
def raise_alarm():
|
def raise_alarm():
|
||||||
""" Raise Remote Logging Server Alarm. """
|
"""Raise Remote Logging Server Alarm"""
|
||||||
|
|
||||||
repair = 'Ensure Remote Log Server IP is reachable from '
|
repair = 'Ensure Remote Log Server IP is reachable from '
|
||||||
repair += 'Controller through OAM interface; otherwise '
|
repair += 'Controller through OAM interface; otherwise '
|
||||||
|
@ -57,9 +57,7 @@ def configure_debuggubg(debug):
|
|||||||
|
|
||||||
|
|
||||||
def parse_arguments(show):
|
def parse_arguments(show):
|
||||||
"""
|
"""Parse command line arguments"""
|
||||||
Parse command line arguments.
|
|
||||||
"""
|
|
||||||
|
|
||||||
parser = argparse.ArgumentParser(
|
parser = argparse.ArgumentParser(
|
||||||
prog=os.path.basename(sys.argv[0]),
|
prog=os.path.basename(sys.argv[0]),
|
||||||
@ -142,8 +140,7 @@ def parse_arguments(show):
|
|||||||
|
|
||||||
|
|
||||||
def get_system_creds():
|
def get_system_creds():
|
||||||
|
"""Return keystone credentials by sourcing /etc/platform/openrc"""
|
||||||
""" Return keystone credentials by sourcing /etc/platform/openrc. """
|
|
||||||
d = {}
|
d = {}
|
||||||
|
|
||||||
proc = subprocess.Popen(['bash', '-c',
|
proc = subprocess.Popen(['bash', '-c',
|
||||||
@ -188,8 +185,7 @@ def convert_to_readable_size(size, orig_unit='B'):
|
|||||||
|
|
||||||
|
|
||||||
def print_disk_view(rows=None, extended=False):
|
def print_disk_view(rows=None, extended=False):
|
||||||
|
"""Print all summary Disk views using PrettyTable"""
|
||||||
""" Print all summary Disk views using PrettyTable. """
|
|
||||||
|
|
||||||
disk_lables_extended = \
|
disk_lables_extended = \
|
||||||
['Host', 'Device Node', 'Device Type', 'UUID', 'Size',
|
['Host', 'Device Node', 'Device Type', 'UUID', 'Size',
|
||||||
@ -216,8 +212,7 @@ def print_disk_view(rows=None, extended=False):
|
|||||||
|
|
||||||
|
|
||||||
def print_vg_view(rows=None, extended=False):
|
def print_vg_view(rows=None, extended=False):
|
||||||
|
"""Print all summary VG views using PrettyTable"""
|
||||||
""" Print all summary VG views using PrettyTable. """
|
|
||||||
vg_labels_extended = \
|
vg_labels_extended = \
|
||||||
['Host', 'VG Name', 'UUID', 'VG State', 'VG Size', 'Current LVs',
|
['Host', 'VG Name', 'UUID', 'VG State', 'VG Size', 'Current LVs',
|
||||||
'Current PVs', 'PV List (name:state:uuid)', 'VG Parameters']
|
'Current PVs', 'PV List (name:state:uuid)', 'VG Parameters']
|
||||||
@ -246,9 +241,9 @@ def print_vg_view(rows=None, extended=False):
|
|||||||
|
|
||||||
|
|
||||||
def get_info_and_display(cc, show=None):
|
def get_info_and_display(cc, show=None):
|
||||||
""" Get storage information from server nodes.
|
"""Get storage information from server nodes
|
||||||
|
|
||||||
Display the following information in table format.
|
Display the following information in table format:
|
||||||
- disk data of all server nodes
|
- disk data of all server nodes
|
||||||
- VG data of all servers nodes
|
- VG data of all servers nodes
|
||||||
"""
|
"""
|
||||||
|
@ -107,14 +107,15 @@ LIBVIRT_REAP_SEC = LIBVIRT_TIMEOUT_SEC + 2.0
|
|||||||
|
|
||||||
# Define a context manager to suppress stdout and stderr.
|
# Define a context manager to suppress stdout and stderr.
|
||||||
class suppress_stdout_stderr(object):
|
class suppress_stdout_stderr(object):
|
||||||
'''
|
"""Context manager for doing a "deep suppression" of stdout and stderr
|
||||||
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
|
i.e. will suppress all print, even if the print originates in a
|
||||||
compiled C/Fortran sub-function.
|
compiled C/Fortran sub-function.
|
||||||
|
|
||||||
This will not suppress raised exceptions, since exceptions are printed
|
This will not suppress raised exceptions, since exceptions are printed
|
||||||
to stderr just before a script exits, and after the context manager has
|
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).
|
exited (at least, I think that is why it lets exceptions through).
|
||||||
'''
|
"""
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
# Open a pair of null files
|
# Open a pair of null files
|
||||||
self.null_fds = [os.open(os.devnull, os.O_RDWR) for x in range(2)]
|
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):
|
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)]
|
return [atoi(c) for c in re.split('(\d+)', text)]
|
||||||
|
|
||||||
|
|
||||||
@ -253,6 +252,7 @@ def help_text_epilog():
|
|||||||
|
|
||||||
class ChoiceOpt(cfg.Opt):
|
class ChoiceOpt(cfg.Opt):
|
||||||
r"""Option with List(String) type
|
r"""Option with List(String) type
|
||||||
|
|
||||||
Option with ``type`` :class:`oslo_config.types.List`
|
Option with ``type`` :class:`oslo_config.types.List`
|
||||||
:param name: the option's name
|
:param name: the option's name
|
||||||
:param choices: Optional sequence of either valid values or tuples of valid
|
: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):
|
def parse_arguments(debug, show):
|
||||||
"""
|
"""Parse command line arguments"""
|
||||||
Parse command line arguments.
|
|
||||||
"""
|
|
||||||
|
|
||||||
# Initialize all debug flags to False
|
# Initialize all debug flags to False
|
||||||
define_debug_flags(debug)
|
define_debug_flags(debug)
|
||||||
@ -357,7 +355,7 @@ def parse_arguments(debug, show):
|
|||||||
|
|
||||||
|
|
||||||
def configure_logging(logger, level=logging.DEBUG):
|
def configure_logging(logger, level=logging.DEBUG):
|
||||||
""" Configure logger streams and format. """
|
"""Configure logger streams and format"""
|
||||||
logger.setLevel(level)
|
logger.setLevel(level)
|
||||||
ch = logging.StreamHandler(sys.stdout)
|
ch = logging.StreamHandler(sys.stdout)
|
||||||
ch.setLevel(level)
|
ch.setLevel(level)
|
||||||
@ -368,8 +366,10 @@ def configure_logging(logger, level=logging.DEBUG):
|
|||||||
|
|
||||||
|
|
||||||
def _translate_keys(collection, convert):
|
def _translate_keys(collection, convert):
|
||||||
""" For a collection of elements, translate _info field names
|
"""translate elements _info field names into human-readable names
|
||||||
into human-readable names based on a list of conversion tuples.
|
|
||||||
|
:param collection: dictionary containing the elements to be translated
|
||||||
|
:param convert: list of conversion tuples
|
||||||
"""
|
"""
|
||||||
for k, item in collection.items():
|
for k, item in collection.items():
|
||||||
keys = list(item.__dict__.keys())
|
keys = list(item.__dict__.keys())
|
||||||
@ -384,7 +384,7 @@ def _translate_keys(collection, convert):
|
|||||||
|
|
||||||
|
|
||||||
def _translate_extended_states(collection):
|
def _translate_extended_states(collection):
|
||||||
""" Return human readable power-state string. """
|
"""Return human readable power-state string"""
|
||||||
power_states = [
|
power_states = [
|
||||||
'NOSTATE', # 0x00
|
'NOSTATE', # 0x00
|
||||||
'Running', # 0x01
|
'Running', # 0x01
|
||||||
@ -408,7 +408,7 @@ def _translate_extended_states(collection):
|
|||||||
|
|
||||||
|
|
||||||
def _translate_virDomainState(state):
|
def _translate_virDomainState(state):
|
||||||
""" Return human readable virtual domain state string. """
|
"""Return human readable virtual domain state string"""
|
||||||
states = {}
|
states = {}
|
||||||
states[0] = 'NOSTATE'
|
states[0] = 'NOSTATE'
|
||||||
states[1] = 'Running'
|
states[1] = 'Running'
|
||||||
@ -423,7 +423,7 @@ def _translate_virDomainState(state):
|
|||||||
|
|
||||||
|
|
||||||
def _translate_virVcpuState(state):
|
def _translate_virVcpuState(state):
|
||||||
""" Return human readable virtual vpu state string. """
|
"""Return human readable virtual vpu state string"""
|
||||||
states = {}
|
states = {}
|
||||||
states[0] = 'Offline'
|
states[0] = 'Offline'
|
||||||
states[1] = 'Running'
|
states[1] = 'Running'
|
||||||
@ -433,7 +433,7 @@ def _translate_virVcpuState(state):
|
|||||||
|
|
||||||
|
|
||||||
def _mask_to_cpulist(mask=0):
|
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 extended: extended info
|
||||||
:param mask: cpuset mask
|
:param mask: cpuset mask
|
||||||
@ -452,11 +452,11 @@ def _mask_to_cpulist(mask=0):
|
|||||||
|
|
||||||
|
|
||||||
def string_to_cpulist(cpus_str=''):
|
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
|
:param cpus_str: string containing list cpus, eg., 1,2,6-7
|
||||||
:returns cpulist
|
:returns cpulist
|
||||||
'''
|
"""
|
||||||
|
|
||||||
# Create list of excluded cpus by parsing excluded_cpulist_str,
|
# Create list of excluded cpus by parsing excluded_cpulist_str,
|
||||||
# example: 1,2,6-7
|
# example: 1,2,6-7
|
||||||
@ -480,7 +480,8 @@ def string_to_cpulist(cpus_str=''):
|
|||||||
|
|
||||||
|
|
||||||
def list_to_range(L=None):
|
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'
|
E.g., [1,2,3,8,9,15] is converted to '1-3,8-9,15'
|
||||||
"""
|
"""
|
||||||
if L is None:
|
if L is None:
|
||||||
@ -491,8 +492,9 @@ def list_to_range(L=None):
|
|||||||
|
|
||||||
|
|
||||||
def range_to_list(csv_range=None):
|
def range_to_list(csv_range=None):
|
||||||
""" Convert a string of comma separate ranges into an expanded list of
|
"""Convert a string of comma separate ranges into an expanded list of ints
|
||||||
integers. E.g., '1-3,8-9,15' is converted to [1,2,3,8,9,15]
|
|
||||||
|
E.g., '1-3,8-9,15' is converted to [1,2,3,8,9,15]
|
||||||
"""
|
"""
|
||||||
if not csv_range:
|
if not csv_range:
|
||||||
return []
|
return []
|
||||||
@ -525,9 +527,9 @@ def libvirt_domain_info_worker(tuple_hosts):
|
|||||||
|
|
||||||
|
|
||||||
def do_libvirt_domain_info(tuple_hosts):
|
def do_libvirt_domain_info(tuple_hosts):
|
||||||
"""
|
"""Connect to libvirt for specified host, and retrieve per-domain information
|
||||||
Connect to libvirt for specified host, and retrieve per-domain information
|
|
||||||
including cpu affinity per vcpu.
|
The information includes cpu affinity per vcpu.
|
||||||
"""
|
"""
|
||||||
(host) = tuple_hosts
|
(host) = tuple_hosts
|
||||||
domains = {}
|
domains = {}
|
||||||
@ -683,9 +685,7 @@ def print_debug_info(tenants=None, regions=None,
|
|||||||
topologies=None, topologies_idx=None, topologies_sib=None,
|
topologies=None, topologies_idx=None, topologies_sib=None,
|
||||||
computes_cell=None,
|
computes_cell=None,
|
||||||
debug=None, show=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)
|
pp = pprint.PrettyPrinter(indent=2)
|
||||||
|
|
||||||
if True in debug.values():
|
if True in debug.values():
|
||||||
@ -779,7 +779,7 @@ def print_debug_info(tenants=None, regions=None,
|
|||||||
|
|
||||||
|
|
||||||
def define_debug_flags(debug):
|
def define_debug_flags(debug):
|
||||||
""" Define dictionary of debug flags. """
|
"""Define dictionary of debug flags"""
|
||||||
opts = ['all',
|
opts = ['all',
|
||||||
'creds',
|
'creds',
|
||||||
'hypervisors',
|
'hypervisors',
|
||||||
@ -800,7 +800,7 @@ def define_debug_flags(debug):
|
|||||||
|
|
||||||
|
|
||||||
def define_options():
|
def define_options():
|
||||||
""" Define several groupings with lists of show options. """
|
"""Define several groupings with lists of show options"""
|
||||||
L_opts = ['brief',
|
L_opts = ['brief',
|
||||||
'all',
|
'all',
|
||||||
]
|
]
|
||||||
@ -826,7 +826,7 @@ def define_options():
|
|||||||
|
|
||||||
def define_option_flags(show, options=None,
|
def define_option_flags(show, options=None,
|
||||||
L_opts=None, L_brief=None, L_details=None, L_other=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:
|
if options is None:
|
||||||
options = []
|
options = []
|
||||||
if L_opts is None:
|
if L_opts is None:
|
||||||
@ -864,8 +864,7 @@ def print_all_tables(tenants=None,
|
|||||||
images_in_use=None,
|
images_in_use=None,
|
||||||
server_groups_in_use=None,
|
server_groups_in_use=None,
|
||||||
debug=None, show=None):
|
debug=None, show=None):
|
||||||
""" Print all summary tables using PrettyTable.
|
"""Print all summary tables using PrettyTable"""
|
||||||
"""
|
|
||||||
# Print list of aggregates
|
# Print list of aggregates
|
||||||
if show['aggregates']:
|
if show['aggregates']:
|
||||||
print()
|
print()
|
||||||
@ -1413,8 +1412,7 @@ def print_all_tables(tenants=None,
|
|||||||
|
|
||||||
|
|
||||||
def _get_host_id(tenant_id=None, host_name=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)
|
sha_hash = hashlib.sha224(tenant_id + host_name)
|
||||||
return sha_hash.hexdigest()
|
return sha_hash.hexdigest()
|
||||||
|
|
||||||
@ -1425,7 +1423,7 @@ def start_process():
|
|||||||
|
|
||||||
|
|
||||||
def get_info_and_display(show=None):
|
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.
|
Display the following information in table format.
|
||||||
- nova view of hypervisors and servers
|
- nova view of hypervisors and servers
|
||||||
|
5
tox.ini
5
tox.ini
@ -50,9 +50,6 @@ commands =
|
|||||||
# H237: module exception is removed in Python 3
|
# H237: module exception is removed in Python 3
|
||||||
# H238: old style class declaration, use new style
|
# H238: old style class declaration, use new style
|
||||||
# H306: imports not in alphabetical order
|
# H306: imports not in alphabetical order
|
||||||
# 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
|
|
||||||
# W series
|
# W series
|
||||||
# W191 indentation contains tabs
|
# W191 indentation contains tabs
|
||||||
# W291 trailing whitespace
|
# W291 trailing whitespace
|
||||||
@ -67,7 +64,7 @@ commands =
|
|||||||
# F series
|
# F series
|
||||||
# F401 'module' imported but unused
|
# F401 'module' imported but unused
|
||||||
ignore = E265,E266,E402,E501,E722
|
ignore = E265,E266,E402,E501,E722
|
||||||
H101,H102,H104,H201,H238,H237,H306,H401,H404,H405,
|
H101,H102,H104,H201,H238,H237,H306,
|
||||||
W191,W291,W391,W503,
|
W191,W291,W391,W503,
|
||||||
B001,B007,B009,B010,B301,
|
B001,B007,B009,B010,B301,
|
||||||
F401
|
F401
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
|
|
||||||
class ValidateError(Exception):
|
class ValidateError(Exception):
|
||||||
"""Base class for license validation exceptions."""
|
"""Base class for license validation exceptions"""
|
||||||
|
|
||||||
def __init__(self, message=None):
|
def __init__(self, message=None):
|
||||||
self.message = message
|
self.message = message
|
||||||
|
Loading…
Reference in New Issue
Block a user