自动化测试===Httprunner测试框架介绍

项目地址:

 

https://github.com/HttpRunner/HttpRunner

中文手册:

http://cn.httprunner.org/

 

首先是环境搭建:

pip install httprunner

或者

pip3 install httprunner

 

安装完成后cmd执行以下命令,有返回则成功:

 hrun -V

>>>0.9.7

har2case -V

>>>0.1.4

 

测试准备

抓包分析

在开始测试之前,我们需要先了解接口的请求和响应细节,而最佳的方式就是采用 Charles Proxy 或者 Fiddler 这类网络抓包工具进行抓包分析(我个人强推Charles)。

我们以某快递查询接口为例,在本案例中,我们先进行权限校验,然后成功创建一个用户,对应的网络抓包内容如下图所示:

接口和参数:

http://www.kuaidi100.com/query?type=huitongkuaidi&postid=350757819118

 

响应参数如下:

{"message":"ok","nu":"350757819118","ischeck":"1","condition":"F00","com":"huitongkuaidi","status":"200","state":"3","data":[{"time":"2017-12-21 15:42:29","ftime":"2017-12-21 15:42:29","context":"广州市|广州市【广州新永和站】,周祥代 已签收","location":""},{"time":"2017-12-21 14:28:59","ftime":"2017-12-21 14:28:59","context":"广州市|广州市【广州新永和站】,【周海祥/18925068779】正在派件","location":""},{"time":"2017-12-21 14:27:59","ftime":"2017-12-21 14:27:59","context":"广州市|到广州市【广州新永和站】","location":""},{"time":"2017-12-20 23:43:30","ftime":"2017-12-20 23:43:30","context":"广州市|广州市【广州黄埔转运中心】,正发往【广州新永和站】","location":""},{"time":"2017-12-20 20:40:15","ftime":"2017-12-20 20:40:15","context":"广州市|到广州市【广州黄埔转运中心】","location":""},{"time":"2017-12-20 16:18:35","ftime":"2017-12-20 16:18:35","context":"广州市|广州市【广州转运中心】,正发往【广州黄埔转运中心】","location":""},{"time":"2017-12-20 08:27:05","ftime":"2017-12-20 08:27:05","context":"广州市|到广州市【广州转运中心】","location":""},{"time":"2017-12-19 03:21:02","ftime":"2017-12-19 03:21:02","context":"西安市|西安市【西安转运中心】,正发往【广州转运中心】","location":""},{"time":"2017-12-18 22:52:37","ftime":"2017-12-18 22:52:37","context":"西安市|到西安市【西安转运中心】","location":""},{"time":"2017-12-18 22:43:29","ftime":"2017-12-18 22:43:29","context":"西安市|到西安市【西安南郊二站集货点】","location":""},{"time":"2017-12-17 21:29:25","ftime":"2017-12-17 21:29:25","context":"西安市|西安市【西安西郊五站】,【赵永刚/02962255063】已揽收","location":""}]}

 

 

然后右键导出,选择har格式。

 

 

 

将har文件进行转换,cmd命令:

 >>>  har2case kauidi.har  kuaidi.json

这样就可以把har格式的转换为json格式的用例

分割线---------------------------------------------------------------------------------------------------

接下来重点是讲用例,也就是json的组成部分。

生成的.json文件内容如下:

[
  {
    "config": {
      "name": "testset description",
      "variables": [],
      "headers": {
        "User-Agent": "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/61.0.3163.100 

Safari/537.36"
      }
    }
  },
  {
    "test": {
      "name": "/query",
      "request": {
        "params": {
          "type": "huitongkuaidi",
          "postid": "350757819118"
        },
        "url": "http://www.kuaidi100.com/query",
        "method": "GET"
      },
      "validate": [
        {
          "eq": [
            "status_code",
            200
          ]
        },
        {
          "eq": [
            "headers.Content-Type",
            "text/html;charset=UTF-8"
          ]
        },
	{
          ]
        }
      ]
    }
  }
]

测试用例的格式如下:

config作为整个测试用例集的全局配置项

test:对应单个测试用例。

 

我从以下4个方面介绍Httprunner的优势:

第一,断言。

断言参数存放在上述代码的这个部分,因为这是自动生成的,因此我们需要根据参数的返回值自己加进去一些数据。

根据响应参数,我们加进去返回结果

执行一下,发现通过

修改断言为其他,则执行失败。

断言可靠,易于维护。

第二,缓存参数。

我们想获取,第一个参数的postid缓存,通过下面的方法:

 

 当需要引用的时候,直接使用

这样就在test2中使用了,test1中的缓存参数。

 执行两条用例都成功:

 

第三个:数据驱动

同样,以快递号,postid为例,假设我们要测试,从350757819118~~350757819200区间的所有快递号码。我们只需要讲数据写入csv文件,并创建参数和.csv文件的关联。

例如:

执行用例:

总共执行了22条,通过一条用例(是因为预期结果的原因,同理我们也可以将所有预期结果放入csv文件,进行关联。从而减少代码量)。设置的数据均被执行。

 

 最后就是测试报告:

每次执行的测试报告以html的格式保存,

内容如下:

 

包括详细错误日志:

 

 

 

 总结:
因为后台做了大量工作,因此我们只需要维护少量的json数据,工作量减少,效率提高。

灵活性:可根据自己需要,定义合适的方法或者数据缓存机制。

httprunner也提供了基于locust的性能测试,可根据需要直接运行json文件即可!

同时,最重要的是,测试用例和代码的分离。这样使得稍有编码功底的人迅速上手。

接口用例可通过har文件录制转换得到,也可自己定义。

 

 

 

顺便提一下

如果有任何问题,你可以在这里找到我 ,软件测试交流qq群,209092584

posted @ 2018-03-06 11:29  botoo  阅读(30823)  评论(0编辑  收藏  举报