文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

python+pytest接口自动化之token关联登录怎么实现

2023-06-29 21:48

关注

今天小编给大家分享一下python+pytest接口自动化之token关联登录怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

在PC端登录公司的后台管理系统或在手机上登录某个APP时,经常会发现登录成功后,返回参数中会包含token,它的值为一段较长的字符串,而后续去请求的请求头中都需要带上这个token作为参数,否则就提示需要先登录。

这其实就是状态或会话保持的第三种方式token

一. 什么是token

token 由服务端产生,是客户端用于请求的身份令牌。第一次登录成功时,服务端会生成一个包含用户信息的加密字符串token,返回给客户端并保存在本地,后续客户端只需要带上token进行请求即可,无需带上用户名密码。

token原理简单概括如下:

二. token场景处理

公司某管理后台系统,登录后返回token,接着去请求其他接口时请求头中都需要加上这个token,否则提示请先登录。

请求该系统的登录接口如下:

import requestsimport jsonheaders = {"Content-Type": "application/json;charset=utf8"}url = "http://127.0.0.1:5000/login"_data = {    "username": "刘德华",    "password": "123456"}res = requests.post(url=url, headers=headers, json=_data).textprint(res)

结果如下:

{
  "code": 1000, 
  "msg": "登录成功!", 
  "token": "sh44ljjl08s32730djsh44ljjl08s32730djsh44ljjl08s32730djsh44ljjl08s32730djsh44ljjl08s32730djsh44ljjl08s32730dj"
}

在对扎样的项目做接口自动化测试时,需要先请求登录接口拿到token,再去请求别的接口。每次请求其他接口时先请求一次登录接口,这样做虽然可行,但这样不仅会降低自动化的执行效率,而且每次都请求登录也会对服务器资源造成浪费。

这里介绍如下两种处理思路。

1. 思路一

在执行用例之前,先请求登录接口,并将返回的token值存储在文件中(如yaml文件),后续请求需要用到token值则从该文件。

python中yaml文件的读写请参考我之前的文章Python读写yaml文件(使用PyYAML库)。

1,运行接口自动化测试框架,初始化时先请求登录接口,获取token值,并写入指定的yaml文件中。

import requestsimport jsonimport yamldef get_token():    '''    请求登录接口,获取token    :return:    headers = {"Content-Type": "application/json;charset=utf8"}    url = "http://127.0.0.1:5000/login"    _data = {        "username": "刘德华",        "password": "123456"    }    res = requests.post(url=url, headers=headers, json=_data).text    res = json.loads(res)    token = res["token"]    return tokendef write_yaml(token):    写入yaml文件    t_data = {        "token": token    with open("yaml文件路径", "w", encoding="utf-8") as f:        yaml.dump(data=t_data,  stream=f, allow_unicode=True)if __name__ == '__main__':    token = get_token() # 获取token    write_yaml(token)   # 将token值写入yaml文件

2,执行测试用例时先读取yaml文件中token值,并将token加入headers中(也有些是将token放在请求参数中,视被测试项目具体情况而定),再发送请求。

import requestsimport yamlimport pytestimport jsondef read_yaml():    '''    读yaml文件    :return:    with open('yaml文件路径', 'r', encoding='utf-8') as f:        result = yaml.load(f.read(), Loader=yaml.FullLoader)    token = result["token"]    return tokendef test_check_user():    查询个人信息(需要先登录系统)    # 先从yaml文件中读取token    token = read_yaml()    # 再将token添加到请求头中    headers = {        "Content-Type": "application/json;charset=utf8",        "token": token    }    url = "http://127.0.0.1:5000/users/3"    res = requests.get(url=url, headers=headers).text    # 返回结果为json格式,转换为字典    res = json.loads(res)    # 断言code是否为1000    assert res["code"] == 1000if __name__ == '__main__':    pytest.main()

这里仅仅只是举例说明,而在实际的框架中,我们需要把这些诸如yaml文件的读写这样的函数单独封装在某个模块中,供其他模块调用,这样会代码会更加清晰简洁。

2. 思路二

利用pytest中的Fixture函数,作用域设置为session,并返回token值,后续测试方法/函数调用该Fixture函数。

pytest中Fixture的使用请参考我之前的文章pytest(6)-Fixture(固件)。

1,首先,在conftest中定义一个作用域为session的Fixture函数,用于请求登录接口返回token。

import pytestimport requestsimport json@pytest.fixture(scope="session")def get_token_fixture():    '''    作用域为session的fixture函数,返回token    :return:    '''    headers = {"Content-Type": "application/json;charset=utf8"}    url = "http://127.0.0.1:5000/login"    _data = {        "username": "刘德华",        "password": "123456"    }    res = requests.post(url=url, headers=headers, json=_data).text    res = json.loads(res)    token = res["token"]    return token

2,接着,测试用例调用该Fixture。

def test_check_user(get_token_fixture):    '''    查询个人信息(需要先登录系统)    :return:    '''    # 通过Fixture函数g获取et_token_fixture值,即token,再将token添加到请求头中    headers = {        "Content-Type": "application/json;charset=utf8",        "token": get_token_fixture    }    url = "http://127.0.0.1:5000/users/3"    res = requests.get(url=url, headers=headers).text    res = json.loads(res)    print(res)    print(headers)    assert res["code"] == 1000if __name__ == '__main__':    pytest.main()

执行测试用例结果如下:

python+pytest接口自动化之token关联登录怎么实现

以上就是“python+pytest接口自动化之token关联登录怎么实现”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