前言:
  • httprunner3.x版本弱化了api层的概念
  • 直接在testcase中写request请求
  • 如果是单个请求,也可以直接写成一个testcase
  • 每个testcase必须具有两个类属性:config和teststeps
config
每个测试用例都应该有一个config部分,可以在其中配置用例级别,有以下属性
name: 指定测试用例名称 这将显示在执行日志和测试报告中-必填

base_url: 如果base_url指定,则testsetp中的url可以设置相对路径部分-选填

verify: https请求时,是否校验证书,默认为True,忽略证书校验可以设置为FALSE-选填

variables: 指定测试用例的公共变量,每个测试步骤都可以引用未在步骤变量中设置的配置变量
换句话说步骤变量比配置变量具有更高的优先级-选填 export: 早期版本是output,指定导出的测试用例会话变量,把变量暴露处理设为全局变量-选填
teststeps
yaml中testsetps步骤参数,testsetps是一个list,可以有多个步骤

name: 指定测试步骤-必填

request:指定测试步骤变量,参数引用变量"$变量名"-必填

variables:指定测试步骤变量,参数引用变量"$变量名"-选填

extract: 提取返回结果-可选

export: 导出测试用例会话变量,设为全局变量-可选

validate: 校验返回结果

示例

config:
name: 登录用例 teststeps:
-
name: step-登录
request:
url: http://xxx.com
method: POST
json:
username: test
password: "12345"
validate:
- eq: [status_code,200]
- eq: [body.msg,login success]
 

base_url

base_url是部署环境地址
部署环境地址和端口是有可能会变,如test、uat、pre环境等
config:
name: 登录用例 teststeps:
-
name: step-登录
request:
url: http://xxx.com/v1/login/
如上所示,request参数中url是整体的请求地址,如果我们下面有多个步骤要更改或者请求环境更改就需要修改全部步骤的url
我们可以配置base_url来实现简单操作,如下,有需要变更直接修改base_url地址,config中设置了base_url,teststpe中值需要写接口相对路径
config:
name: 登录用例
base_url: http://xxx.com teststeps:
-
name: step-登录
request:
url:/v1/login/
如果config设置了base_url,但是下面的接口步骤中的url写了绝对路径,也可以请求成功,不会冲突
 如果config base_url之后没有其他的请求路径,那么在request中可以 url: /,但是不可以不写
variables变量声明与引用
  • teststeps中变量对当前step有效
  • config中变量在整个yaml中都生效
 
局部变量
在teststeps中,使用variables声明局部变量,格式也是键值对
然后当前步骤调用,使用$变量名进行调用,每个步骤中的variables只对当前步骤有效
config:
name: 登录用例 teststeps:
-
name: step-登录
variables: #声明局部变量
user: test
password: "12345"
request:
url: http://xxx.com/v1/login/
method: POST
json:
username: $user #调用局部变量
password: $password
validate:
- eq: [status_code,200]
- eq: [body.msg,login success]
 全局变量
在config中使用variables声明全局变量,格式也是键值对
在config声明的全局变量,下方所有步骤都可以调用
config:
name: 登录用例
variables: #声明全局变量
user: test
password: "12345" teststeps:
-
name: step-登录
request:
url: http://xxx.com/v1/login/
method: POST
json:
username: $user #调用全局变量
password: $password
validate:
- eq: [status_code,200]
- eq: [body.msg,login success]
如果局部变量和全局变量有同名变量,那么优先级局部变量>全局变量
validate校验结果
使用jmespath提取json响应正文并使用预期值进行验证
-jmes_path:jmespath表达式

-expect:预期值,这里也可以使用指定的预期值、变量或函数引用
-message消息(可选):用于指示断言错误原因

httprunner请求源码片段

    resp_obj_meta = {
"status_code": self.status_code,
"headers": self.headers,
"cookies": self.cookies,
"body": self.body,
}
我们使用httprunner成功请求一个接口,会返回四个字段
status_code :请求状态码
headers:请求头
cookies:请求cookies
body:响应正文,一般是json格式
我们根据上述格式进行验证
jmes_path表达式,expect预期值,message消息(可选)断言失败原因
# 简单示例
validate:
- eq: [status_code,200] #校验请求状态码是200
- eq: [headers.Content-Type,appliction/json] #校验请求头类型是json
- eq: [body.code,0] #校验返回值内容的code是0
- eq: [body.msg,success,msg返回不一致] #校验返回值的msg是success,如果不是,提示原因msg返回不一致
- len_eq: [body.token,40] # 校验返回值的token长度是40
upload
upload关键字专门用于文件上传

teststeps:
-
name: step-登录
request:
url: /v1/login/
method: POST
upload:#上传文件
file: data/test.png
title: '封面'
setup_hooks:
- ${setup_hook()}
- ${request_sign($request)}
teardown_hooks:
- ${teardown_hook()}

