0a47197c6a
Previously decorators shared logger. This patch makes LOG object in closure for every decorated method in order to use correct logging level. Closes-Bug: #1340778 Change-Id: If907acbab34f8bf23e1277e66c3ddd839f668764
38 lines
1.4 KiB
Python
38 lines
1.4 KiB
Python
# Copyright (C) 2013 eNovance SAS <licensing@enovance.com>
|
|
#
|
|
# Author: Sylvain Afchain <sylvain.afchain@enovance.com>
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
"""Log helper functions."""
|
|
import functools
|
|
|
|
from neutron.openstack.common import log as logging
|
|
|
|
|
|
def log(method):
|
|
"""Decorator helping to log method calls."""
|
|
LOG = logging.getLogger(method.__module__)
|
|
|
|
@functools.wraps(method)
|
|
def wrapper(*args, **kwargs):
|
|
instance = args[0]
|
|
data = {"class_name": "%s.%s" % (instance.__class__.__module__,
|
|
instance.__class__.__name__),
|
|
"method_name": method.__name__,
|
|
"args": args[1:], "kwargs": kwargs}
|
|
LOG.debug('%(class_name)s method %(method_name)s'
|
|
' called with arguments %(args)s %(kwargs)s', data)
|
|
return method(*args, **kwargs)
|
|
return wrapper
|