当前位置: 首页 > news >正文

Apifox 「定时任务」操作指南,解锁自动化测试的新利器

定时任务是按照预设时间自动执行的任务,它可以有效解决一些常见问题,比如频繁执行的回归测试和大规模的接口测试,这些任务需要在固定时间点或间隔周期内自动运行,以确保软件的持续集成和持续交付过程中的稳定性和可靠性。通过使用定时任务,可以减少人为操作的失误和麻烦,提高测试效率和准确性。

Apifox 现已支持设置定时任务,例如,你可以定时执行自动化测试中的测试场景。

图片

定时任务生成的测试报告还可以发送给邮箱、飞书、钉钉、企业微信等平台。

图片

当前自动化测试的定时任务仅支持基于自托管 Runner 来执行。Runner 可以理解为是一个自动化程序,可以托管在独立服务器上,它能够执行 Apifox 内的自动化测试定时任务、定时导入接口文档等工作。

下文就来介绍一下怎么通过自托管 Runner 来定时执行自动化测试的测试场景,在开始之前,请确保把 Apifox 更新到了最新版

前置条件

要使用定时任务,首先需要在服务器实例中部署 Runner,以下是 Runner 运行环境的推荐配置及部署方法。

1 Runner 运行环境

推荐的实例规格如下:

图片

当服务器实例准备好后,在部署 Runner 之前还需要确保实例中已安装 Docker 环境,因为 Runner 通过 Docker 来执行任务。

2 安装  Docker

如何在服务器实例中安装 Docker?可以自行搜索一下,或者参考 Docker 官方文档来安装(国内镜像源可以找找云服务器厂商的)。需要注意的是,Docker 的最低版本号需使用 20.10.0。

图片

Docker 环境有了之后,就可以开始部署 Runner 了。

3 部署 Runner

首先需要确保你有团队管理员权限,然后在 Apifox 的主窗口中,选择你的团队,并依次点击「团队资源 -> 通用 Runner -> 部署通用 Runner」。

图片

在弹出框中复制部署通用 Runner 的命令,你可以根据需要定义命令,支持自定义服务器 OS、暴露端口、挂载数据目录等。以下是对这些设置的详细说明:

  1. 服务器 OS:指定了 Docker 容器运行的操作系统。包括 Linux、macOS 和 Windows,选择正确的操作系统是确保 Docker 容器能够正确运行的关键。

  2. Docker 镜像:提供了三种版本,分别是通用版、精简版和自定义版本。若你的「自定义脚本」需要调用外部程序,请根据不同版本所包含的语言环境选择合适的镜像进行安装。

    1. 通用版:包含 Runner 的所有功能,并内置以下外部程序的语言环境:Node.js 18、Java 21、Python 3、PHP 8。

    2. 精简版:包含 Runner 的所有功能,仅内置 Node.js 18 语言环境。

    3. 自定义:包含 Runner 的所有功能,并支持自定义外部程序的语言环境。你可以通过创建自己的 Dockerfile,根据需求添加或移除相关环境。

  3. 暴露端口:Docker 容器默认不会将内部端口暴露给外部访问。通过 -p 参数,你可以将容器内部的端口映射到宿主机的端口上,使得外部可以访问容器提供的服务。例如,-p 80:4524 表示将容器内部的 4524 端口映射到宿主机的 80 端口。

  4. 挂载数据目录:使用 -v 参数可以将宿主机的目录挂载到容器内部,这样容器就可以访问和操作宿主机上的文件(数据库配置、外部程序等)。例如,-v "/opt/runner":/opt/runner 表示将宿主机的 /opt/runner 目录挂载到容器的 /opt/runner 目录。

图片

在服务器实例中粘贴并运行刚才复制的命令,系统将自动拉取镜像并启动容器。

图片

你可以通过 docker ps 命令来查看已启动的 Runner 服务。

图片

Runner 部署完成后,回到 Apifox 的「团队资源」页面,可以查看已连接的 Runner 服务(如未显示,可尝试刷新页面)。在这里,你可以对 Runner 进行管理,包括重命名、添加描述、删除、停用或重启。

图片

成功部署自托管 Runner 后,你就可以在 Apifox 中创建和使用定时任务了。

创建  定时任务

在项目的自动化测试模块中,选择「定时任务」,然后新建定时任务。设置以下信息:

  • 任务名称与说明: 用于区分定时任务并描述其详细目的。

  • 测试场景: 定时任务将执行选定的一个或多个测试场景,每个场景可单独配置。

  • 运行周期: 设置任务的执行周期,如每周日 11 点或每 6 小时一次。

  • 运行于: 选择执行任务的实例,可使用 Apifox 云端(敬请期待)或团队自托管的 Runner。

  • 通知: 开启通知后,运行结果将按设置发送给相关人员,可手动输入非项目成员的邮箱。

图片

基本信息设置完毕后保存即可。

执行 定时任务

定时任务将根据设置的「运行周期」自动执行。在定时任务列表中,可以查看已运行次数、启用状态,以及下次运行时间。

图片

 

查看 测试报告

定时任务运行完成后,运行结果将保存在定时任务的运行结果页面中,你可以随时进入「运行历史」页面查看定时任务运行的详情。

图片

同时,系统将按照设置的通知渠道向相关人员或者平台发送信息。

