一.安装

(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完整笔记(从搭建到应用)的更多相关文章

  1. 虚拟机搭建Zookeeper服务器集群完整笔记

    虚拟机搭建Zookeeper服务器集群完整笔记 本笔记主要记录自己搭建Zookeeper服务器的全过程,默认已经安装部署好Centos7. 一.虚拟机下Centos无法联网解决方案 1.首先调整虚拟机 ...

  2. Hadoop学习笔记(10) ——搭建源码学习环境

    Hadoop学习笔记(10) ——搭建源码学习环境 上一章中,我们对整个hadoop的目录及源码目录有了一个初步的了解,接下来计划深入学习一下这头神象作品了.但是看代码用什么,难不成gedit?,单步 ...

  3. Hadoop学习笔记(4) ——搭建开发环境及编写Hello World

    Hadoop学习笔记(4) ——搭建开发环境及编写Hello World 整个Hadoop是基于Java开发的,所以要开发Hadoop相应的程序就得用JAVA.在linux下开发JAVA还数eclip ...

  4. Spring学习笔记--环境搭建和初步理解IOC

    Spring框架是一个轻量级的框架,不依赖容器就能够运行,像重量级的框架EJB框架就必须运行在JBoss等支持EJB的容器中,核心思想是IOC,AOP,Spring能够协同Struts,hiberna ...

  5. struts2学习笔记--动手搭建环境+第一个helloworld项目

    在Myeclipse中已经内置好了struts2的环境,但是为了更好的理解,这里自己从头搭建一下: 前期准备:下载struts2的完整包,下载地址:https://struts.apache.org/ ...

  6. NuGet学习笔记3——搭建属于自己的NuGet服务器

    文章导读 创建NuGetServer Web站点 发布站点到IIS 添加本地站点到包包数据源 在上一篇NuGet学习笔记(2) 使用图形化界面打包自己的类库 中讲解了如何打包自己的类库,接下来进行最重 ...

  7. NuGet学习笔记(3) 搭建属于自己的NuGet服务器

    文章导读 创建NuGetServer Web站点 发布站点到IIS 添加本地站点到包包数据源 在上一篇NuGet学习笔记(2) 使用图形化界面打包自己的类库 中讲解了如何打包自己的类库,接下来进行最重 ...

  8. angularJS学习笔记之——搭建学习环境

    学习AngularJS已经好几天了,从今天开始学习AngularJS环境搭建. 无论是Mac.Linux或Windows环境中,您均可遵循本教程学习编程. 第一步:安装Git Git是什么呢? Git ...

  9. NuGet学习笔记(3)——搭建属于自己的NuGet服务器(转)

    在上一篇NuGet学习笔记(2) 使用图形化界面打包自己的类库 中讲解了如何打包自己的类库,接下来进行最重要的一步,从零开始搭建属于自己的NuGet服务器,诚然园子里及其它很多地方已经有完全写好的Nu ...

随机推荐

  1. 深入理解C语言-结构体做函数参数

    结构体做函数参数,在C语言中属于常见现象,此时为了内存考虑,不传递结构体,而是传递结构体的地址 结构体定义 struct Man { char name[64]; int age; }; 结构体可以与 ...

  2. vue-router在返回时返回到上次滚动位置

    参考链接:https://blog.csdn.net/qq_40963664/article/details/79850589

  3. Android Service 入门

    说明 Service 工作在主进程上.生命周期图 两种状态 Started 比如Activity通过调用startService 方法.一旦被启动(Started),服务就永久在后台运行,即使创建他的 ...

  4. check_mysql.sh

    #!/bin/bash# -------------------------------------------------------------------------------# FileNa ...

  5. Forest Program(dfs方法---树上的环)

    题意:http://acm.hdu.edu.cn/showproblem.php?pid=6736 沙漠中的每一个连通块都是一棵仙人掌:一个连通块是一棵仙人掌当且仅当连通块中不存在重边和自环,并且每一 ...

  6. spark的安装步骤

    官网:http://spark.apache.org/downloads.html 安装:tar -zxvf spark-2.4.3-bin-hadoop2.7.tgz#配置环境变量(vim ~/.b ...

  7. iview Message(全局提示)与Notice(通知提醒)全局配置方法

    在使用iview 的Message与Notice组件时,可以对提示框的显示位置与显示时长进行配置. iview提供了两个配置属性.分别是: top 提示组件距离顶端的距离,单位像素. duration ...

  8. golang作用域问题

    //参考 https://segmentfault.com/a/1190000012214571 //参考 https://studygolang.com/articles/2215 func bar ...

  9. k8s之configmap和secret

    1.configmap configmap和secret是两种特殊的存储卷,它们不是给pod提供存储空间用的,而是给管理员或者用户提供了从外部向pod内部注入信息的方式. configmap:把配置文 ...

  10. 2 - sat 模板(自用)

    2-sat一个变量两种状态符合条件的状态建边找强连通,两两成立1 - n 为第一状态(n + 1) - (n + n) 为第二状态 例题模板 链接一  POJ 3207 Ikki's Story IV ...