2.httprunner-yaml用例结构的更多相关文章

  1. httprunner学习9-完整的用例结构(yaml&json)

    前言 前面几篇零散的学了一些httprunner的知识点,那么一个完整的 YAML/JSON 用例文件包含哪些关键字呢? 测试用例结构 在 HttpRunner 中,测试用例组织主要基于三个概念: 测 ...

  2. HttpRunner学习2--用例格式和简单使用

    前言 HttpRunner中,测试用例支持两种文件格式:YAML 和 JSON.两种格式的用例是完全等价的,对于相同的信息内容,使用 YAML /JSON 得到的测试结果和报告也是一致的. 本人环境: ...

  3. 使用Python写yaml用例

    1.打开cmd,进入本机安装python的目录,执行   pip install pyyaml ,安装pyyaml第三方包. 2.在Pycharm中新建一个项目(已有的话就不需要啦) 新建yaml文件 ...

  4. 【HttpRunner v3.x】笔记 ——4. 测试用例-结构解析

    一.官方首推pytest格式 上篇文章我们知道了,httprunner可以支持三种格式的用例,分别是pytest.yaml和json.yaml和json是以前的版本所使用的用例格式,但是在3.x版本上 ...

  5. HttpRunner学习11--指定用例运行次数

    前言 在HttpRunner中,一般情况下,我们写的用例脚本都是每次运行一次,如果我们想要指定用例运行的次数,可以通过 times 关键字来实现. 测试场景 在这里,我们以访问 TesterHome ...

  6. httprunner(8)用例调用-RunTestCase

    前言 一般我们写接口自动化的时候,遇到复杂的逻辑,都会调用API方法来满足前置条件,Pytest的特性是无法用例之间相互调动的,我们一般只调用自己封装的API方法. 而httprunner支持用例之间 ...

  7. 基于HttpRunner的接口自动化测试平台HttpRunnerManager(二)

    https://github.com/HttpRunner/HttpRunnerManager HttpRunnerManager Design Philosophy 基于HttpRunner的接口自 ...

  8. HttpRunner学习3--extract提取数据和引用

    前言 在HttpRunner中,我们要想从当前 HTTP 请求的响应结果中提取参数,可以通过 extract 关键字来实现. 本人环境:HttpRunner V1.5.8 测试场景 在这里,我将以一个 ...

  9. HttpRunner学习10--hook机制

    前言 对于使用过 Python结合Unittest 框架来做自动化测试的同学,应该知道在 Unittest 中,有这样2个方法:setUp() 和 tearDown() ,即前置和后置操作.通常 se ...

随机推荐

  1. 如何在Linux快速搭建一套ADB环境

    一.ADB简介 1.什么是ADB Android Debug Bridge,安卓调试桥,它借助adb.exe(Android SDK安装目录platform-tools下),用于电脑端与模拟器或者真实 ...

  2. Web 前端实战:JQ 实现下拉菜单

    实现过程 实现一个简易的鼠标悬停菜单项显示其子项的下拉框控件.将用到 CSS 绝对定位.流式布局.动画等:JQuery 鼠标移入和移出事件.DOM 查找.效果图如下: HTML 结构: <div ...

  3. tqdm和zip组合使用时无法显示进度条-解决办法

    问题 单独对于可迭代对象iterator使用tqdm时,结合循环就可以在终端显示进度条, 以直观展示程序进度,如下: from tqdm import tqdm textlist = [] for i ...

  4. java数组---概念

    1.数组的定义 数组是相同类型数据的有序集合.数组描述的是相同类型的若干个数据,按照一定的先后次序排列组合而成.其中,每一个数据称作一个数组元素,每个数组元素可以通过一个下标来访问它们. 2.数组的建 ...

  5. ZJU-199001 第三周练习 2 数字特征值 位运算算法

    题目 对数字求特征值是常用的编码算法,奇偶特征是一种简单的特征值. 对于一个整数, 从个位开始对每一位数字编号, 个位是 \(1\) 号, 十位是 \(2\) 号, 以此类推. 这个整数在第位上的数字 ...

  6. 给ShardingSphere提了个PR,不知道是不是嫌弃我

    说来惭愧,干了 10 来年程序员,还没有给开源做过任何贡献,以前只知道嘎嘎写,出了问题嘎嘎改,从来没想过提个 PR 去修复他,最近碰到个问题,发现挺简单的,就随手提了个 PR 过去. 问题 问题挺简单 ...

  7. Html飞机大战(八):子弹的移动和管理

    好家伙,这应该是这个小游戏最难的几个点之一了 现在我们要做出子弹射击的效果我们应该如何处理? 1.首先我们要确定几个变量和方法的关系 变量: 子弹  bullet  弹夹(用来装子弹的东西)bulle ...

  8. 第二章 Kubernetes快速入门

    一.四组基本概念 Pod/Pod控制器: Name/Namespace: Label/Label选择器: Service/Ingress. 二.Pod/Pod控制器 2.1 Pod Pod是K8S里能 ...

  9. 踩坑之旅:配置 ROS 环境

    以下内容为本人的著作,如需要转载,请声明原文链接微信公众号「englyf」https://www.cnblogs.com/englyf/p/16660252.html 最近在学习机器人相关的导航算法, ...

  10. 《吐血整理》进阶系列教程-拿捏Fiddler抓包教程(20)-Fiddler精选插件扩展安装,让你的Fiddler开挂到你怀疑人生

    1.简介 Fiddler本身的功能其实也已经很强大了,但是Fiddler官方还有很多其他扩展插件功能,可以更好地辅助Fiddler去帮助用户去开发.测试和管理项目上的任务.Fiddler已有的功能已经 ...