图片

点击邮件中的「查看详情」链接,即可跳转到 Apifox 端内查看更详细的定时任务报告。

图片

常见问题 解答

Q 在服务器实例中部署了 Runner,但「定时任务」到设定时间点后不生效怎么办?

针对这种情况,建议首先在 Apifox 中手动运行一次「定时任务」,然后在服务器实例中使用 docker logs 命令查看容器的运行日志,确认是否有「定时任务」的相关信息。

图片

如果日志中没有相关信息,建议检查服务器是否开放了 4524 端口,并确认该端口未被防火墙拦截。

同时,可以尝试在测试场景中将「运行于」更改为当前部署的 Runner ,然后点击「运行」按钮,通过检查应用内显示的内容以及 Docker 容器日志,并等待测试场景运行完成后,查看是否有「测试报告」回传,以更详细地定位问题。

图片

此外,你还可以尝试删除旧版 Docker 容器及其对应的镜像,然后重新部署最新版的 Runner。如果问题依然存在,欢迎加入交流群与我们的技术支持联系,以便进一步解决。

Q 如何在服务器实例中删除已安装的 Runner?

首先需要删除容器,命令如下:

  1. 查看容器:docker ps -a

  2. 停止容器:docker stop

  3. 删除容器:docker rm

图片

然后删除镜像,命令如下:

  1. 查看镜像:docker images

  2. 删除镜像:docker rmi

图片

这样,就把部署在服务器实例中的 Runner 删除干净了。

附录

以下是常用的 Docker 命令,你可以对已部署的 Runner 执行相关的操作:

图片

定时任务在 Apifox 中能极大提升工作效率,简化操作流程。通过自托管 Runner 的部署,你可以灵活地安排自动化测试和接口文档导入,享受更高效的团队协作。未来,我们还将推出更多便捷功能,让 Apifox 云端支持定时任务,敬请期待!

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • MATLAB系列09:图形句柄
  • Java 微服务框架 HP-SOA v1.1.4
  • sudo yum remove 误删 恢复
  • 怎么开通GitHub Copilot?不会开通GitHub Copilot?一文看懂
  • 全国职业院校技能大赛(大数据赛项)-平台搭建Spark、Scala笔记
  • 基于JAVA+SpringBoot+Vue的社区智慧养老监护管理平台
  • LeetCode 2374.边积分最高的节点:模拟
  • 【标准库的典型内容】std::declval
  • 使用HTML和CSS制作网页的全面指南
  • Windows X86 远线程注入问题解惑
  • Python实现图形学光栅化的Bresenham算法
  • Linux通过yum安装Docker
  • C高级day4
  • VulnHub-Bilu_b0x靶机笔记
  • 《在华为交换机上配置防止 ARP 攻击》
  • [js高手之路]搞清楚面向对象,必须要理解对象在创建过程中的内存表示
  • 【399天】跃迁之路——程序员高效学习方法论探索系列(实验阶段156-2018.03.11)...
  • Android优雅地处理按钮重复点击
  • C++入门教程(10):for 语句
  • IOS评论框不贴底(ios12新bug)
  • node学习系列之简单文件上传
  • Python进阶细节
  • vue 配置sass、scss全局变量
  • 编写符合Python风格的对象
  • 来,膜拜下android roadmap,强大的执行力
  • 每天一个设计模式之命令模式
  • 前端学习笔记之观察者模式
  • 算法-图和图算法
  • 携程小程序初体验
  • 应用生命周期终极 DevOps 工具包
  • Oracle Portal 11g Diagnostics using Remote Diagnostic Agent (RDA) [ID 1059805.
  • ​LeetCode解法汇总2808. 使循环数组所有元素相等的最少秒数
  • # 20155222 2016-2017-2 《Java程序设计》第5周学习总结
  • $(this) 和 this 关键字在 jQuery 中有何不同?
  • (C语言)strcpy与strcpy详解,与模拟实现
  • (二)Linux——Linux常用指令
  • (附源码)springboot教学评价 毕业设计 641310
  • (三)Kafka 监控之 Streams 监控(Streams Monitoring)和其他
  • (十一)图像的罗伯特梯度锐化
  • (顺序)容器的好伴侣 --- 容器适配器
  • (推荐)叮当——中文语音对话机器人
  • (文章复现)基于主从博弈的售电商多元零售套餐设计与多级市场购电策略
  • (转载)VS2010/MFC编程入门之三十四(菜单:VS2010菜单资源详解)
  • ./configure,make,make install的作用
  • .NET : 在VS2008中计算代码度量值
  • .NET Entity FrameWork 总结 ,在项目中用处个人感觉不大。适合初级用用,不涉及到与数据库通信。
  • .NetCore发布到IIS
  • .net的socket示例
  • .net对接阿里云CSB服务
  • ??javascript里的变量问题
  • [ C++ ] 类和对象( 下 )
  • [18] Opencv_CUDA应用之 基于颜色的对象检测与跟踪
  • [AIGC] Nacos:一个简单 yet powerful 的配置中心和服务注册中心
  • [AIGC] SpringBoot的自动配置解析
  • [Algorithm][动态规划][简单多状态DP问题][按摩师][打家劫舍Ⅱ][删除并获得点数][粉刷房子]详细讲解