HttpRunner自动化测试工具之获取响应数据&extract提取值到变量

获取响应数据

extract: 提取

注:extract 应与request保持同一层级

1、响应行,响应头;通过 extract 提取响应的数据并存储到变量中,如下图:

注:变量名的前面要有 -

获取响应数据: 响应行(200,ok)\响应头

  • config:

name: 测试百度网站

base_url: https://www.baidu.com

  • test:

name: 接口名称 百度接口

request:

url: /

method: GET

extract: # 提取值存储到变量中

  • code: status_code # 响应码

  • info: reason # ok

  • header_Content: headers.Content-Type # 响应头部

validate:

  • eq: [code,200\] # 引用变量 变量名

  • eq: [$info,"OK"]

  • eq: [$header_Content,'text/html']

2、获取响应正文

extract 解析响应正文(支持正则)

通过 extract 提取响应正文的数据并存储到变量中(可使用正则提取),如下图:

注:如果断言为中文,加上headers头部的Accept-Language即可,后面有专门写的中文乱码解码的问题解决

获取响应数据 响应正文(支持正则)

  • config:

name: 百度

base_url: https://www.baidu.com

  • test:

name: 百度主页

request:

url: /

method: GET

headers: # 如果断言为中文的话,加上headers的Accept-Language即可

Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9

Accept-Encoding: gzip, deflate, br

Accept-Language: zh-CN,zh;q=0.9

User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/93.0.4577.82 Safari/537.36

extract:

  • title: <title>(.+?)</title> # 可以使用正则表达式提取

validate:

  • eq: [$title,"百度一下,你就知道"]

extract 解析响应正文(支持json)

通过 extract 提取响应正文的数据并存储到变量中(提取json数据),格式以content为根节点:content.key.key.key ;如下图:

注:可通过 https://www.bejson.com/ 该网址展示json视图更清晰

获取响应数据 响应正文 (支持json)

  • config:

name: 用户标签管理

base_url: https://api.weixin.qq.com

  • test:

name: 百度主页

request:

url: /cgi-bin/tags/get

method: GET

params:

access_token: 49_lsdk_pQJJ4R5IWdWVcDTQu3bHyVOsHDlAcuA99UtVwsmzrtHhSGJKgSPMi3i3TdOQrGeuzZdB62K1uhcKJQAk6eKjzlBL7HgWvAmw7gfiRTp00QnLdSZzN7ul9f2TMPex-Iz2tCg-ZWsSPLbJTJdABAYIY

extract:

validate:

  • eq: [$id,2]

  • eq: [$name,"星标组"]

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

相关推荐
一只积极向上的小咸鱼1 小时前
Codex 在 VS Code + ModelArts 场景下的登录与配置总结
linux·运维·windows
Waay5 小时前
Linux Shell 知识点考评(一):grep 文本搜索(附答案)
linux·运维·服务器
碧海银沙音频科技研究院6 小时前
基于VMware虚拟机ubuntu开发博通BK7258方法
linux·运维·ubuntu
黄昏回响10 小时前
信息系统基础知识(五):专家系统(ES)详解
程序人生·自动化·软件工程·改行学it
谁似人间西林客10 小时前
工厂大脑如何让汽车制造告别“救火式”运维?
运维·汽车·制造
飞飞传输11 小时前
数字化科研提速关键 构建安全可控一体化跨网数据传输体系
大数据·运维·安全
wanhengidc11 小时前
服务器中带宽的重要性
运维·服务器·网络·安全·web安全
云游牧者12 小时前
K8S故障排查三板斧-CSDN博客
运维·docker·云原生·kubernetes·k8s·容器化·故障排查
程序员老邢12 小时前
【技术底稿 32】Nginx 经典大坑复盘:本机公网域名自环代理,导致接口返回首页 / 404 实战排障
java·运维·nginx·前后端分离·技术底稿·后端部署
忧云13 小时前
开源 SSH 客户端 Netcatty:免费替代 Termius,带 AI 的现代化运维工具
运维·开源·ssh