测试平台系列(78) 编写Redis配置管理功能(上)

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: 编写Redis配置管理功能(上)

大家好~我是米洛


我正在从0到1打造一个开源的接口测试平台, 也在编写一套与之对应的完整教程,希望大家多多支持。


回顾


上一节我们编写了测试计划相关功能。由于我们的数据构造器(前置条件)还有一些不完善的,所以我们这段时间要开始完善redis相关内容。

如果把redis看做数据库的话,我们也是需要编写对应的连接配置页面的,编写完以后我们需要接入前置条件,也得能够在页面上在线执行redis命令。这些都会是接下来几天的任务。

成果图


1.jpg

image

设计Redis配置表


redis和mysql比较类似,有一些共通的部分:

  • host
  • port
  • username
  • password
  • database
    在redis中是一片一片的db,一般是0-15。而Mysql则是一个具体的库。
    除此之外,二者区别很小。主要提现在:
  • redis分为集群和单例模式,集群是可以不输入用户密码的
  • 一般redis的连接串会把host和port合到一起,便于我们进行集群管理
    所以总结起来就是,我们基本可以照搬MySQL配置表。


from sqlalchemy import Column, INT, String, Boolean, UniqueConstraint
from app.models.basic import PityBase
class PityRedis(PityBase):
    __tablename__ = "pity_redis_info"
    __table_args__ = (
        UniqueConstraint('env', 'name', 'deleted_at'),
    )
    env = Column(INT, nullable=False)  # 对应环境id
    name = Column(String(24), nullable=False)  # redis描述名称
    addr = Column(String(128), nullable=False)
    username = Column(String(36), nullable=False)
    password = Column(String(64), nullable=False)
    db = Column(INT, nullable=False)
    # 是否是集群,默认为false,集群可不输入用户密码
    cluster = Column(Boolean, default=False, nullable=False)
    def __init__(self, env, name, addr, username, password, db, cluster, user):
        super().__init__(user)
        self.env = env
        self.name = name
        self.addr = addr
        self.password = password
        self.username = username
        self.db = db
        self.cluster = cluster

可以看到,他几乎和MySQL差不多。那我们来按照管理编写增删改查接口。

编写Dao层


其实按照惯例,我估计又从之前的DbConfigDao.py复制出代码然后改一改了。

但这次我不打算这么做了,因为其实每次写的增删改查代码虽然不完全一样,但都很像啊!!!

所以如果能有个办法可以省略这些操作,那么一个后端接口就很快能够写出来了~

对于我们这样简易的接口测试平台,是事半功倍的。


其实思路来源于Mybatis Plus,这个框架的好处就是封装了selectList,selectById等常用api,导致哥们都不需要编写具体的select方法,直接传入查询条件就可以了。

update更是离谱,传入一个新对象即可。

所以可以看到具体的mapper都是继承BaseMapper,就可以完成对应的操作。

可能大家没有具体的概念,我先给大家展示下半成品:

2.jpg

可以看到类里面都没有任何方法

使用方式


3.jpg

image

可以看到,需要精确查找就直接传入,需要模糊查询的则加上like。


看起来是非常美好,有兴趣的朋友可以测试一下。


今天的内容到这就结束了,下一节我们继续完善这个Mapper基类中的方法,并实现一个完整的demo简化开发。


思路虽然是原创,但难免和其他人碰到一起,其实大家做的测试平台思路大体都是一致的,所以如果遇到高度相似的,真的还是纯属巧合。




相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
1月前
|
运维
【运维基础知识】用dos批处理批量替换文件中的某个字符串(本地单元测试通过,部分功能有待优化,欢迎指正)
该脚本用于将C盘test目录下所有以t开头的txt文件中的字符串“123”批量替换为“abc”。通过创建批处理文件并运行,可实现自动化文本替换,适合初学者学习批处理脚本的基础操作与逻辑控制。
150 56
|
8天前
|
人工智能 供应链 安全
AI辅助安全测试案例某电商-供应链平台平台安全漏洞
【11月更文挑战第13天】该案例介绍了一家电商供应链平台如何利用AI技术进行全面的安全测试,包括网络、应用和数据安全层面,发现了多个潜在漏洞,并采取了有效的修复措施,提升了平台的整体安全性。
|
18天前
|
监控 安全 测试技术
构建高效的精准测试平台:设计与实现指南
在软件开发过程中,精准测试是确保产品质量和性能的关键环节。一个精准的测试平台能够自动化测试流程,提高测试效率,缩短测试周期,并提供准确的测试结果。本文将分享如何设计和实现一个精准测试平台,从需求分析到技术选型,再到具体的实现步骤。
82 1
|
29天前
|
NoSQL 测试技术 Redis
Redis 性能测试
10月更文挑战第21天
35 2
|
1月前
|
人工智能 监控 测试技术
云应用开发平台测试
云应用开发平台测试
53 2
|
18天前
|
监控 安全 测试技术
构建高效精准测试平台:设计与实现全攻略
在软件开发过程中,精准测试是确保产品质量的关键环节。一个高效、精准的测试平台能够自动化测试流程,提高测试覆盖率,缩短测试周期。本文将分享如何设计和实现一个精准测试平台,从需求分析到技术选型,再到具体的实现步骤。
43 0
|
1月前
|
存储 NoSQL 大数据
大数据-51 Redis 高可用方案CAP-AP 主从复制 一主一从 全量和增量同步 哨兵模式 docker-compose测试
大数据-51 Redis 高可用方案CAP-AP 主从复制 一主一从 全量和增量同步 哨兵模式 docker-compose测试
35 3
|
14天前
|
JSON Java 测试技术
SpringCloud2023实战之接口服务测试工具SpringBootTest
SpringBootTest同时集成了JUnit Jupiter、AssertJ、Hamcrest测试辅助库,使得更容易编写但愿测试代码。
49 3
|
1月前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
67 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
|
2月前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
248 7
Jmeter实现WebSocket协议的接口测试方法
下一篇
无影云桌面