Delete log translation functions and add hacking rule
The i18n team has decided not to translate the logs because it seems like it not very useful; operators prefer to have them in English so that they can search for those strings on the internet. Since we have removed log translations completely, we should add hacking rule to prevent future mistakes. Change-Id: I3ec4ae79db525640bb5d6369727985d5071b7fd4
This commit is contained in:
parent
745cebc9ef
commit
1d3d04150c
@ -20,3 +20,4 @@ Zun Specific Commandments
|
|||||||
- [Z338] Use assertIn/NotIn(A, B) rather than assertEqual(A in B, True/False).
|
- [Z338] Use assertIn/NotIn(A, B) rather than assertEqual(A in B, True/False).
|
||||||
- [Z339] Don't use xrange()
|
- [Z339] Don't use xrange()
|
||||||
- [Z352] LOG.warn is deprecated. Enforce use of LOG.warning.
|
- [Z352] LOG.warn is deprecated. Enforce use of LOG.warning.
|
||||||
|
- [Z353] Don't translate logs.
|
||||||
|
@ -300,10 +300,9 @@ class DockerDriver(driver.ComputeDriver):
|
|||||||
if not hasattr(self, '_nodename'):
|
if not hasattr(self, '_nodename'):
|
||||||
self._nodename = nodename
|
self._nodename = nodename
|
||||||
if nodename != self._nodename:
|
if nodename != self._nodename:
|
||||||
LOG.error(_('Hostname has changed from %(old)s to %(new)s. '
|
LOG.error('Hostname has changed from %(old)s to %(new)s. '
|
||||||
'A restart is required to take effect.'
|
'A restart is required to take effect.',
|
||||||
), {'old': self._nodename,
|
{'old': self._nodename, 'new': nodename})
|
||||||
'new': nodename})
|
|
||||||
|
|
||||||
memory = hostinfo.get_memory_usage()
|
memory = hostinfo.get_memory_usage()
|
||||||
disk = hostinfo.get_disk_usage()
|
disk = hostinfo.get_disk_usage()
|
||||||
@ -383,8 +382,8 @@ class DockerDriver(driver.ComputeDriver):
|
|||||||
except Exception as e:
|
except Exception as e:
|
||||||
# If failed to load image from shared_directory, continue
|
# If failed to load image from shared_directory, continue
|
||||||
# to download the image from glance then load.
|
# to download the image from glance then load.
|
||||||
LOG.warning(_('Cannot load repository file from shared '
|
LOG.warning('Cannot load repository file from shared '
|
||||||
'directory: %s'),
|
'directory: %s',
|
||||||
e, instance=instance, exc_info=True)
|
e, instance=instance, exc_info=True)
|
||||||
|
|
||||||
# TODO(imain): It would be nice to do this with file like object
|
# TODO(imain): It would be nice to do this with file like object
|
||||||
@ -408,7 +407,7 @@ class DockerDriver(driver.ComputeDriver):
|
|||||||
return self.docker.inspect_image(
|
return self.docker.inspect_image(
|
||||||
self._encode_utf8(image_meta.name))
|
self._encode_utf8(image_meta.name))
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
LOG.warning(_('Cannot load repository file: %s'),
|
LOG.warning('Cannot load repository file: %s',
|
||||||
e, instance=instance, exc_info=True)
|
e, instance=instance, exc_info=True)
|
||||||
msg = _('Cannot load repository file: {0}')
|
msg = _('Cannot load repository file: {0}')
|
||||||
raise exception.NovaException(msg.format(e),
|
raise exception.NovaException(msg.format(e),
|
||||||
@ -478,7 +477,7 @@ class DockerDriver(driver.ComputeDriver):
|
|||||||
'Timeout waiting for vif plugging',
|
'Timeout waiting for vif plugging',
|
||||||
instance_id=instance['name'])
|
instance_id=instance['name'])
|
||||||
except (Exception) as e:
|
except (Exception) as e:
|
||||||
LOG.warning(_('Cannot setup network: %s'),
|
LOG.warning('Cannot setup network: %s',
|
||||||
e, instance=instance, exc_info=True)
|
e, instance=instance, exc_info=True)
|
||||||
msg = _('Cannot setup network: {0}')
|
msg = _('Cannot setup network: {0}')
|
||||||
self.docker.kill(container_id)
|
self.docker.kill(container_id)
|
||||||
@ -580,7 +579,7 @@ class DockerDriver(driver.ComputeDriver):
|
|||||||
self.docker.stop(container_id, max(timeout, 5))
|
self.docker.stop(container_id, max(timeout, 5))
|
||||||
except errors.APIError as e:
|
except errors.APIError as e:
|
||||||
if 'Unpause the container before stopping' not in e.explanation:
|
if 'Unpause the container before stopping' not in e.explanation:
|
||||||
LOG.warning(_('Cannot stop container: %s'),
|
LOG.warning('Cannot stop container: %s',
|
||||||
e, instance=instance, exc_info=True)
|
e, instance=instance, exc_info=True)
|
||||||
raise
|
raise
|
||||||
self.docker.unpause(container_id)
|
self.docker.unpause(container_id)
|
||||||
@ -623,9 +622,8 @@ class DockerDriver(driver.ComputeDriver):
|
|||||||
if network_info:
|
if network_info:
|
||||||
self.unplug_vifs(instance, network_info)
|
self.unplug_vifs(instance, network_info)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
LOG.warning(_('Cannot destroy the container network'
|
LOG.warning('Cannot destroy the container network'
|
||||||
' during reboot {0}').format(e),
|
' during reboot {0}'.format(e), exc_info=True)
|
||||||
exc_info=True)
|
|
||||||
return
|
return
|
||||||
|
|
||||||
self.docker.start(container_id)
|
self.docker.start(container_id)
|
||||||
@ -634,7 +632,7 @@ class DockerDriver(driver.ComputeDriver):
|
|||||||
self.plug_vifs(instance, network_info)
|
self.plug_vifs(instance, network_info)
|
||||||
self._attach_vifs(instance, network_info)
|
self._attach_vifs(instance, network_info)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
LOG.warning(_('Cannot setup network on reboot: {0}'), e,
|
LOG.warning('Cannot setup network on reboot: {0}', e,
|
||||||
exc_info=True)
|
exc_info=True)
|
||||||
return
|
return
|
||||||
|
|
||||||
@ -650,7 +648,7 @@ class DockerDriver(driver.ComputeDriver):
|
|||||||
self.plug_vifs(instance, network_info)
|
self.plug_vifs(instance, network_info)
|
||||||
self._attach_vifs(instance, network_info)
|
self._attach_vifs(instance, network_info)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
LOG.debug(_('Cannot setup network: %s'),
|
LOG.debug('Cannot setup network: %s',
|
||||||
e, instance=instance, exc_info=True)
|
e, instance=instance, exc_info=True)
|
||||||
msg = _('Cannot setup network: {0}')
|
msg = _('Cannot setup network: {0}')
|
||||||
self.docker.kill(container_id)
|
self.docker.kill(container_id)
|
||||||
@ -674,7 +672,7 @@ class DockerDriver(driver.ComputeDriver):
|
|||||||
if not self.docker.pause(cont_id):
|
if not self.docker.pause(cont_id):
|
||||||
raise exception.NovaException
|
raise exception.NovaException
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
LOG.debug(_('Error pause container: %s'),
|
LOG.debug('Error pause container: %s',
|
||||||
e, instance=instance, exc_info=True)
|
e, instance=instance, exc_info=True)
|
||||||
msg = _('Cannot pause container: {0}')
|
msg = _('Cannot pause container: {0}')
|
||||||
raise exception.NovaException(msg.format(e),
|
raise exception.NovaException(msg.format(e),
|
||||||
@ -690,7 +688,7 @@ class DockerDriver(driver.ComputeDriver):
|
|||||||
if not self.docker.unpause(cont_id):
|
if not self.docker.unpause(cont_id):
|
||||||
raise exception.NovaException
|
raise exception.NovaException
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
LOG.debug(_('Error unpause container: %s'),
|
LOG.debug('Error unpause container: %s',
|
||||||
e, instance=instance, exc_info=True)
|
e, instance=instance, exc_info=True)
|
||||||
msg = _('Cannot unpause container: {0}')
|
msg = _('Cannot unpause container: {0}')
|
||||||
raise exception.NovaException(msg.format(e),
|
raise exception.NovaException(msg.format(e),
|
||||||
|
@ -33,7 +33,7 @@ def teardown_network(container_id):
|
|||||||
run_as_root=True)
|
run_as_root=True)
|
||||||
break
|
break
|
||||||
except processutils.ProcessExecutionError:
|
except processutils.ProcessExecutionError:
|
||||||
LOG.warning(_('Cannot remove network namespace, netns id: %s'),
|
LOG.warning('Cannot remove network namespace, netns id: %s',
|
||||||
container_id)
|
container_id)
|
||||||
|
|
||||||
|
|
||||||
|
@ -141,7 +141,7 @@ class OpenContrailVIFDriver(object):
|
|||||||
utils.execute('ip', 'netns', 'exec', container_id, 'ip', 'link',
|
utils.execute('ip', 'netns', 'exec', container_id, 'ip', 'link',
|
||||||
'set', if_remote_name, 'up', run_as_root=True)
|
'set', if_remote_name, 'up', run_as_root=True)
|
||||||
except Exception:
|
except Exception:
|
||||||
LOG.exception(_("Failed to attach vif"), instance=instance)
|
LOG.exception("Failed to attach vif", instance=instance)
|
||||||
|
|
||||||
def _retrieve_ip_address(self, vif, version):
|
def _retrieve_ip_address(self, vif, version):
|
||||||
address = None
|
address = None
|
||||||
@ -174,4 +174,4 @@ class OpenContrailVIFDriver(object):
|
|||||||
utils.execute('ip', 'link', 'delete', if_local_name,
|
utils.execute('ip', 'link', 'delete', if_local_name,
|
||||||
run_as_root=True)
|
run_as_root=True)
|
||||||
except Exception:
|
except Exception:
|
||||||
LOG.exception(_("Delete port failed"), instance=instance)
|
LOG.exception("Delete port failed", instance=instance)
|
||||||
|
@ -209,7 +209,7 @@ class DockerGenericVIFDriver(object):
|
|||||||
run_as_root=True)
|
run_as_root=True)
|
||||||
linux_net.delete_net_dev(if_local_name)
|
linux_net.delete_net_dev(if_local_name)
|
||||||
except processutils.ProcessExecutionError:
|
except processutils.ProcessExecutionError:
|
||||||
LOG.exception(_("Failed while unplugging vif"), instance=instance)
|
LOG.exception("Failed while unplugging vif", instance=instance)
|
||||||
|
|
||||||
def unplug_midonet(self, instance, vif):
|
def unplug_midonet(self, instance, vif):
|
||||||
"""Unplug into MidoNet's network port
|
"""Unplug into MidoNet's network port
|
||||||
@ -220,7 +220,7 @@ class DockerGenericVIFDriver(object):
|
|||||||
utils.execute('mm-ctl', '--unbind-port',
|
utils.execute('mm-ctl', '--unbind-port',
|
||||||
vif['id'], run_as_root=True)
|
vif['id'], run_as_root=True)
|
||||||
except processutils.ProcessExecutionError:
|
except processutils.ProcessExecutionError:
|
||||||
LOG.exception(_("Failed while unplugging vif"), instance=instance)
|
LOG.exception("Failed while unplugging vif", instance=instance)
|
||||||
|
|
||||||
def _create_veth_pair(self, if_local_name, if_remote_name, bridge):
|
def _create_veth_pair(self, if_local_name, if_remote_name, bridge):
|
||||||
undo_mgr = utils.UndoManager()
|
undo_mgr = utils.UndoManager()
|
||||||
|
@ -48,6 +48,10 @@ dict_constructor_with_list_copy_re = re.compile(r".*\bdict\((\[)?(\(|\[)")
|
|||||||
assert_xrange_re = re.compile(
|
assert_xrange_re = re.compile(
|
||||||
r"\s*xrange\s*\(")
|
r"\s*xrange\s*\(")
|
||||||
|
|
||||||
|
log_levels = {"debug", "error", "info", "warning", "critical", "exception"}
|
||||||
|
translated_log = re.compile(r"(.)*LOG\.(%(levels)s)\(\s*_\(" %
|
||||||
|
{'levels': '|'.join(log_levels)})
|
||||||
|
|
||||||
|
|
||||||
def no_mutable_default_args(logical_line):
|
def no_mutable_default_args(logical_line):
|
||||||
msg = "Z322: Method's default argument shouldn't be mutable!"
|
msg = "Z322: Method's default argument shouldn't be mutable!"
|
||||||
@ -121,8 +125,7 @@ def use_timeutils_utcnow(logical_line, filename):
|
|||||||
|
|
||||||
def dict_constructor_with_list_copy(logical_line):
|
def dict_constructor_with_list_copy(logical_line):
|
||||||
msg = ("Z336: Must use a dict comprehension instead of a dict constructor"
|
msg = ("Z336: Must use a dict comprehension instead of a dict constructor"
|
||||||
" with a sequence of key-value pairs."
|
" with a sequence of key-value pairs.")
|
||||||
)
|
|
||||||
if dict_constructor_with_list_copy_re.match(logical_line):
|
if dict_constructor_with_list_copy_re.match(logical_line):
|
||||||
yield (0, msg)
|
yield (0, msg)
|
||||||
|
|
||||||
@ -136,11 +139,24 @@ def no_log_warn(logical_line):
|
|||||||
Z352
|
Z352
|
||||||
"""
|
"""
|
||||||
|
|
||||||
msg = ("Z352: LOG.warn is deprecated, please use LOG.warning!")
|
msg = "Z352: LOG.warn is deprecated, please use LOG.warning!"
|
||||||
if "LOG.warn(" in logical_line:
|
if "LOG.warn(" in logical_line:
|
||||||
yield (0, msg)
|
yield (0, msg)
|
||||||
|
|
||||||
|
|
||||||
|
def no_translate_logs(logical_line):
|
||||||
|
"""Check for 'LOG.*(_('
|
||||||
|
|
||||||
|
Starting with the Pike series, OpenStack no longer supports log
|
||||||
|
translation.
|
||||||
|
|
||||||
|
Z353
|
||||||
|
"""
|
||||||
|
msg = "Z353: Log messages should not be translated!"
|
||||||
|
if translated_log.match(logical_line):
|
||||||
|
yield (0, msg)
|
||||||
|
|
||||||
|
|
||||||
def factory(register):
|
def factory(register):
|
||||||
register(no_mutable_default_args)
|
register(no_mutable_default_args)
|
||||||
register(assert_equal_true_or_false)
|
register(assert_equal_true_or_false)
|
||||||
@ -151,3 +167,4 @@ def factory(register):
|
|||||||
register(dict_constructor_with_list_copy)
|
register(dict_constructor_with_list_copy)
|
||||||
register(no_xrange)
|
register(no_xrange)
|
||||||
register(no_log_warn)
|
register(no_log_warn)
|
||||||
|
register(no_translate_logs)
|
||||||
|
@ -200,4 +200,4 @@ class KuryrNetwork(network.Network):
|
|||||||
{'port': updated_port})
|
{'port': updated_port})
|
||||||
except Exception:
|
except Exception:
|
||||||
with excutils.save_and_reraise_exception():
|
with excutils.save_and_reraise_exception():
|
||||||
LOG.exception(_("Neutron Error:"))
|
LOG.exception("Neutron Error:")
|
||||||
|
@ -232,3 +232,11 @@ class HackingTestCase(base.BaseTestCase):
|
|||||||
LOG.warning("LOG.warn is deprecated")
|
LOG.warning("LOG.warn is deprecated")
|
||||||
"""
|
"""
|
||||||
self._assert_has_no_errors(code, check)
|
self._assert_has_no_errors(code, check)
|
||||||
|
|
||||||
|
def test_no_log_translations(self):
|
||||||
|
for log in checks.log_levels:
|
||||||
|
bad = 'LOG.%s(_("Bad"))' % log
|
||||||
|
self.assertEqual(1, len(list(checks.no_translate_logs(bad))))
|
||||||
|
# Catch abuses when used with a variable and not a literal
|
||||||
|
bad = 'LOG.%s(_(msg))' % log
|
||||||
|
self.assertEqual(1, len(list(checks.no_translate_logs(bad))))
|
||||||
|
Loading…
Reference in New Issue
Block a user