Fix confusing logging when running asynchronous commands
We log them as completed when they start executing. Also fix a problem in remove_large_keys that prevented items with defaultdict from being logged. Change-Id: I34a06cc85f55c693416f8c4c9877d55d6affafc9
This commit is contained in:
parent
46bf7e0ef4
commit
0eee26ea66
@ -164,7 +164,7 @@ class AsyncCommandResult(BaseCommandResult):
|
|||||||
|
|
||||||
if isinstance(result, (bytes, str)):
|
if isinstance(result, (bytes, str)):
|
||||||
result = {'result': '{}: {}'.format(self.command_name, result)}
|
result = {'result': '{}: {}'.format(self.command_name, result)}
|
||||||
LOG.info('Command: %(name)s, result: %(result)s',
|
LOG.info('Asynchronous command %(name)s completed: %(result)s',
|
||||||
{'name': self.command_name,
|
{'name': self.command_name,
|
||||||
'result': utils.remove_large_keys(result)})
|
'result': utils.remove_large_keys(result)})
|
||||||
with self.command_state_lock:
|
with self.command_state_lock:
|
||||||
@ -270,9 +270,6 @@ class ExecuteCommandMixin(object):
|
|||||||
# recorded as a failed SyncCommandResult with an error message
|
# recorded as a failed SyncCommandResult with an error message
|
||||||
LOG.exception('Command execution error: %s', e)
|
LOG.exception('Command execution error: %s', e)
|
||||||
result = SyncCommandResult(command_name, kwargs, False, e)
|
result = SyncCommandResult(command_name, kwargs, False, e)
|
||||||
LOG.info('Command %(name)s completed: %(result)s',
|
|
||||||
{'name': command_name,
|
|
||||||
'result': utils.remove_large_keys(result)})
|
|
||||||
self.command_results[result.id] = result
|
self.command_results[result.id] = result
|
||||||
return result
|
return result
|
||||||
|
|
||||||
@ -299,10 +296,13 @@ def async_command(command_name, validator=None):
|
|||||||
# know about the mode
|
# know about the mode
|
||||||
bound_func = functools.partial(func, self)
|
bound_func = functools.partial(func, self)
|
||||||
|
|
||||||
return AsyncCommandResult(command_name,
|
ret = AsyncCommandResult(command_name,
|
||||||
command_params,
|
command_params,
|
||||||
bound_func,
|
bound_func,
|
||||||
agent=self.agent).start()
|
agent=self.agent).start()
|
||||||
|
LOG.info('Asynchronous command %(name)s started execution',
|
||||||
|
{'name': command_name})
|
||||||
|
return ret
|
||||||
return wrapper
|
return wrapper
|
||||||
return async_decorator
|
return async_decorator
|
||||||
|
|
||||||
@ -325,6 +325,9 @@ def sync_command(command_name, validator=None):
|
|||||||
validator(self, **command_params)
|
validator(self, **command_params)
|
||||||
|
|
||||||
result = func(self, **command_params)
|
result = func(self, **command_params)
|
||||||
|
LOG.info('Synchronous command %(name)s completed: %(result)s',
|
||||||
|
{'name': command_name,
|
||||||
|
'result': utils.remove_large_keys(result)})
|
||||||
return SyncCommandResult(command_name,
|
return SyncCommandResult(command_name,
|
||||||
command_params,
|
command_params,
|
||||||
True,
|
True,
|
||||||
|
@ -634,10 +634,9 @@ _LARGE_KEYS = frozenset(['configdrive', 'system_logs'])
|
|||||||
def remove_large_keys(var):
|
def remove_large_keys(var):
|
||||||
"""Remove specific keys from the var, recursing into dicts and lists."""
|
"""Remove specific keys from the var, recursing into dicts and lists."""
|
||||||
if isinstance(var, abc.Mapping):
|
if isinstance(var, abc.Mapping):
|
||||||
return var.__class__(
|
return {key: (remove_large_keys(value)
|
||||||
(key, remove_large_keys(value)
|
|
||||||
if key not in _LARGE_KEYS else '<...>')
|
if key not in _LARGE_KEYS else '<...>')
|
||||||
for key, value in var.items())
|
for key, value in var.items()}
|
||||||
elif isinstance(var, abc.Sequence) and not isinstance(var, str):
|
elif isinstance(var, abc.Sequence) and not isinstance(var, str):
|
||||||
return var.__class__(map(remove_large_keys, var))
|
return var.__class__(map(remove_large_keys, var))
|
||||||
else:
|
else:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user