测试平台系列(64) 用Sqlalchemy填下断言的坑

简介: 用Sqlalchemy填下断言的坑

大家好~我是米洛


这是一个完整的接口测试平台系列教程,希望能和大家一起学习,从0到1打造一个开源平台。


回顾


上一节我们讲了软删除,一个看似无关紧要却又很严肃的问题。如今我们来填一下之前的坑

之前埋的坑


之前我们在用例详情页面,只是让用户可以添加断言,但是没有支持编辑和删除的功能,甚至连展示的页面都冇,那今天我们就来好好填坑:

完成这块的编辑和删除功能。

老规矩


做完之前,看下当前的效果图:

16.PNG

提供了一个小小的页面

其实就是在断言tab下面写了个curd的小页面

后端的改动


之所以把这一节单独拉出来讲,是因为以往我们都是新增/编辑数据以后,去请求一次list接口,等于是请求了2次。

这次我们换个方向,请求后直接拿到最新的那条数据,然后整合到现有的table之中。

其实之所以这么做,是因为我这个页面很大,里面有case的很多信息,涉及到多个表,局部数据的刷新我又不想单独包装一个接口。

让我们看看怎么做吧!

了解SqlAlchemy的机制


SqlAchemy是一款大家比较熟悉的orm库,在我的使用过程中发现一个特点:

比如我新建了一个model,使用session.add更新到db里面,如果是同步session则还需要commit操作。

但我们如今的需求是,insert到数据库之后拿到最新的数据。其实sqlalchemy会默认把之前插入过的数据销毁掉,也可能不是销毁,反正就是session结束了之后,数据将不复存在

所以我们百度查了一下,有这样一个方法,可以保留原先的数据:


session.expunge(data)

编写新增断言的接口


17.jpg

新增的接口和之前的区别就在这了

首先用session.flush()等待数据更新,refresh可以帮助我们拿到insert之后的id。

最后我们用expunge方法,保留这个对象,再返回即可。

编写编辑断言的接口


18.jpg

和新增类似

编辑和新增类似,但因为我们不需要获取主键id,因为咱们本来就有,所以只需要expunge即可。

编写删除断言的接口


19.jpg

删除也是一种update

因为软删除的缘故,我们实际上执行的也是update操作。

20.jpg

这样断言的编辑/删除就完成了

新增执行用例的功能


其实很简单,调用一下之前的接口即可。看看图吧~

21.PNG

执行下看看效果


至此,一个case的百分之80的执行流程就已经完毕了。接下来还是有很多事情需要做的:

  • 定时任务执行case
  • 用例变量/全局变量目前应该还没应用到断言之中
  • 断言还不支持JSON对比等等
  • 用例评分系统
  • 用户操作记录
  • 工作台未完成
  • 用户资料修改
  • 用户管理功能
  • 七牛云/阿里云oss接入
  • 其他前置条件类型
  • 后置条件

......


就以上已经有很多内容了,更别说未来的:

  • 数据工厂
  • 精准测试等等
    不过话说回来,这个平台希望的就是真正从0到1做成一个完全体的平台,慢慢填坑吧~




相关文章
|
3月前
|
资源调度 测试技术 Linux
一款接口自动化神器—开源接口测试平台Lim(Less is More)
一款接口自动化神器—开源接口测试平台Lim(Less is More)
142 2
|
5月前
|
分布式计算 测试技术 Spark
通过Langchain实现大模型完成测试用例生成的代码(可集成到各种测试平台)
通过Langchain实现大模型完成测试用例生成的代码(可集成到各种测试平台)
750 0
|
17小时前
|
数据挖掘 测试技术 网络安全
LabVIEW开发卫星测试平台
LabVIEW开发卫星测试平台
|
1天前
|
算法 物联网 5G
LabVIEW开发最小化5G系统测试平台
LabVIEW开发最小化5G系统测试平台
|
2天前
|
消息中间件 测试技术 Linux
linux实时操作系统xenomai x86平台基准测试(benchmark)
本文是关于Xenomai实时操作系统的基准测试,旨在评估其在低端x86平台上的性能。测试模仿了VxWorks的方法,关注CPU结构、指令集等因素对系统服务耗时的影响。测试项目包括信号量、互斥量、消息队列、任务切换等,通过比较操作前后的时戳来测量耗时,并排除中断和上下文切换的干扰。测试结果显示了各项操作的最小、平均和最大耗时,为程序优化提供参考。注意,所有数据基于特定硬件环境,测试用例使用Alchemy API编写。
10 0
linux实时操作系统xenomai x86平台基准测试(benchmark)
|
2天前
|
传感器 Linux 测试技术
xenomai 在X86平台下中断响应时间测试
该文讨论了实时操作系统中断响应时间的重要性,并介绍了x86中断机制和Xenomai的中断管理,包括硬件中断和虚拟中断的处理。Xenomai通过I-Pipe确保实时性,中断优先级高的Xenomai先处理中断。文中还提到了中断响应时间的测试设计,分别针对I-Pipe内核间虚拟中断和硬件中断进行了测试,并给出了在不同负载下的测试结果。
8 0
xenomai 在X86平台下中断响应时间测试
|
10天前
|
Linux 测试技术 数据安全/隐私保护
CentOS安装MeterSphere并实现无公网IP远程访问本地测试平台
CentOS安装MeterSphere并实现无公网IP远程访问本地测试平台
|
18天前
|
人工智能 监控 数据处理
【AI大模型应用开发】【LangSmith: 生产级AI应用维护平台】1. 快速上手数据集与测试评估过程
【AI大模型应用开发】【LangSmith: 生产级AI应用维护平台】1. 快速上手数据集与测试评估过程
38 0
|
2月前
|
缓存 运维 Serverless
应用研发平台EMAS产品常见问题之测试检查更新没有反应如何解决
应用研发平台EMAS(Enterprise Mobile Application Service)是阿里云提供的一个全栈移动应用开发平台,集成了应用开发、测试、部署、监控和运营服务;本合集旨在总结EMAS产品在应用开发和运维过程中的常见问题及解决方案,助力开发者和企业高效解决技术难题,加速移动应用的上线和稳定运行。
|
2月前
|
机器学习/深度学习 人工智能 监控
视觉智能平台常见问题之体验产品的美颜测试关掉如何解决
视觉智能平台是利用机器学习和图像处理技术,提供图像识别、视频分析等智能视觉服务的平台;本合集针对该平台在使用中遇到的常见问题进行了收集和解答,以帮助开发者和企业用户在整合和部署视觉智能解决方案时,能够更快地定位问题并找到有效的解决策略。
24 1

热门文章

最新文章