用户分享|Apifox 结合 Jenkins 持续集成接口自动化测试

Apifox基本使用

Apifox官方下载:Apifox - API 文档、调试、Mock、测试一体化协作平台。拥有接口文档管理、接口调试、Mock、自动化测试等功能,接口开发、测试、联调效率,提升 10 倍。最好用的接口文档管理工具,接口自动化测试工具。

Apifox的界面和功能和Postman大同小异,不过Apifox更加的便捷,使用起来也更加的高效,我们先来看下最基本的使用,熟悉Postman的同学应该是开箱即会可以跳过这个步骤。

主窗口

这里可以创建个人团队,也可以加入团队项目,并且项目可以实现共享,这样方便了接口管理及团队管理。

接口管理

新建一个接口,默认是这个页面,你可以编写这个接口的请求方式,请求路径,选择对应的环境,非常适合开发快速生成接口文档供测试进行接口测试(我就是那个被开发这样丢文档给我的测试),

请求参数:Params,在文档中可以添加此接口需要传入哪些参数,并设置类型,示列值,说明

Body:json,一般这个请求格式用的会多一些,和请求参数一样,填好后,之后你对这个接口添加测试用例,这些参数会自动带进去,你只要做一些简单的修改即可。

前置操作,后置操作,根据业务需求进行使用,比如登录后会有token,那么可以通过后置操作提取token值为全局变量,后面要使用的时候直接两个花括号加变量值就可以使用了,如{{token}}

返回响应:这一部分可以写响应示列值,可以在项目设置 -> 功能设置 -> 响应校验设置中设置你响应校验的内容。

token接口传值

前面说到可以通过后置操作提取token值为全局变量,这里大致说下操作步骤。

1、登录接口,接口响应值会带有token,这个token就是我们之后访问需要鉴权接口必传的值。

2、这里可以看到json格式的响应值里面有个token的参数,通过后置操作可以提取出来,而Apifox的简单变量提取很方便,其他的还是需要自己编写脚本。(红框位置可以预览自己的提取值是否正确。)

3、使用token值,我的个人项目后端接口鉴权是在请求头里面,Authorization Bearer {{token}},正常提取全局变量环境变量可以直接点击输入框旁边的魔法棒就可以直接选择,也可以通过这个方法进行mock数据,比如随机生成手机号码。

自定义脚本验证响应

Apifox里面添加后置操作,选择自定义脚本,即可编写自定义的断言验证方式。

比如以下是我的一个响应验证脚本,根据响应里面的gender值配置不同的断言方式。

pm.test("根据gender值验证data下面的人设数量是否正确", function () {
    var jsonData = pm.response.json();
    var gender = jsonData.user.gender;
    var data = jsonData.data;
  
    function calculateTotalIdLength(array) {
        return array.length
    }

    //计算每个分类下的人设数量
    var mineIdLength = calculateTotalIdLength(data.mine);
    console.log(mineIdLength)

    var specialLength = calculateTotalIdLength(data.special);
    console.log(specialLength)

    var trendyLength = calculateTotalIdLength(data.trendy);
    console.log(trendyLength)

    totalIdLength  = mineIdLength + specialLength + trendyLength
    console.log(totalIdLength)

    // 根据性别验证人设的总数
    if (gender === 2) {
        pm.expect(totalIdLength).to.eql(36);
    } elseif (gender === 1) {
        pm.expect(totalIdLength).to.eql(29);
    }

    // 验证mine的长度
    pm.expect(mineIdLength).to.be.at.least(12);
});

Apifox自动化测试

1、点击左侧菜单中的自动化测试,可以新建测试场景。

2、可以从接口或者从接口用例里面导入你要测的内容,比如我设置一套注册、登录、查看用户、修改用户、查看用户正向流程,就可以把对应的接口用例导入进来,根据不同的场景修改对应的断言方式从而确保接口在该业务场景下能够正常执行。

3、设计的过程需要自己一步步调试好,最后点击右侧运行就可以直接运行这个场景了。

4、如果你有其他的测试数据,可以导入进来,或者直接在Apifox进行操作,比如你有20个用户的账号密码,你要全部登录一遍验证登录接口,就可以像如下添加数据集。

5、运行成功后可以看到测试报告,测试报告如果有断言失败的,可以查看详情。

6、在自动化场景测试中,还可以看到导航栏有一个CI/CD,这个就是持续部署持续集成,选择你项目持续部署的平台,根据提示进行配置就ok了,记得需要生成一下Access Token,保存好,生成一次后不会再显示出来了,下次申请就是新的了,老的还的去替换掉。

7、我使用的是jenkins,那么就需要在jenkins的流水线pipeline配置中配置下面的内容。

Apifox结合Jenkins持续集成

如何部署Jenkins在之前的文章有写:Jenkins部署及持续集成——傻瓜式教程

下载pipeline

1、正常你没有下载pipeline的话,在新建item中是看不到流水线Pipeline的

2、Dashboard -> Manage Jenkins -> System Configuration -> Plugins

3、进入后,Available plugins中搜索Pipeline进行下载即可,这里我已经下载了所以看不到。

4、下载好的插件在Installed plugins中

新建Pipeline类型项目

1、新建一个Pipeline流水线项目

2、在General中的流水线中,写入从Apifox中复制的Pipeline script,由于我是windows进行演示,不是在服务器的linux系统中,所以我的脚本会修改成bat命令,如果直接使用的是linux系统就不需要进行修改。因为在Apifox中我们复制的命令只有一个场景的自动化,如果有多个场景,那你可以在后面加stage就可以。比如我这里就是两个场景。具体的Pipeline语法可以参考官网进行学习。

