HttpRunner完整笔记(从搭建到应用)
一.安装
(1) 直接python2 –m pip install HttpRunner,安装完成后,可使用hrun –V 来查看安装版本;python2 pip install -U HttpRunner可进行版本升级;
(2) 配置环境变量,生成脚本和运行脚本时需要使用har2case和hrun;
(3) 新建测试项目:cd到项目要放置的路径,执行hrun --startproject BaseAccApiTest,即可在该路径下创建新项目BaseAccApiTest;
二.录制脚本
(1) 录制脚本过程,借用charles来进行抓包,抓取具体接口后,导出为.har格式后保存到本地
(2) Cmd进入到导出文件路径,执行har2case $name.har $name.yml/name.json
三.执行脚本
(1) hrun $name.har
(2) 执行完成后,会在report下生成html报告,基本操作过程就这些;
四.脚本格式
(1) 此处只介绍下yml格式的脚本,如需添加多个接口,则只需继续添加test即可;
-config:
name: report
request:
base_url: ''
headers:
'Authorization': 'Bearer eyJhbGciOiJIUzUoKQ'
User-Agent: 'Mozilla/5.0 (Windows NT 10.0; Win64;
x64)
AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.12
Safari/537.36'
variables: []
- test:
name: '用户登录接口(login)'
request:
headers:
'Content-Type': 'application/json;charset=UTF-8'
json:
'name': 'root@aoneai.com'
'password': '63a9f0ea7bb98050796b649e85481845'
method: 'POST'
url: 'http://xxx.xxx.xxx.xxx:8001/gw/aone-rbac/rbac/auth/login'
validate:
- eq:
- status_code
- 200
- eq:
-
headers.Content-Type
- 'application/json;charset=UTF-8'
- eq:
- content.code
- 0
说明:
name 这个test的名字
variables 定义变量名和值, 这里定义的变量名和值只可以在当前test中引用. 引用方法跟上面一样: $变量名
request 这个test具体发送http请求的各种信息, 如下:
url 请求的路径 (若config中有定义base_url,
则完整路径是用 base_url + url )
method 请求方法 POST, GET等等
headers 请求所带的头部信息 (config中request下面的headers中的值会被隐含地加入)
data /
json / param 请求所带内容 对POST方法,
data 是指消息体是键值对表单, json 是指消息体是json串, params 是指用GET方法时带在url后的参数
extract 完成请求后, 从返回内容中抽取数据存入变量, 在后面的请求中, 可以通过引用该变量来获取该值.
validate 完成请求后, 所要进行的验证内容. 所有验证内容均通过该test才算通过,否则失败.
五.缓存参数
(1) 测试过程中经常会需要将上一接口的返回值作为当前接口的请求值,基于这种场景,Httprunner提供了缓存参数机制(extract),具体操作如下:
场景一:
“获取指定定时报告”接口需要“定时报告列表”返回参数中的id来作为参数进行获取报告。
“定时报告列表”接口响应参数如下:
{
"code": 0,
"page": {
"page": 1,
"count": 17,
"size": 20
},
"data": [
{
"startTime":
"",
"email": "624@qq.com",
"cycleUnit":
"month",
"createTime":
"2018-08-09 14:58:08",
"description":
"",
"endTime": "",
"id": 7,
"jobID": 12,
"status": 0,
"scheduleType":
"plan",
"cycleSubParamDay": 9,
"uid": 1,
"cycleSubParamHour": 16,
"title": "月",
"jobGroup": 1,
"updateTime":
"2018-08-09 15:08:54",
"userName":
"root",
"dashboardId": 1
},
{
"startTime":
"",
"email": "624@qq.com",
"cycleUnit":
"week",
"createTime":
"2018-08-09 14:58:40",
"description":
"",
"endTime": "",
"id": 8,
"jobID": 13,
"status": 0,
"scheduleType":
"plan",
"cycleSubParamDay": 4,
"uid": 1,
"cycleSubParamHour": 16,
"title": "周",
"jobGroup": 1,
"updateTime":
"2018-08-09 15:09:07",
"userName":
"root",
"dashboardId": 1
},
…….
}
当需要提取上述返回结果中的id作为下个接口的请求值,则可在“定时报告列表”接口的test下添加:
extract:
- id: content.data.0.id
然后在“获取指定定时报告”test下请求参数下直接引用;
params:
'id': '$id'
六.数据驱动
三种数据源:直接在yaml/json中定义、调用csv文件、调用函数。
1. 直接在yaml或json中引用
定义:
parameters:
- page-size-title-uid:
- ["1","11","3","1"]
- ["0","10","2","1"]
- ["0","12","2","1"]
引用:
request:
method: 'GET'
params:
'page': '$page'
'size': '$size'
'title': '$title'
'uid': '$uid'
注意:网上说parameters可分别加在config或test里,但是实际测试时,发现yaml中只能加在config中,加在test里感觉取不到值。此外,加在config中跑用例集感觉不太合适,比如有三个接口,其中一个接口参数定义了三组,那么跑脚本时,就会执行三次用例集,暂时还没测试多个接口多组变量。
2. 调用csv文件
目前测试是添加在config中,在test中加,一直报VariableNotFound,后续在研究研究。
定义:
parameters:
- page-size-title-uid: ${P(page-size-title-uid.csv)}
其中${P(page-size-title-uid.csv)}可替换为${parameterize(page-size-title-uid.csv)}
引用:
params:
'page': '$page'
'size': '$size'
'title': '$title'
'uid': '$uid'
page-size-title-uid.csv)文件格式:
注意:有时读取文件出错时,可能是文件格式错误,需为utf-8;
3. 调用函数
支持热加载的插件机制debugtalk.py中自定义函数get_size(),然后在config中声名,最后在test中引用。
自定义函数:
def getsize():
return [{"size":10},{"size":15},{"size":20}]
声名:
parameters:
- size: ${getsize()}
引用:
params:
'page': '0'
'size': '$size'
七.断言
Httprunner中,validate来进行对结果进行校验。
validate:
- eq:
- status_code
- 200
- eq:
- headers.Content-Type
- 'application/json;charset=UTF-8'
- eq:
- content.code
- 0
如content.code来校验code是否为0;
八.问题点收集:
1. variables: [{size: 8},{size: 9}]添加到config或test中,参数只能取值size:9,之前是parameters出现过次问题,但由版本1.5.12升级到1.5.13后,parameters问题解决,但variable仍存在此问题!
HttpRunner完整笔记(从搭建到应用)的更多相关文章
- 虚拟机搭建Zookeeper服务器集群完整笔记
虚拟机搭建Zookeeper服务器集群完整笔记 本笔记主要记录自己搭建Zookeeper服务器的全过程,默认已经安装部署好Centos7. 一.虚拟机下Centos无法联网解决方案 1.首先调整虚拟机 ...
- Hadoop学习笔记(10) ——搭建源码学习环境
Hadoop学习笔记(10) ——搭建源码学习环境 上一章中,我们对整个hadoop的目录及源码目录有了一个初步的了解,接下来计划深入学习一下这头神象作品了.但是看代码用什么,难不成gedit?,单步 ...
- Hadoop学习笔记(4) ——搭建开发环境及编写Hello World
Hadoop学习笔记(4) ——搭建开发环境及编写Hello World 整个Hadoop是基于Java开发的,所以要开发Hadoop相应的程序就得用JAVA.在linux下开发JAVA还数eclip ...
- Spring学习笔记--环境搭建和初步理解IOC
Spring框架是一个轻量级的框架,不依赖容器就能够运行,像重量级的框架EJB框架就必须运行在JBoss等支持EJB的容器中,核心思想是IOC,AOP,Spring能够协同Struts,hiberna ...
- struts2学习笔记--动手搭建环境+第一个helloworld项目
在Myeclipse中已经内置好了struts2的环境,但是为了更好的理解,这里自己从头搭建一下: 前期准备:下载struts2的完整包,下载地址:https://struts.apache.org/ ...
- NuGet学习笔记3——搭建属于自己的NuGet服务器
文章导读 创建NuGetServer Web站点 发布站点到IIS 添加本地站点到包包数据源 在上一篇NuGet学习笔记(2) 使用图形化界面打包自己的类库 中讲解了如何打包自己的类库,接下来进行最重 ...
- NuGet学习笔记(3) 搭建属于自己的NuGet服务器
文章导读 创建NuGetServer Web站点 发布站点到IIS 添加本地站点到包包数据源 在上一篇NuGet学习笔记(2) 使用图形化界面打包自己的类库 中讲解了如何打包自己的类库,接下来进行最重 ...
- angularJS学习笔记之——搭建学习环境
学习AngularJS已经好几天了,从今天开始学习AngularJS环境搭建. 无论是Mac.Linux或Windows环境中,您均可遵循本教程学习编程. 第一步:安装Git Git是什么呢? Git ...
- NuGet学习笔记(3)——搭建属于自己的NuGet服务器(转)
在上一篇NuGet学习笔记(2) 使用图形化界面打包自己的类库 中讲解了如何打包自己的类库,接下来进行最重要的一步,从零开始搭建属于自己的NuGet服务器,诚然园子里及其它很多地方已经有完全写好的Nu ...
随机推荐
- 【计算机视觉】极限优化:Haar特征的另一种的快速计算方法—boxfilter
这种以Boxfilter替代integral image 的方法很难使用到haar.LBP等特征检测中,因为像下面说的,它不支持多尺度,也就是说所提取的特征必须是同一个大小,最起码同一个宽高比的,这一 ...
- Centos7 下安装docker
Docker 运行在 CentOS 7 上,要求系统为64位.系统内核版本为 3.10 以上. Docker 运行在 CentOS-6.5 或更高的版本的 CentOS 上,要求系统为64位.系统内核 ...
- And Reachability CodeForces - 1169E (有向图可达性)
大意: 给定序列$a$, 对所有的a[i]&a[j]>0, 从$i$向$j$连一条有向边, 给出$m$个询问$(x,y)$, 求是否能从$x$到达$y$. 裸的有向图可达性, 有向图可达 ...
- 牛客 40F 珂朵莉的约数 (莫队)
珂朵莉给你一个长为n的序列,有m次查询 每次查询给两个数l,r 设s为区间[l,r]内所有数的乘积 求s的约数个数mod 1000000007 直接莫队暴力维护复杂度是$O(8m\sqrt{m})$. ...
- .Net高级工程师面试题
----------高级开发工程师岗位职责: 1.完成平台系统新功能模块开发,维护现有产品,独立地设计.开发.实现和测试关键系统: 2.负责公司项目核心代码的编写: 3.根据产品需求进行业务功能的开发 ...
- Java Web 拦截器和过滤器的区别
一.AOP:面向切面编程,Java Web中有两个常用的技术:拦截器.过滤器 二.拦截器 1.定义:在某个方法或字段被访问之前,进行拦截然后在之前或之后加入某些操作 2.原理:大部分时候,拦截器方法都 ...
- js对象的 两种访问方式
来对象访问属性有两种方式.有一个对象Obj = {"Name":"Langshen","AGE":"28"} 用点访问, ...
- 《深入实践C++模板编程》之四——特例
1. 所谓模板特例,是针对符合某种条件的模板参数值集合另外声明的模板实现变体. template<typename T> class my_vector; template<> ...
- JS基础_关系运算符
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- Laravel 查询数据按照时间分组
首先取消严格模式: // config/database.php // 'strict' => true, // 严谨模式注释掉 查询构造器代码: //查询构造器部分代码 })->with ...