python自动化测试如何做数据缓存 ?这个第三方包推荐给你,方便又简单!

python自动化测试如何做数据缓存 ?这个第三方包推荐给你,方便又简单。

1.数据缓存说明

数据缓存可以说也是项目开发中比不可少的一个工具 ,像我们测试的系统中 ,你都会见到像Redis一样的数据缓存库 。使用缓存数据库的好处不言而喻,那就是效率高 ,简单数据直接放在缓存中 ,存取简单方便 。

在python中也有这样的缓存库 ,接下来我们介绍的这个第三方包就是一个缓存库 ,它也可以将数据临时缓存到内存中,可以做到随存随取。做自动化测试也是一样,你肯定也离不开这样的包 ,因为像token这样的值,存储在缓存中是最方便的 。

2.cacheout介绍

1.下载安装

 
  1. # 下载

  2. pip install cacheout

  3. # 验证

  4. pip show cacheout

2 . 导包

from cacheout import Cache

3.创建cache对象

cache = Cache()     # 创建cache对象,这样的对象创建都使用的是默认值

Cache()的默认参数有:

  • maxsize : 缓存默认值大小为256
  • ttl : 生存时间 ,过期关闭
  • timer :计时器 ,以s为单位
  • default : 缺少键名的默认值为None
cache = Cache(maxsize=256, ttl=0, timer=time.time, default=None)  # defaults

不过我们创建cache对象时一般都会使用默认值 ,也没必须修改这些参数

 
  1. 现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。

  2. 如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受

  3. 可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛

  4. 分享他们的经验,还会分享很多直播讲座和技术沙龙

  5. 可以免费学习!划重点!开源的!!!

  6. qq群号:455787643【暗号:csdn999】