3、在general中可以构建触发器,比如你gitlab提交了代码就进行触发,这里我只做集成测试,之前的Jenkins教程里面有写如何构建触发器,感兴趣的可以移步查看。

配置%APIFOX_ACCESS_TOKEN%

保存好项目之后,还需要进行配置一个全局变量,不知道大家还记不记得前面Apifox里面的一个Access_token,这个值在Pipeline脚本中有个像我们环境变量一样的值%APIFOX_ACCESS_TOKEN%,这个是需要我们在Jenkins中配置的。

1、Dashboard -> Manage Jenkins -> System Configuration -> System 这里可以配置全局变量和路径。

2、进入之后下滑到全局属性,勾选【环境变量】Environment variables,输入APIFOX_ACCESS_TOKEN键值进行配置

3、点击应用,保存

Build项目进行测试

1、点击Build Now进行项目构建

2、进入构建,点击Console Output查看日志输出

3、发现Jenkins中文输出乱码,解决方案一,启动Jenkins的时候加入启动参数

启动加参数:

java  -Dfile.encoding=UTF8 -jar jenkins.war

解决方案二:在全局变量中加入以下键值对

key:JAVA_TOOL_OPTIONS
value:-Dfile.encoding=UTF8

4、输出日志正常

5、在项中可以看到构建历史,可以看到相关数据

6、回到Apifox中,可以看到同步过来的测试报告(需要刷新一下)

除此之外Apifox还有定时任务,现在还是Beta版本,这个我就没去试验了,目前在重构自己的接口测试平台,这些工具对单接口测试,开发自测是非常方便的,但针对于一些场景业务,还需要很多定制化。

说在最后

如果你也有类似的 Apifox 使用场景或遇到的问题解决过程,欢迎来稿分享,有精美周边掉落哦!无论是个人使用小技巧,还是解决难题的思路想法,统统都可以!

最后: 下方这份完整的软件测试视频教程已经整理上传完成,需要的朋友们可以自行领取【保证100%免费】

### 如何在 Jenkins 中实现 Apifox持续集成 要在 Jenkins 中实现 Apifox持续集成,可以按照以下方法操作: #### 1. 安装必要的插件和工具 确保 Jenkins 已安装 `Pipeline` 插件以及任何其他可能需要的构建工具。此外,还需要下载并配置 Apifox CLI 工具以便通过命令行执行测试。 可以通过访问 Apifox 官方文档获取最新版本的 CLI 下载链接[^1]。将其解压后放置于系统的 PATH 环境变量下,或者直接指定其可执行文件的位置。 #### 2. 创建一个新的 Jenkins Pipeline Job 创建一个新任务,在类型选择中选取 “Pipeline”。此类型的作业允许定义复杂的流水线脚本用于自动化流程控制。 #### 3. 编写 Jenkinsfile 或者直接输入 Scripted Pipeline 脚本 下面是一个简单的声明式 Jenkins Pipeline 示例,展示如何调用 Apifox CLI 来运行 API 测试并将结果报告回传给 Jenkins: ```groovy pipeline { agent any environment { // 设置环境变量 APIFOX_TOKEN = 'your-apifox-token' PROJECT_ID = 'your-project-id' } stages { stage('Run Apifox Tests') { steps { script { echo "Starting Apifox tests..." sh """ apifox test run \ --projectId ${env.PROJECT_ID} \ --token ${env.APIFOX_TOKEN} \ --reportPath ./apifox-report.html """ archiveArtifacts artifacts: 'apifox-report.html', onlyIfSuccessful: false } } } stage('Notify Results via Webhook') { steps { script { def webhookUrl = 'http://127.0.0.1:8080/webhook' httpRequest contentType: 'APPLICATION_JSON', customHeaders: [[name: 'Authorization', value: env.APIFOX_TOKEN]], httpMode: 'POST', requestBody: """{ "message": "Apifox Test Completed", "status": "${currentBuild.result}" }""", url: webhookUrl } } } } post { always { mail to: 'team@example.com', subject: "Job '${env.JOB_NAME}' (${env.BUILD_NUMBER}) Result Notification", body: "The build has finished with status: ${currentBuild.result}. Check the report here: ${BUILD_URL}/artifact/apifox-report.html" } } } ``` 上述脚本实现了以下几个功能: - 使用 `sh` 步骤来触发 Apifox CLI 命令以运行测试,并生成 HTML 报告。 - 将生成的测试报告存档为构件 (`archiveArtifacts`) 方便后续查看。 - 利用了 HTTP 请求发送通知至自定义的服务端接口地址(如钉钉、飞书等),这一步可以根据实际需求调整[^2]。 - 构建完成后向团队成员发送电子邮件通知。 #### 4. 配置凭证管理 对于敏感数据例如 Apifox Token 和项目 ID 不应硬编码进脚本里,而是应该利用 Jenkins 凭证存储机制安全地保管它们。这样既提高了安全性又便于维护。 --- ### 注意事项 - **权限设置**:确认所使用的 Jenkins 用户有足够的权限去读取所需资源及上传工件。 - **网络连通性**:保证 Jenkins Server 能够无障碍连接到外部服务包括但不限于 Apifox 平台本身及其相关依赖项。 - **错误处理逻辑增强**:考虑加入更多的异常捕获与日志记录措施提升稳定性。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值