测试平台系列(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做成一个完全体的平台,慢慢填坑吧~




相关文章
|
28天前
|
关系型数据库 MySQL 测试技术
【分享】AgileTC测试用例管理平台使用分享
AgileTC 是一个脑图样式测试用例管理平台,支持用例设计、执行与团队协作,帮助测试人员高效管理测试流程。
172 116
【分享】AgileTC测试用例管理平台使用分享
|
26天前
|
人工智能 数据可视化 测试技术
AI测试平台自动遍历:低代码也能玩转全链路测试
AI测试平台的自动遍历功能,通过低代码配置实现Web和App的自动化测试。用户只需提供入口链接或安装包及简单配置,即可自动完成页面结构识别、操作验证,并生成可视化报告,大幅提升测试效率,特别适用于高频迭代项目。
|
1月前
|
人工智能 测试技术 调度
写用例写到怀疑人生?AI 智能测试平台帮你一键生成!
霍格沃兹测试开发学社推出AI智能测试用例生成功能,结合需求文档一键生成高质量测试用例,大幅提升效率,减少重复劳动。支持自定义提示词、多文档分析与批量管理,助力测试人员高效完成测试设计,释放更多时间投入核心分析工作。平台已开放内测,欢迎体验!
|
1月前
|
人工智能 测试技术 项目管理
测试不再碎片化:AI智能体平台「项目资料套件」功能上线!
在实际项目中,需求文档分散、整理费时、测试遗漏等问题常困扰测试工作。霍格沃兹推出AI智能体测试平台全新功能——项目资料套件,可将多个关联文档打包管理,并一键生成测试用例,提升测试完整性与效率。支持套件创建、文档关联、编辑删除及用例生成,适用于复杂项目、版本迭代等场景,助力实现智能化测试协作,让测试更高效、更专业。
|
2月前
|
存储 人工智能 算法
AI测试平台实战:深入解析自动化评分和多模型对比评测
在AI技术迅猛发展的今天,测试工程师面临着如何高效评估大模型性能的全新挑战。本文将深入探讨AI测试平台中自动化评分与多模型对比评测的关键技术与实践方法,为测试工程师提供可落地的解决方案。
|
4月前
|
存储 测试技术 虚拟化
VMmark 4.0.3 - 虚拟化平台基准测试
VMmark 4.0.3 - 虚拟化平台基准测试
95 0
VMmark 4.0.3 - 虚拟化平台基准测试
|
28天前
|
人工智能 自然语言处理 测试技术
AI测试平台的用例管理实践:写得清晰,管得高效,执行更智能
在测试过程中,用例分散、步骤模糊、回归测试效率低等问题常困扰团队。霍格沃兹测试开发学社推出的AI测试平台,打通“用例编写—集中管理—智能执行”全流程,提升测试效率与覆盖率。平台支持标准化用例编写、统一管理操作及智能执行,助力测试团队高效协作,释放更多精力优化测试策略。目前平台已开放内测,欢迎试用体验!
|
2月前
|
存储 人工智能 文字识别
从零开始打造AI测试平台:文档解析与知识库构建详解
AI时代构建高效测试平台面临新挑战。本文聚焦AI问答系统知识库建设,重点解析文档解析关键环节,为测试工程师提供实用技术指导和测试方法论
|
2月前
|
人工智能 安全 数据可视化
安全测试平台的选型标准与搭建思路
随着企业安全需求升级,传统漏洞扫描和渗透测试已无法满足要求。构建安全测试平台(STP)成为趋势,实现漏洞扫描、权限评估、接口测试等工作的平台化运营。本文从选型标准、平台架构、模块功能等六个方面,系统讲解如何搭建企业级安全测试平台,提升安全能力。
|
5月前
|
安全 前端开发 Linux
Immunity CANVAS Professional 7.27 (macOS, Linux, Windows) - 渗透测试和漏洞利用平台
Immunity CANVAS Professional 7.27 (macOS, Linux, Windows) - 渗透测试和漏洞利用平台
167 3
Immunity CANVAS Professional 7.27 (macOS, Linux, Windows) - 渗透测试和漏洞利用平台

热门文章

最新文章