Add function decorator `log_deprecated_args'
Add decorator `log_deprecated_args' that issues a message whenever the decorated function is called with deprecated keyword arguments supplied. Message is issued only once or per each call depending on the configuration. Change-Id: Icedf72c40d9255f8d82233ebf640165d4827d53b
This commit is contained in:
parent
0c413f553c
commit
3db7200ab6
@ -224,7 +224,7 @@ def log_verification_wrapper(log_function, msg, **kw):
|
||||
|
||||
|
||||
def log_deprecated(message, rally_version, log_function=None):
|
||||
"""A wrapper marking a certain method as decrecated.
|
||||
"""A wrapper marking a certain method as deprecated.
|
||||
|
||||
:param message: Message that describes why the method was deprecated
|
||||
:param rally_version: version of Rally when the method was deprecated
|
||||
@ -243,6 +243,37 @@ def log_deprecated(message, rally_version, log_function=None):
|
||||
return decorator
|
||||
|
||||
|
||||
def log_deprecated_args(message, rally_version, deprecated_args,
|
||||
log_function=None, once=False):
|
||||
"""A wrapper marking certain arguments as deprecated.
|
||||
|
||||
:param message: Message that describes why the arguments were deprecated
|
||||
:param rally_version: version of Rally when the arguments were deprecated
|
||||
:param deprecated_args: List of deprecated args.
|
||||
:param log_function: Logging method to be used, e.g. LOG.info
|
||||
:param once: Show only once (default is each)
|
||||
"""
|
||||
log_function = log_function or LOG.warning
|
||||
|
||||
def decorator(f):
|
||||
@functools.wraps(f)
|
||||
def wrapper(*args, **kwargs):
|
||||
if (not once) or (not getattr(f, "_warned_dep_args", False)):
|
||||
deprecated = ", ".join([
|
||||
"`%s'" % x for x in deprecated_args if x in kwargs])
|
||||
if deprecated:
|
||||
log_function(
|
||||
"%(msg)s (args %(args)s deprecated in Rally "
|
||||
"v%(version)s)" %
|
||||
{"msg": message, "version": rally_version,
|
||||
"args": deprecated})
|
||||
setattr(f, "_warned_dep_args", once)
|
||||
result = f(*args, **kwargs)
|
||||
return result
|
||||
return wrapper
|
||||
return decorator
|
||||
|
||||
|
||||
def load_plugins(directory):
|
||||
if os.path.exists(directory):
|
||||
LOG.info("Loading plugins from directories %s/*" % directory)
|
||||
|
@ -169,6 +169,36 @@ class LogTestCase(test.TestCase):
|
||||
mock_log.assert_called_once_with("Deprecated test "
|
||||
"(deprecated in Rally v0.0.1)")
|
||||
|
||||
def test_log_deprecated_args(self):
|
||||
mock_log = mock.MagicMock()
|
||||
|
||||
@utils.log_deprecated_args("Deprecated test", "0.0.1", ("z",),
|
||||
mock_log, once=True)
|
||||
def some_method(x, y, z):
|
||||
return x + y + z
|
||||
|
||||
self.assertEqual(some_method(2, 2, z=3), 7)
|
||||
mock_log.assert_called_once_with(
|
||||
"Deprecated test (args `z' deprecated in Rally v0.0.1)")
|
||||
|
||||
mock_log.reset_mock()
|
||||
self.assertEqual(some_method(2, 2, z=3), 7)
|
||||
self.assertFalse(mock_log.called)
|
||||
|
||||
@utils.log_deprecated_args("Deprecated test", "0.0.1", ("z",),
|
||||
mock_log, once=False)
|
||||
def some_method(x, y, z):
|
||||
return x + y + z
|
||||
|
||||
self.assertEqual(some_method(2, 2, z=3), 7)
|
||||
mock_log.assert_called_once_with(
|
||||
"Deprecated test (args `z' deprecated in Rally v0.0.1)")
|
||||
|
||||
mock_log.reset_mock()
|
||||
self.assertEqual(some_method(2, 2, z=3), 7)
|
||||
mock_log.assert_called_once_with(
|
||||
"Deprecated test (args `z' deprecated in Rally v0.0.1)")
|
||||
|
||||
|
||||
class LoadExtraModulesTestCase(test.TestCase):
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user