mirror of https://github.com/milvus-io/milvus.git
102 lines
4.0 KiB
Python
102 lines
4.0 KiB
Python
import sys
|
|
import traceback
|
|
import copy
|
|
|
|
from check.func_check import ResponseChecker, Error
|
|
from utils.util_log import test_log as log
|
|
|
|
# enable_traceback = os.getenv('ENABLE_TRACEBACK', "True")
|
|
# log.info(f"enable_traceback:{enable_traceback}")
|
|
|
|
|
|
log_row_length = 300
|
|
|
|
|
|
def api_request_catch():
|
|
def wrapper(func):
|
|
def inner_wrapper(*args, **kwargs):
|
|
try:
|
|
_kwargs = copy.deepcopy(kwargs)
|
|
if "enable_traceback" in _kwargs:
|
|
del _kwargs["enable_traceback"]
|
|
res = func(*args, **_kwargs)
|
|
# if enable_traceback == "True":
|
|
if kwargs.get("enable_traceback", True):
|
|
res_str = str(res)
|
|
log_res = res_str[0:log_row_length] + '......' if len(res_str) > log_row_length else res_str
|
|
log.debug("(api_response) : %s " % log_res)
|
|
|
|
return res, True
|
|
except Exception as e:
|
|
e_str = str(e)
|
|
log_e = e_str[0:log_row_length] + '......' if len(e_str) > log_row_length else e_str
|
|
# if enable_traceback == "True":
|
|
if kwargs.get("enable_traceback", True):
|
|
log.error(traceback.format_exc())
|
|
log.error("(api_response) : %s" % log_e)
|
|
return Error(e), False
|
|
return inner_wrapper
|
|
return wrapper
|
|
|
|
|
|
@api_request_catch()
|
|
def api_request(_list, **kwargs):
|
|
if isinstance(_list, list):
|
|
func = _list[0]
|
|
if callable(func):
|
|
arg = _list[1:]
|
|
arg_str = str(arg)
|
|
log_arg = arg_str[0:log_row_length] + '......' if len(arg_str) > log_row_length else arg_str
|
|
# if enable_traceback == "True":
|
|
if kwargs.get("enable_traceback", True):
|
|
log.debug("(api_request) : [%s] args: %s, kwargs: %s" % (func.__qualname__, log_arg, str(kwargs)))
|
|
return func(*arg, **kwargs)
|
|
return False, False
|
|
|
|
|
|
def logger_interceptor():
|
|
def wrapper(func):
|
|
def log_request(*arg, **kwargs):
|
|
arg = arg[1:]
|
|
arg_str = str(arg)
|
|
log_arg = arg_str[0:log_row_length] + '......' if len(arg_str) > log_row_length else arg_str
|
|
if kwargs.get("enable_traceback", True):
|
|
log.debug("(api_request) : [%s] args: %s, kwargs: %s" % (func.__name__, log_arg, str(kwargs)))
|
|
|
|
def log_response(res, **kwargs):
|
|
if kwargs.get("enable_traceback", True):
|
|
res_str = str(res)
|
|
log_res = res_str[0:log_row_length] + '......' if len(res_str) > log_row_length else res_str
|
|
log.debug("(api_response) : [%s] %s " % (func.__name__, log_res))
|
|
return res, True
|
|
|
|
async def handler(*args, **kwargs):
|
|
_kwargs = copy.deepcopy(kwargs)
|
|
_kwargs.pop("enable_traceback", None)
|
|
check_task = kwargs.get("check_task", None)
|
|
check_items = kwargs.get("check_items", None)
|
|
try:
|
|
# log request
|
|
log_request(*args, **_kwargs)
|
|
# exec func
|
|
res = await func(*args, **_kwargs)
|
|
# log response
|
|
log_response(res, **_kwargs)
|
|
# check_response
|
|
check_res = ResponseChecker(res, sys._getframe().f_code.co_name, check_task, check_items, True).run()
|
|
return res, check_res
|
|
except Exception as e:
|
|
log.error(str(e))
|
|
e_str = str(e)
|
|
log_e = e_str[0:log_row_length] + '......' if len(e_str) > log_row_length else e_str
|
|
if kwargs.get("enable_traceback", True):
|
|
log.error(traceback.format_exc())
|
|
log.error("(api_response) : %s" % log_e)
|
|
check_res = ResponseChecker(Error(e), sys._getframe().f_code.co_name, check_task,
|
|
check_items, False).run()
|
|
return Error(e), check_res
|
|
|
|
return handler
|
|
|
|
return wrapper
|