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

news2025/1/23 4:49:38

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

1.数据缓存说明

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

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

2.cacheout介绍

1.下载安装

# 下载
pip install cacheout
​
# 验证
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对象时一般都会使用默认值 ,也没必须修改这些参数

现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:310357728【暗号:csdn999】

3.cacheout功能

# 数据缓存 :cacheout
"""
作用 :就是将全局的变量值临时保存起来(内存中) ,以便跨文件访问 。
​
下载安装 :
    pip install cacheout
    pip show cacheout
​
# 导包
from cacheout import Cache()
​
# 初始化对象
cache = Cache()
​
主要功能 :
cache.set(key,value)        # 将key=value形式保存到内存中
cache.get(key)              # 获取键名对应的值。
cache.has(kye)              # 判断键是否存在
cache.items()               :返回所有的键值对
cache.keys()                : 返回所有的键名
cache.values()              : 返回所有的值
cache.delete(key)           : 删除其中的一组键值队
cache.clear()               : 删除所有的键值对
cache.popitem()             : 移除所有的键值对
cache.copy()                : 拷贝所有的键值对
cache.size()                : 查看已缓存的键值对数
cache.add()                 : 添加一对键值对
cache.add_many(items)       : 添加多组键值对
cache.delete_man(iteratee)  : 删除多组键值对
cache.get_many(items)       : 获取多组键值对
cache.set_many(items)       : 设置多组键值对
cache.full()                : 判断键值对是否已满,返回bool类型,若存放的键值对已满,返回TRUE,否则返回FALSE
cache.setup()
​
=====以下为属性=======
cache.default           : 查看参数default的默认值
cache.maxsize           : 查看缓存最大数
cache.timer             : 查看计算器
cache.ttl               : 查看ttl值
"""
​
​
from cacheout import Cache
​
cache = Cache()
​
# 设置键值对到缓存中
cache.set('a',10)
cache.set('b',20)
​
​
# 查看所有的键值对
print(cache.items())        # 输出 :odict_items([('a', 10), ('b', 20)])
​
# 获取键名a对应的值
print(cache.get('a'))       # 输出 :10
​
# 获取键名c对应的值
print(cache.get('c'))       # 输出 :None
​
​
# 拷贝当前缓存中的所有键值对
x = cache.copy()
print(x)                    # 输出 :odict_items([('a', 10), ('b', 20)]) 
​
# 查看键值对数 ,即缓存的键值对有几对
print(cache.size())         # 输出 :2
​
# 添加键值对
cache.add('c',123)
print(cache.items())        # 输出 :odict_items([('a', 10), ('b', 20), ('c', 123)])
​
print("============")
print(cache.full())
​
# 使用和执行批量操作:cache.set_many()cache.get_many()cache.delete_many()
cache.set_many({'a': 1, 'b': 2, 'c': 3})
assert cache.get_many(['a', 'b', 'c']) == {'a': 1, 'b': 2, 'c': 3}
cache.delete_many(['a', 'b', 'c'])
assert cache.count() == 0
​
​
# 使用复杂的过滤:cache.get_many()cache.delete_many()
import re
cache.set_many({'a_1': 1, 'a_2': 2, '123': 3, 'b': 4})
assert cache.get_many('a_*') == {'a_1': 1, 'a_2': 2}
assert cache.get_many(re.compile(r'\d')) == {'123': 3}
assert cache.get_many(lambda key: '2' in key) == {'a_2': 2, '123': 3}
​
cache.delete_many('a_*')
assert dict(cache.items()) == {'123': 3, 'b': 4}
​
​
#使用以下方法管理多个缓存:CacheManager , 以下功能需要在python>=3.7版本中才支持
​
from cacheout import CacheManager
​
cacheman = CacheManager({'a': {'maxsize': 100},
                         'b': {'maxsize': 200, 'ttl': 900},
                         'c': {})
​
cacheman['a'].set('key1', 'value1')
value = cacheman['a'].get('key')
​
cacheman['b'].set('key2', 'value2')
assert cacheman['b'].maxsize == 200
assert cacheman['b'].ttl == 900
​
cacheman['c'].set('key3', 'value3')
​
cacheman.clear_all()
for name, cache in cacheman:
    assert name in cacheman
    assert len(cache) == 0

4.项目实践

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

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

# 实现登录
def login(self):
    """
        请求登录,返回结果,将token缓存起来
        :return:
        """
    # 1. 请求登录
    login_path = '/admin/auth/login'
    login_url = self.get_url(login_path)
    result = self.post(login_url,LOGIN_INFO)
    # 2. 进行判断
    if 0 == result.get('errno'):
        logger.success("请求登录接口成功")
        token = result.get('data').get('token')     # 获取token的值
        cache.set('token',token)            # 缓存token,为了后面被调用使用
    else:
        logger.error("登录失败:{}".format(result))
        return result

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

# 实现请求头的处理
def _get_headers(self):
    """
        将请求头中数据以字典形式返回,包括键值对 :Conetent-Tpye ,X-Litemall-Admin-Token
        :return:
        """
    headers = {"Content-Type":"application/json"}
    token = cache.get('token')      # 获取缓存中的token值
    if token:
        headers.update({'X-Litemall-Admin-Token':token})
        return headers
    return headers

5.项目总结

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

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

软件测试面试文档

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

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

探索Scrapy-spider:构建高效网络爬虫

Spider简介 Scrapy中的Spider是用于定义和执行数据抓取逻辑的核心组件。Spider负责从指定的网站抓取数据,并定义了如何跟踪链接、解析内容以及提取数据的规则。它允许您定制化地指定要抓取的网站、页面和所需的信息。Spider的作用是按照预定的规则爬取网页&#xf…

12.7 C++作业

自由发挥登录窗口的应用场景,实现一个登录窗口界面 #include "widget.h"Widget::Widget(QWidget *parent): QWidget(parent) {//*******窗口相关设置********this->setWindowTitle("王者农药"); //设置窗口标题this->setWindowIcon(QIc…

OpenTiny Vue 3.12.0 发布:文档大优化!增加水印和二维码两个新组件

你好,我是 Kagol。 非常高兴跟大家宣布,2023年11月30日,OpenTiny Vue 发布了 v3.12.0 🎉。 OpenTiny 每次大版本发布,都会给大家带来一些实用的新特性,10.24 我们发布了 v3.11.0 版本,增加了富…

算法学习系列(六):高精度加法、减法、乘法、除法

目录 引言一、高精度加法1.题目描述2.代码实现3.测试 二、高精度减法1.题目描述2.代码实现3.测试 三、高精度乘法1.题目描述2.代码实现3.测试 四、高精度除法1.题目描述2.代码实现3.测试 引言 本文介绍了高精度加法、高精度减法、高精度乘法、高精度除法,这个高精度…

【Java数据结构 -- List和ArrayList与顺序表】

List和ArrayList与顺序表 一. List1.1 List介绍2.1 常见接口介绍3.1 List的使用 二. ArrayList与顺序表1.线性表2.顺序表2.1 接口的实现 3.ArrayList简介4. ArrayList使用4.1 ArrayList的构造 4.2 ArrayList常见操作4.3 ArrayList的遍历4.4 ArrayList的扩容机制5. ArrayList的具…

Python 网络爬虫(二):HTTP 基础知识

《Python入门核心技术》专栏总目录・点这里 文章目录 1. HTTP 协议简述2. HTTP 请求过程3. HTTP 的结构3.1 请求行3.2 请求头3.3 请求体3.4 状态行3.5 响应头3.6 响应体4. Cookie 状态管理5. HTTP 请求示例6. 总结<

HTML5+CSS3小实例:3D翻转Tab选项卡切换特效

实例:3D翻转Tab选项卡切换特效 技术栈:HTML+CSS 效果: 源码: 【HTML】 <!DOCTYPE html> <html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"><meta name="viewport" content=…

【Linux】公网远程访问AMH服务器管理面板

目录 1. Linux 安装AMH 面板2. 本地访问AMH 面板3. Linux安装Cpolar4. 配置AMH面板公网地址5. 远程访问AMH面板6. 固定AMH面板公网地址 AMH 是一款基于 Linux 系统的服务器管理面板&#xff0c;它提供了一系列的功能&#xff0c;包括网站管理、FTP 管理、数据库管理、DNS 管理、…

信号完整性分析

目录 前言一、信号完整性SI1.1 信号失真1.2 串扰1.3 衰减 二、电源完整性PI2.1 地弹2.2 电源轨道塌陷 三、电磁兼容EMC3.1 电磁辐射3.2 抗干扰 前言 本篇介绍信号完整性分析的知识体系&#xff0c;以及部分分析方法。   什么是信号完整性?通俗来讲&#xff0c;信号在互连线的…

若依角色与权限字符串

文章目录 一、简介1.基于权限字段串2.基于角色 二、若依的权限控制1.介绍2.实践 一、简介 基于权限字段串和基于角色的访问控制是两种不同的权限管理模型&#xff0c;它们各自有其优点和应用场景。下面是这两种模型的基本概念&#xff1a; 1.基于权限字段串 基于权限字段串&…

基于ssm实验室课程管理系统源码和论文

idea 数据库mysql5.7 数据库链接工具&#xff1a;navcat,小海豚等 环境&#xff1a; jdk8 tomcat8.5 摘 要 随着科学实验规模的不断扩大&#xff0c;实验室课程数量的急剧增加&#xff0c;有关实验室课程的各种信息量也在不断成倍增长。面对庞大的信息量&#xff0c;就需要有…

SpringCloud简介和用处

Spring Cloud是一套基于Spring Boot的微服务框架&#xff0c;它旨在提供一种快速构建分布式系统的方法。它可以帮助开发人员构建具有高可用性、可扩展性和容错性的微服务&#xff0c;并通过Spring Boot的开发工具和库提供强大的支持。 一、简介 Spring Cloud是Spring家族中的一…

Spark Structured Streaming使用教程

文章目录 1、输入数据源2、输出模式3、sink输出结果4、时间窗口4.1、时间窗口4.2、时间水印&#xff08;Watermarking&#xff09; 5、使用例子 Structured Streaming是一个基于Spark SQL引擎的可扩展和容错流处理引擎&#xff0c;Spark SQL引擎将负责增量和连续地运行它&#…

2023-2024-1-高级语言程序设计-第2次月考编程题

注&#xff1a;此前已发布过的题解不再发布&#xff08;原题请在下面位置进行搜索&#xff09;。 7-1-2 排序(算法任意) 本题要求将给定的n个整数从大到小排序后输出&#xff08;可使用任意排序算法&#xff09;。 输入格式: 输入第一行给出一个不超过10的正整数n。第二行给…

WVP-RPO开源项目搭建实践

0.拉取代码 GitHub - 648540858/wvp-GB28181-pro: WEB VIDEO PLATFORM是一个基于GB28181-2016标准实现的网络视频平台&#xff0c;支持NAT穿透&#xff0c;支持海康、大华、宇视等品牌的IPC、NVR、DVR接入。支持国标级联&#xff0c;支持rtsp/rtmp等视频流转发到国标平台&…

详细解读电力DLT698.45-2017通信规约--正向有功总电能

建立连接请看这篇&#xff1a;详细解读DLT698.45-2017通信规约--预连接响应http://mp.weixin.qq.com/s?__bizMzA3NjAwMjQzMQ&mid2652026396&idx1&sna0a17f005d23136c922a7c381ddb7e75&chksm8481f30cb3f67a1a94e66db77e61fe73c22b1904fcdbb0144108e132b265e7b4…

dtaidistance笔记:dtw_ndim (高维时间序列之间的DTW)

1 数据 第一个维度是sequence的index&#xff0c;每一行是多个元素&#xff08;表示这一时刻的record&#xff09; from dtaidistance.dtw_ndim import *s1 np.array([[0, 0],[0, 1],[2, 1],[0, 1],[0, 0]], dtypenp.double) s2 np.array([[0, 0],[2, 1],[0, 1],[0, .5],[0…

水果党flstudio用什么midi键盘?哪个版本的FL Studio更适合我

好消息&#xff01;好消息&#xff01;特大好消息&#xff01; 水果党们&#xff01;终于有属于自己的专用MIDI键盘啦&#xff01; 万众期待的Novation FLKEY系列 正式出炉&#xff01; 话有点多话&#xff0c;先分享一份干货&#xff0c;尽快下载 FL Studio 21 Win-安装包&…

搜索推荐技术-爱奇艺搜索引擎技术

一、爱奇艺的搜索引擎框架示意图 即通过召回系统&#xff0c;即基于文本匹配的matching system&#xff0c;得到大量视频资源的候选集&#xff0c;经过粗排和精排&#xff0c;最后返回给用户。重点在于召回模块和排序模块。 二、召回模块 召回模块比较重要的是基础相关性&am…

Unity Meta Quest 一体机开发(九):【手势追踪】通过录制抓取手势实现自定义抓取姿势

文章目录 &#x1f4d5;教程说明&#x1f4d5;录制前的准备&#x1f4d5;第一种录制方法&#xff08;Hand Grab Pose Tool 场景&#xff09;⭐在运行模式中确认录制⭐保存录制的手势&#xff0c;将物体做成 Prefab⭐在编辑阶段调整抓取手势&#x1f50d;Fingers Freedom&#x…