api_request.py 1.9 KB
Newer Older
D
del-zhenwu 已提交
1
import traceback
2
import os
3 4
from utils.util_log import test_log as log

W
wt 已提交
5 6 7 8
# enable_traceback = os.getenv('ENABLE_TRACEBACK', "True")
# log.info(f"enable_traceback:{enable_traceback}")


9 10
class Error:
    def __init__(self, error):
紫晴 已提交
11
        self.code = getattr(error, 'code', -1)
12 13 14
        self.message = getattr(error, 'message', str(error))


15
log_row_length = 300
16 17


18 19 20 21 22
def api_request_catch():
    def wrapper(func):
        def inner_wrapper(*args, **kwargs):
            try:
                res = func(*args, **kwargs)
W
wt 已提交
23 24
                # if enable_traceback == "True":
                if kwargs.get("enable_traceback", True):
25 26 27 28
                    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)

29 30
                return res, True
            except Exception as e:
31 32
                e_str = str(e)
                log_e = e_str[0:log_row_length] + '......' if len(e_str) > log_row_length else e_str
W
wt 已提交
33 34
                # if enable_traceback == "True":
                if kwargs.get("enable_traceback", True):
35 36
                    log.error(traceback.format_exc())
                    log.error("(api_response) : %s" % log_e)
37 38 39 40 41 42 43 44 45 46
                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):
47
            arg = _list[1:]
48 49
            arg_str = str(arg)
            log_arg = arg_str[0:log_row_length] + '......' if len(arg_str) > log_row_length else arg_str
50 51
            # if enable_traceback == "True":
            if kwargs.get("enable_traceback", True):
52
                log.debug("(api_request)  : [%s] args: %s, kwargs: %s" % (func.__qualname__, log_arg, str(kwargs)))
53 54
            return func(*arg, **kwargs)
    return False, False