news 2026/4/15 4:15:22

0代码实现接口自动化测试 —— RF框架实践

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
0代码实现接口自动化测试 —— RF框架实践

robotframework是一款关键字自动化测试框架,可能做各种类型的自动化测试。本文介绍通过 robotframework 来实现接口测试

01、安装接口请求的第三方库

pip install robotframework-requests

在python安装目录的Lib\site-packages可以看到

02、接口关键字基础

robotframework-requests关键字文档地址:http://marketsquare.github.io/robotframework-requests/doc/RequestsLibrary.html

以我的接口项目中的以下接口为例:

1. 创建测试集合并导入接口库

创建一个测试集合apibasic,选中后在设置区导入RequestsLibrary库

测试集合下添加集合全局变量host,作为接口测试的域名

在该集合下将会针对码同学全栈接口项目中的接口进行测试,每个接口的域名都是一致的,因此我们给测试集合增加一个前置动作,前置动作里完成该域名下session的创建,那么在用例之中发起请求时都使用该session,可以帮我们有效关联相关数据

关键信息解释,创建一个session对象,命名为pinter

  • Create Sesion:这是接口库提供的一个关键字,用来创建一个session对象

  • pinter:这是自定义起的一个session对象的名字,用于后续其他地方要使用时进行引用

  • ${host}:这是引用集合变量定义的host

2. get接口

创建一个用例,起名叫get接口

  • Get On Session:发起get请求的关键字

  • ${resp.json()}[message]:表示提取接口响应body体重的message字段

3. post 表单接口

创建一个用例,起名叫post表单接口

  • Post On Session:发起post请求的关键字

4. post json接口

由于json格式参数通常比较多,所以我们将他定义成了普通变量,但是接口关键字请求时json参数 必须是字典格式,所以使用Evaluate关键字将字符串形式的json参数转换成字典

5. put 接口

6. delete 接口

7. 文件上传

表单形式上传

  • Get File For Streaming Upload:获取本地文件转换成流对象

  • ${resp.text}:因为该接口返回信息并不是json串,是个纯文本,所以使用这种方式获取

Ajax上传接口

8. 文件下载接口

9. 需要签名验证的接口

接口参数格式如下,其中timestamp参数时实时的毫秒时间戳

{"phoneNum":"123434","optCode":"testfan","timestamp":"12112121212","sign":"your sign data"}

签名规则如下:

  • sign字段的值 = phoneNum+optCode+timestamp

    组合在一起然后进行md5加密

因此在脚本中需要先进行加密处理,同时因为用到了实时时间戳,所以我们要导入一个时间处理库 DateTime库,在测试集合中导入DateTime库

加密时的核心:

hashlib.md5('${phoneNum}${optCode}${timestamp}'.encode(encoding='utf8')).hexdigest()

计算得到毫秒时间戳:

int(round(${timestamp} *1000))

脚本如下:

10. cookie关联

在使用相同的session对象时,会自动做到cookie关联

先实现登录接口的用例,再实现查询余额接口的测试,然后两个一起执行即可

一起执行,勾选两条用例

11. token关联

对于接口鉴权采用token时,即便采用相同的session对象也是关联不了的,需要我们自行处理

业务规则:

  • 登录接口成功后响应信息中的data字段就是产生的token值

  • 查询余额接口请求时headers中的testfan-token字段就是token参数名称

因此我们需要从登录接口响应中提取data,并将其传给查询余额的接口headers

脚本如下:

03、rf数据驱动实现接口测试

1. 安装数据驱动依赖库

pip install robotframework-datadriver

在python安装目录的Lib\site-packages可以看到

2. 准备测试数据文件

以码同学全栈接口项目的一个登录接口为例,准备测试数据

创建一个excel文件写入如下数据:

  • 第一行第一列是固定格式,表示测试用例名称

  • 第二列开始是测试数据对应的变量名称

  • 第二行开始是测试数据

3. 创建测试集合并导入第三方库

创建测试集合apidatadriver,导入库RequestsLibrary和DataDriver,注意导入DataDriver时要写参数,导入后标红的话先不用管,继续做

4. 创建集合变量并初始化session

5. 创建登录接口关键字

6. 创建测试用例引用数据驱动

测试用例中只需要在设置的模板中填写第5步创建的登录接口关键字即可

执行测试,测试数据有三组,登录接口也执行了三次

最后作为一位过来人也是希望大家少走一些弯路,在这里我给大家分享一些软件测试的学习资料和我花了3个月整理的软件测试自学全栈,这些资料希望能给你前进的路上带来帮助。

视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 4:15:20

JDK11的安装教程

一、什么是 JDK JDK 是 JAVA 语言的软件开发工具包;JDK 包含了 JAVA 的运行环境(JVM Java 系统类库)和 JAVA 工具 二、下载 JDK11 ① 检查本机是否安装 Win R 键输入cmd进入到Windows控制台,然后输入:java -vers…

作者头像 李华
网站建设 2026/4/15 4:15:19

DeerFlow 图文并茂功能的实现机制

DeerFlow 实现图文并茂的核心在于其信息获取、处理与展示的全流程设计,结合代码库中的多个关键组件协同工作。以下从技术实现角度解析其图文处理能力: 1. 图像资源的获取机制 基于 InfoQuest 的图像提取 在 src/crawler/infoquest_client.py 中,InfoQuestClient 类通过 c…

作者头像 李华
网站建设 2026/4/9 23:37:41

python基于Django的招聘信息系统的设计与实现_dv4l6u2p

文章目录具体实现截图主要技术与实现手段关于我本系统开发思路java类核心代码部分展示结论源码lw获取/同行可拿货,招校园代理 :文章底部获取博主联系方式!具体实现截图 同行可拿货,招校园代理 python基于Django的招聘信息系统的设计与实现_dv4l6u2p …

作者头像 李华
网站建设 2026/4/8 22:07:05

Java的Stream流

目录 1.什么是Stream Stream的特点 2.Stream流vs传统集合操作 3.创建Stream流 4.Stream常用方法 4.1中间方法 过滤操作 排序操作 限制和跳过元素 去重操作 映射操作 流合并 关键点总结 4.2 终结方法 1.foreach 2.count统计个数 3.max/min 最大/最小值 4.3 收…

作者头像 李华
网站建设 2026/4/11 17:37:45

北京化工大学《Chem. Commun.》突破:液体焦耳加热“秒级”合成催化剂,性能碾压贵金属!

导语 电解水制氢的核心催化剂合成技术迎来效率革命!北京化工大学胡传刚教授与苏州科技大学郭春显教授团队在化学领域权威期刊《Chemical Communications》 上发表重要研究成果。该团队首创 “超快液体焦耳加热” 技术,在数秒内即可在泡沫镍上原位合成出高…

作者头像 李华
网站建设 2026/4/12 10:17:50

中国石油大学/天津大学《CEJ》突破:0.5秒极速“烧”制合金膜,实现CO₂到甲酸近100%高效转化

导语 将温室气体CO₂高效、高选择性地转化为高价值化学品,是实现“双碳”目标的核心技术之一。近日,中国石油大学吴文婷教授、宁汇副教授及天津大学陈亚楠教授团队在国际权威期刊《Chemical Engineering Journal》上发表创新成果。该研究采用一种毫秒级焦…

作者头像 李华