pytest中token的一种处理方法

在某个场景中,各个接口经常需要使用到token,而且接口对频繁登录做了防抖,无法频繁调用。考虑了很多方法,发现总是有一些或多或少的弊端,这里在conftest中定义了一个钩子函数用于处理token。

复制代码
@pytest.fixture(scope="module")
def auth_tokens(refresh_threshold=600):  # 假设刷新阈值为10分钟
    tokens = {}
    def get_or_refresh_token(username):
        token_info = tokens.get(username)
        if not token_info or (time.time() - token_info['timestamp']) > refresh_threshold:
            logger.info(f"没有获取到该账号{username}的token,或者token已过期,重新获取token中")
            token = login_user(username, '222222').response.json()['data']['accessToken']
            tokens[username] = {'token': token, 'timestamp': time.time()}
        logger.info(f"{username}的token为{tokens[username]['token']}")
        return tokens[username]['token']
    return get_or_refresh_token

作用域定义为模块级,在整个模块中只执行一次。

定义了一个get_or_refresh_token闭包,该闭包负责根据用户名获取或刷新token。虽然auth_tokens fixture在模块级别只实例化一次,但是它返回的闭包(get_or_refresh_token)能够对每个传入的用户名进行独立的操作,确保每个账号的token都是根据需要获取或刷新的。

相关推荐
fanruitian3 分钟前
Springboot项目父子工程
java·数据库·spring boot
小肖爱笑不爱笑7 分钟前
SpringBoot Web
java·http协议·分层解耦·web后端
柒.梧.10 分钟前
Spring核心知识全解析:从入门实战到进阶
java·后端·spring
hboot10 分钟前
别再被 TS 类型冲突折磨了!一文搞懂类型合并规则
前端·typescript
乌日尼乐13 分钟前
【Java基础整理】Java字符串处理,String、StringBuffer、StringBuilder
java·后端
在西安放羊的牛油果14 分钟前
浅谈 import.meta.env 和 process.env 的区别
前端·vue.js·node.js
鹏北海19 分钟前
从弹窗变胖到 npm 依赖管理:一次完整的问题排查记录
前端·npm·node.js
布列瑟农的星空20 分钟前
js中的using声明
前端
薛定谔的猫220 分钟前
Cursor 系列(2):使用心得
前端·ai编程·cursor
全栈独立开发者20 分钟前
点餐系统装上了“DeepSeek大脑”:基于 Spring AI + PgVector 的 RAG 落地指南
java·人工智能·spring