最近发现做接口测试的朋友越来越多了,打算写一个系列的rf+requests做接口测试(主要是Http接口)的文档,可以帮助新入门的同学对接口测试有个大概的了解,同时也是敦促自己做总结的一种手段。希望经验丰富的大神路过时,如发现我文档中的不足,提出中肯的批评及更好的解决思路。以期共同进步。
一、环境准备
1)默认已经安装robotframework
2)默认已经安装requests库
3)默认已经安装并成功导入RequestsLibrary
4)会用抓包工具,fiddler或Charles都可
用这个库做接口测试,希望用户本身对这个库有一定的了解,如果不了解,那么我们来叨一叨选择的理由。
1)Python的requests库号称是“HTTP for Humans”,它提供了非常方便且人性化的接口调用方法,上手快,功能强大且完美,甩同类库urllib2, httplib好几条街。国外网友的使用心得大多是,呵呵呵呵,用requests库十几行代码,把以前的几百行代码重构了。缺点是封装了太多层,不利于http底层原理的理解。中文版用户指南:http://docs.python-requests.org/zh_CN/latest/user/quickstart.html
2)RequestsLibrary是基于requests模块做的RF库,其根基本身就强大,再加上git上有一些大神一直在对其进行持续地更新及维护,提供了很不错的官方Demo,从使用人数来说,也是完爆那些HTTPLibrary之流,意味着遇到问题得到解答的机会更大。Git地址:https://github.com/bulkan/robotframework-requests/
二、Http接口测试初窥
这一节要写一个get请求的例子,强烈推荐使用官方Demo入门,并且建议新老用户都熟悉Demo的每一个细节,对,是每一个细节。笔者当初多走了许多弯路,对这个细致的Demo相见恨晚,每次都温习demo而后知耻。。
第一个栗子:假如有个这样的get请求:https://api.github.com/users/bulkan,抓包
可以看出,这个接口请求中:
协议: https
访问的host: api.github.com
root url(基础url): https://api.github.com
相对uri: /users/bulkan
method: get
传输参数: 无
该抓包其对应的测试用例如下:
对应到用例,第一步创建一个到https://api.github.com的session,取个很容易认的别名github,第二步,使用get方法,访问别名为github的相对路径/users/bulkan。第3,4步断言返回数据。
对于前面两步,直接使用requests.get方法可以一步完成,为什么要强制拆成两步呢。可以大概揣测一下作者的意图:
1、使用别名,会使后面的请求写起来更顺手,用例也比较好看,大部分时候访问同一地址的请求,不需要重复创建session
2、session的使用,可以实现跨请求保持一些cookie,这个功能才是session的重头戏。
Get request的好基友是post request,也是非常基础的必须掌握的一种请求方式,这个我就不写了。官方Demo几乎列出了所有可能出现的get 及post请求的例子,非常经典,实际项目中都能从里面找到原型。另外还有一些不常见的请求方式如head, put, delete等,也有例子。
三、如何开始你的接口测试第一步
首先,你得有项目组完善且规范的接口文档。好吧,大部分的中小公司的宝宝会说啥文档也没有。也可以通过抓包来开始做项目的接口demo,在无须外力的因素下迈出第一步,但是单凭抓包是抓不全的,所以最终实施前还是得搞来一份完整的接口文档,才能保证用例的覆盖。
单有接口文档也是不够的,还要学会如何抓包,抓包后知道如何解剖一个请求,重点关注请求的method, url, request header, request body, cookie, response header, response body等,还是那句话,办法永远比问题多,培养好的观察能力和解决问题能力无比重要。
原文地址:https://www.cnblogs.com/changyou615/p/8776517.html