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都是根据需要获取或刷新的。

相关推荐
天启HTTP3 分钟前
多线程环境下,动态IP怎么分配最合理
java·服务器·网络
hzb6666610 分钟前
xd_day32-day40
java·javascript·学习·安全·web安全·tomcat·php
东北甜妹13 分钟前
Python脚本
java·开发语言·前端
心勤则明14 分钟前
Spring AI Alibaba 实战 MCP 协议
java·人工智能·spring
四千岁15 分钟前
WSL + OpenCode 最佳实践:环境一致、模型配置、GUI 远程使用
前端·javascript·后端
NGC_661121 分钟前
ConcurrentHashMap1.8 多线程扩容机制
java·开发语言
ssshooter26 分钟前
Tauri 2 Linux 上 asset://localhost 访问返回 403 避坑指南
前端·后端·架构
东离与糖宝28 分钟前
不用Python!Java+Spring AI 3.x本地RAG系统搭建实战
java·人工智能
半世轮回半世寻30 分钟前
这 5 个 Elements 小技巧,真的能提高调试效率
前端·浏览器
kyriewen30 分钟前
for...of 的秘密:迭代器与可迭代对象,你也能创造“可循环”的东西
前端·javascript·面试