3.cacheout功能
 
  1. # 数据缓存 :cacheout

  2. """

  3. 作用 :就是将全局的变量值临时保存起来(内存中) ,以便跨文件访问 。

  4. 下载安装 :

  5. pip install cacheout

  6. pip show cacheout

  7. # 导包

  8. from cacheout import Cache()

  9. # 初始化对象

  10. cache = Cache()

  11. 主要功能 :

  12. cache.set(key,value) # 将key=value形式保存到内存中

  13. cache.get(key) # 获取键名对应的值。

  14. cache.has(kye) # 判断键是否存在

  15. cache.items() :返回所有的键值对

  16. cache.keys() : 返回所有的键名

  17. cache.values() : 返回所有的值

  18. cache.delete(key) : 删除其中的一组键值队

  19. cache.clear() : 删除所有的键值对

  20. cache.popitem() : 移除所有的键值对

  21. cache.copy() : 拷贝所有的键值对

  22. cache.size() : 查看已缓存的键值对数

  23. cache.add() : 添加一对键值对

  24. cache.add_many(items) : 添加多组键值对

  25. cache.delete_man(iteratee) : 删除多组键值对

  26. cache.get_many(items) : 获取多组键值对

  27. cache.set_many(items) : 设置多组键值对

  28. cache.full() : 判断键值对是否已满,返回bool类型,若存放的键值对已满,返回TRUE,否则返回FALSE

  29. cache.setup()

  30. =====以下为属性=======

  31. cache.default : 查看参数default的默认值

  32. cache.maxsize : 查看缓存最大数

  33. cache.timer : 查看计算器

  34. cache.ttl : 查看ttl值

  35. """

  36. from cacheout import Cache

  37. cache = Cache()

  38. # 设置键值对到缓存中

  39. cache.set('a',10)

  40. cache.set('b',20)

  41. # 查看所有的键值对

  42. print(cache.items()) # 输出 :odict_items([('a', 10), ('b', 20)])

  43. # 获取键名a对应的值

  44. print(cache.get('a')) # 输出 :10

  45. # 获取键名c对应的值

  46. print(cache.get('c')) # 输出 :None

  47. # 拷贝当前缓存中的所有键值对

  48. x = cache.copy()

  49. print(x) # 输出 :odict_items([('a', 10), ('b', 20)])

  50. # 查看键值对数 ,即缓存的键值对有几对

  51. print(cache.size()) # 输出 :2

  52. # 添加键值对

  53. cache.add('c',123)

  54. print(cache.items()) # 输出 :odict_items([('a', 10), ('b', 20), ('c', 123)])

  55. print("============")

  56. print(cache.full())

  57. # 使用和执行批量操作:cache.set_many()cache.get_many()cache.delete_many()

  58. cache.set_many({'a': 1, 'b': 2, 'c': 3})

  59. assert cache.get_many(['a', 'b', 'c']) == {'a': 1, 'b': 2, 'c': 3}

  60. cache.delete_many(['a', 'b', 'c'])

  61. assert cache.count() == 0

  62. # 使用复杂的过滤:cache.get_many()cache.delete_many()

  63. import re

  64. cache.set_many({'a_1': 1, 'a_2': 2, '123': 3, 'b': 4})

  65. assert cache.get_many('a_*') == {'a_1': 1, 'a_2': 2}

  66. assert cache.get_many(re.compile(r'\d')) == {'123': 3}

  67. assert cache.get_many(lambda key: '2' in key) == {'a_2': 2, '123': 3}

  68. cache.delete_many('a_*')

  69. assert dict(cache.items()) == {'123': 3, 'b': 4}

  70. #使用以下方法管理多个缓存:CacheManager , 以下功能需要在python>=3.7版本中才支持

  71. from cacheout import CacheManager

  72. cacheman = CacheManager({'a': {'maxsize': 100},

  73. 'b': {'maxsize': 200, 'ttl': 900},

  74. 'c': {})

  75. cacheman['a'].set('key1', 'value1')

  76. value = cacheman['a'].get('key')

  77. cacheman['b'].set('key2', 'value2')

  78. assert cacheman['b'].maxsize == 200

  79. assert cacheman['b'].ttl == 900

  80. cacheman['c'].set('key3', 'value3')

  81. cacheman.clear_all()

  82. for name, cache in cacheman:

  83. assert name in cacheman

  84. assert len(cache) == 0

4.项目实践

在项目中的很多地方都会用到cacheout ,就比如最常见的就是处理token值 。

第一步 :调用登录接口将token值先缓存起来

 
  1. # 实现登录

  2. def login(self):

  3. """

  4. 请求登录,返回结果,将token缓存起来

  5. :return:

  6. """

  7. # 1. 请求登录

  8. login_path = '/admin/auth/login'

  9. login_url = self.get_url(login_path)

  10. result = self.post(login_url,LOGIN_INFO)

  11. # 2. 进行判断

  12. if 0 == result.get('errno'):

  13. logger.success("请求登录接口成功")

  14. token = result.get('data').get('token') # 获取token的值

  15. cache.set('token',token) # 缓存token,为了后面被调用使用

  16. else:

  17. logger.error("登录失败:{}".format(result))

  18. return result

第二步:在请求头中将token值传进去,将token值获取到最终传入到headers中。

 
  1. # 实现请求头的处理

  2. def _get_headers(self):

  3. """

  4. 将请求头中数据以字典形式返回,包括键值对 :Conetent-Tpye ,X-Litemall-Admin-Token

  5. :return:

  6. """

  7. headers = {"Content-Type":"application/json"}

  8. token = cache.get('token') # 获取缓存中的token值

  9. if token:

  10. headers.update({'X-Litemall-Admin-Token':token})

  11. return headers

  12. return headers

5.项目总结

至此,我们已经实现了五步了 

最后感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走!

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
 

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/525873.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

好物周刊#47:快捷启动器

https://github.com/cunyu1943 村雨遥的好物周刊,记录每周看到的有价值的信息,主要针对计算机领域,每周五发布。 一、项目 1. Tianji All-in-One 的数据洞察中心,同时具备网站分析器 状态监控器 服务状态上报的功能。 2. Ip2…

论文笔记:Efficient Training of Language Models to Fill in the Middle

导语 Decoder-only的模型只能从左向右看,无法利用双向信息完成填空等操作,本文是OpenAI最早提出使用Fill-in-the-model到Autoregressive形式的模型中的文章,启发了后面一些Text-to-Code的大模型,比如InCoder,SantaCod…

Linux下下载安装JDK配置Java环境变量

Linux下下载安装JDK配置Java环境变量 1. 下载JDK 下载链接:(https://www.oracle.com/java/technologies/javase/jdk17-archive-downloads.html) 2. 上传至服务器并解压 可通过shell工具进行上传,我这里是上传安装在/opt目录 解压jdk-17.0.10_linux-x64_b…

Nacos注册中心的部署及使用(超详细)

目录 1 前言 2 注册中心的原理 3 Linux上Nacos的部署 3.1 Mysql的部署 3.2 存储Nacos数据的数据库的建立 3.3 准备Nacos的环境文件 3.4 部署Nacos 3.5 检查是否成功 3.5.1 查看日志 3.5.2 访问Nacos 4 Java中的配置及食用方法 4.1 引入依赖坐标 4.2 配置Nacos 4…

苍穹外卖学习-----2024/03/09

1.菜品分页查询 代码在这里 分页查询菜品 2.删除菜品 [链接]param 1、概览 本文将带你了解 Spring 中 RequestParam 注解的用法。 简单地说,可以使用 RequestParam 从请求中提取查询参数、表单参数甚至是多个参数。 2、示例端点 假设我们有一个端点 /api/foos&a…

11. 搭建较通用的GoWeb开发脚手架

文章目录 导言一、加载配置二、初始化日志三、初始化MySQL连接四、初始化Redis连接五、初始化gin框架内置的校验器使用的翻译器六、注册路由七、 启动服务八、测试运行九:注意事项 代码地址:https://gitee.com/lymgoforIT/bluebell 导言 有了前述知识的…

Linux 之五:权限管理(文件权限和用户管理)

1. 文件权限 在Linux系统中,文件权限是一个非常基础且重要的安全机制。它决定了用户和用户组对文件或目录的访问控制级别。 每个文件或目录都有一个包含9个字符的权限模式,这些字符分为三组,每组三个字符,分别对应文件所有者的权限…

基于springboot+vue的食品安全管理系统(源码+论文)

目录 前言 一、功能设计 二、功能实现 1 首页 2 后台登录 3 食品信息添加页面 4 食品查询 三、库表设计 四、论文 前言 从事食品行业的商家可能会对于食品的储存以及食品的销售,都有着不同门道的想法,那么如何能将这些想法一一实现,…

【Linux】CentOS网络故障排查大揭秘: 实战攻略解读

🍎个人博客:个人主页 🏆个人专栏:Linux ⛳️ 功不唐捐,玉汝于成 目录 前言 正文 检查网络连接状态: 检查网络配置: 重启网络服务: 检查防火墙设置: 查看日志文…

大模型笔记:幻觉 hallucination

1 介绍 “幻觉” (Hallucination),指模型生成自然流畅,语法正确但实际上毫无意义且包含虚假信息即事实错误的文本,以假乱真,就像人产生的幻觉一样。 举个例子就是,即使现在的chatgpt-4,你问他一些有确切…

【Nestjs实操】环境变量和全局配置

一、环境变量 1、使用dotenv 安装pnpm add dotenv。 根目录下创建.env文件,内容如下: NODE_ENVdevelopment使用 import {config} from "dotenv"; const path require(path); config({path:path.join(__dirname,../.env)}); console.log(…

腾讯云轻量应用服务器流量用完了怎么办?

腾讯云轻量服务器流量用完了怎么办?超额流量另外支付流量费,流量价格为0.8元/GB,会自动扣你的腾讯云余额,如果你的腾讯云账号余额不足,那么你的轻量应用服务器会面临停机,停机后外网无法访问,继…