测试平台系列(75) 完善测试计划的删改查功能

简介: 测试平台系列(75) 完善测试计划的删改查功能

大家好~我是米洛


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


回顾


上一节我们写好了一个测试计划的初级版本,并且能够添加计划,也能定时执行。那今天我们就来完善测试计划删改查与APScheduler相结合的部分。

定时任务和测试计划的耦合


目前来看,测试计划和定时任务有着高度的耦合,考虑到我们并不打算做一款自由度高的定时job系统,所以暂时就先按这个思路设计。毕竟我们是一个做接口自动化的平台,而不是类似jenkins一样,有各类任务的平台。如果后续有相关的需求,我们再考虑。

所以现在的情况是,定时任务列表存放了一批job数据,测试计划表又存放了与之对应的测试计划数据。

查询定时任务


我们之前不是添加过一个定时任务吗?我们先来看看用APScheduler的api,获取到的数据内容。这时候就需要debug了~

Scheduler对象是有个get_job的方法,我们之前给job的id定义为测试计划的id。

所以我们现在可以用测试计划的id去查询定时任务的一些信息。

在utils/scheduler.py新增list_test_plan方法:


@staticmethod
    def list_test_plan(data: List):
        for d in data:
            job = Scheduler.scheduler.get_job(str(d.get('id')))
            print(job)
            d["next_run"] = job.next_run_time

传入的data是查询测试计划接口拿到的测试计划数据

14.jpg

image

过程如下:

  1. 获取到测试计划数据
  2. 根据测试计划数据去获取到定时任务的数据
  3. 一并返回

15.jpg

看看一个job返回的数据

其实我这里弱化了定时任务的特点,反而把cron这样的字段剥离到测试计划之中了。所以这个定时任务给我们的作用就只有2个:

  • 它是不是存在
  • 它是否正常工作,可以通过next_run_at来判断
    所以我们只需要在查询接口,加上next_run_at就可以了。

16.jpg

可以看到,我们是没有2这个测试计划的,所以查出来的job是None

这点很重要,因为我们可能创建测试计划成功了,但创建定时任务失败了。所以这个数据不可忽略。

当我们没获取到job的时候,把job的state改为2(并非在数据库改),只是在页面上显示这个测试计划任务未添加成功!!!

17.jpg

获取定时计划的最终结果如下

编写编辑/删除定时任务方法


由于APS本身就提供了良好的api,所以我们简易封装一下即可。


@staticmethod
    def edit_test_plan(plan_id, plan_name, cron):
        """
        通过测试计划id,更新测试计划任务的cron,name等数据
        :param plan_id:
        :param plan_name:
        :param cron:
        :return:
        """
        Scheduler.scheduler.modify_job(job_id=str(plan_id), trigger=CronTrigger.from_crontab(cron), name=plan_name)
    @staticmethod
    def pause_resume_test_plan(plan_id, status):
        """
        暂停或恢复测试计划,会影响到next_run_at
        :param plan_id:
        :param status:
        :return:
        """
        if status:
            Scheduler.scheduler.resume_job(job_id=str(plan_id))
        else:
            Scheduler.scheduler.pause_job(job_id=str(plan_id))
    @staticmethod
    def remove(plan_id):
        """
        删除job,当删除测试计划时,调用此方法
        :param plan_id:
        :return:
        """
        Scheduler.scheduler.remove_job(str(plan_id))

这边已经都写好了注释,至于为什么我们需要pause和resume方法呢,是因为有时候我们可能不太想跑这个任务,我们想先暂停一下,所以有这个情况发生。

修改对应的接口


18.jpg

红线部分是修改的地方,此外我们新增了一个switch接口,用于开关定时任务

我们来测试下暂停功能:

  • 暂停之前获取测试计划列表

19.jpg

image

  • 暂停之后

20.jpg

image

可以看到,由于next_run_at为None了,所以我们之前的strftime失效了。

所以我们要做下调整:

21.jpg

image

所以我们testplan有了3个状态:

  • 0:等待中
  • 1: 执行中
  • 2: 定时任务未添加
  • 3: 定时任务已暂停
    有了这些数据,我们前端就知道要怎么展示测试计划的定时任务状态了。
    下一节我们就要开始编写测试计划页面的前端部分了。



相关文章
|
5天前
|
人工智能 供应链 安全
AI辅助安全测试案例某电商-供应链平台平台安全漏洞
【11月更文挑战第13天】该案例介绍了一家电商供应链平台如何利用AI技术进行全面的安全测试,包括网络、应用和数据安全层面,发现了多个潜在漏洞,并采取了有效的修复措施,提升了平台的整体安全性。
|
15天前
|
监控 安全 测试技术
构建高效的精准测试平台:设计与实现指南
在软件开发过程中,精准测试是确保产品质量和性能的关键环节。一个精准的测试平台能够自动化测试流程,提高测试效率,缩短测试周期,并提供准确的测试结果。本文将分享如何设计和实现一个精准测试平台,从需求分析到技术选型,再到具体的实现步骤。
65 1
|
1月前
|
人工智能 监控 测试技术
云应用开发平台测试
云应用开发平台测试
49 2
|
15天前
|
监控 安全 测试技术
构建高效精准测试平台:设计与实现全攻略
在软件开发过程中,精准测试是确保产品质量的关键环节。一个高效、精准的测试平台能够自动化测试流程,提高测试覆盖率,缩短测试周期。本文将分享如何设计和实现一个精准测试平台,从需求分析到技术选型,再到具体的实现步骤。
40 0
|
11天前
|
JSON Java 测试技术
SpringCloud2023实战之接口服务测试工具SpringBootTest
SpringBootTest同时集成了JUnit Jupiter、AssertJ、Hamcrest测试辅助库,使得更容易编写但愿测试代码。
43 3
|
1月前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
64 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
|
2月前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
245 7
Jmeter实现WebSocket协议的接口测试方法
|
2月前
|
JSON 移动开发 监控
快速上手|HTTP 接口功能自动化测试
HTTP接口功能测试对于确保Web应用和H5应用的数据正确性至关重要。这类测试主要针对后台HTTP接口,通过构造不同参数输入值并获取JSON格式的输出结果来进行验证。HTTP协议基于TCP连接,包括请求与响应模式。请求由请求行、消息报头和请求正文组成,响应则包含状态行、消息报头及响应正文。常用的请求方法有GET、POST等,而响应状态码如2xx代表成功。测试过程使用Python语言和pycurl模块调用接口,并通过断言机制比对实际与预期结果,确保功能正确性。
254 3
快速上手|HTTP 接口功能自动化测试
|
2月前
|
JavaScript 前端开发 测试技术
ChatGPT与接口测试
ChatGPT与接口测试,测试通过
49 5
|
1月前
|
JavaScript 前端开发 API
vue尚品汇商城项目-day02【9.Home组件拆分+10.postman测试接口】
vue尚品汇商城项目-day02【9.Home组件拆分+10.postman测试接口】
40 0
下一篇
无影云桌面