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:
Eric Barrett 2019-04-18 09:11:20 -04:00
parent 70bbb84587
commit 7c67589b1b
11 changed files with 119 additions and 177 deletions

View File

@ -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()

View File

@ -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]

View File

@ -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)

View File

@ -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()

View File

@ -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>

View File

@ -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):

View File

@ -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

View File

@ -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 '

View File

@ -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