自动化测试接口测试之RESTful接口
Posted 黑黑白白君
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了自动化测试接口测试之RESTful接口相关的知识,希望对你有一定的参考价值。
接口测试的流程主要为:
- 第一步: 分析出测试需求,并拿到开发提供的接口说明文档。
- 第二步: 从接口说明文档中整理出接口测试案例,里面要包括详细的入参和出参数据以及明确的格式和检查点。
- 第三步: 和开发一起对接口测试案例进行评审。
- 第四步: 结合开发库,准备接口测试案例中的入参和出参数据,并整理成csv格式的文件。
- 第五步: 结合接口测试案例文档和csv格式的数据文档,做接口测试案例的自动化案例开发。
RESTful作为目前最流行的API设计规范,测试人员需要对其有一定了解。
1)REST(Representational State Transfer)
互联网软件采用客户端/服务器模式,建立在分布式体系上,通过互联网通信,具有高延时(high latency)、高并发等特点。
- 网站开发,完全可以采用软件开发的模式。但是传统上,软件和网络是两个不同的领域,很少有交集。
- 软件开发主要针对单机环境,网络则主要研究系统之间的通信。
互联网的兴起,使得这两个领域开始融合,现在我们必须考虑,如何开发在互联网环境中使用的软件。
2000年Roy Fielding博士在其博士论文中提出REST(Representational State Transfer)风格的软件架构模式后,REST就基本上迅速取代了复杂而笨重的SOAP,成为Web API的标准了。
REST即Representational State Transfer,可翻译成"表现层状态转化",指的是一组架构约束条件和原则。
-
如果一个架构符合REST原则,就称它为RESTful架构。
-
RESTful架构是目前最流行的一种互联网软件架构。它结构清晰、符合标准、易于理解、扩展方便,所以正得到越来越多网站的采用。
1、表现层(Representation)
把"资源"具体呈现出来的形式,就是它的"表现层"(Representation)。
- 比如,文本可以用txt格式表现,也可以用html格式、XML格式、JSON格式表现,甚至可以采用二进制格式。
- 图片可以用JPG格式表现,也可以用PNG格式表现。
2、状态转化(State Transfer)
访问一个网站,就代表了客户端和服务器的一个互动过程。在这个过程中,势必涉及到数据和状态的变化。
- 由于互联网通信协议HTTP协议,是一个无状态协议。这意味着,所有的状态都保存在服务器端。因此,如果客户端想要操作服务器,必须通过某种手段,让服务器端发生"状态转化"(State Transfer)。而这种转化是建立在表现层之上的,所以就是"表现层状态转化"。
客户端用到的手段,只能是HTTP协议:
- 具体来说,就是HTTP协议里面四个表示操作方式的动词:GET、POST、PUT、DELETE。
- 它们分别对应四种基本操作:GET用来获取资源,POST用来新建资源(也可以用于更新资源),PUT用来更新资源,DELETE用来删除资源。
2)RESTful API 设计
RESTful API是目前比较成熟的一套互联网应用程序的API设计理论。
*为什么需要API架构?
网络应用程序,分为前端和后端两个部分。当前的发展趋势,就是前端设备层出不穷(手机、平板、桌面电脑、其他专用设备…)。因此,必须有一种统一的机制,方便不同的前端设备与后端进行通信。这导致API构架的流行,甚至出现"API First"的设计思想。
2.1 URL设计
1、数据的安全保障(协议):
- API与用户的通信协议,总是使用HTTPs协议。
- 采用https协议,可以提高数据交互过程中的安全性。
2、接口特征表现(域名):
- 用api关键字标识接口url,看到api字眼就代表该请求url链接是完成前后台数据交互的。
- 应该尽量将API部署在专用域名之下:
https://api.example.com
- 如果确定API很简单,不会有进一步扩展,可以考虑放在主域名下:
https://example.org/api/
- 应该尽量将API部署在专用域名之下:
3、多数据版本共存(版本):
- 在url链接中标识数据版本:
- https://api.xxxx.com/v1
- https://api.xxxx.com/v2
- url链接中的v1、v2就是不用数据版本的体现(只有在一种数据资源有多版本情况下)。
4、数据即是资源(路径):
- 接口一般都是完成前后台数据的交互,交互的数据我们称之为资源。
- 一般来说,数据库中的表都是同种记录的"集合"(collection),所以API中的名词也应该使用复数。
- https://api.xxxx.com/users
- https://api.xxxx.com/books
- 在RESTful架构中,每个网址代表一种资源(resource),所以网址中不能有动词,只能有名词,而且所用的名词往往与数据库的表格名对应。
- 特殊的接口可以出现动词,因为这些接口一般没有一个明确的资源,或动词就是接口的核心内容:
- https://api.xxxx.com/login
- https://api.xxxx.com/resgister
- 一般来说,数据库中的表都是同种记录的"集合"(collection),所以API中的名词也应该使用复数。
5、资源操作由请求方式决定(HTTP动词):
- 操作资源一般都会涉及到增删改查,对于资源的具体操作类型,由HTTP动词表示。
常用的HTTP动词有下面五个(括号里是对应的SQL命令):
- GET(SELECT):从服务器取出资源(一项或多项)。
- https://api.xxxx.com/books - get请求:获取所有书
- https://api.xxxx.com/books/1 - get请求:获取主键为1的书
- POST(CREATE):在服务器新建一个资源。
- https://api.xxxx.com/books - post请求:新增一本书
- PUT(UPDATE):在服务器更新资源(客户端提供改变后的完整资源)。
- https://api.xxxx.com/books/1 - put请求:整体修改主键为1的书
- PATCH(UPDATE):在服务器更新资源(客户端提供改变的属性)。
- https://api.xxxx.com/books/1 - pathc请求:局部修改主键为1的书
- DELETE(DELETE):从服务器删除资源。
- https://api.xxxx.com/books/1 - delete请求:删除主键为1的书
还有两个不常用的HTTP动词:
- HEAD:获取资源的元数据。
- OPTIONS:获取信息,关于资源的哪些属性是客户端可以改变的。
5、过滤信息
- 如果记录数量很多,服务器不可能都将它们返回给用户。API应该提供参数,过滤返回结果。常见的参数:
- ?limit=10:指定返回记录的数量
- ?offset=10:指定返回记录的开始位置。
- ?page=2&per_page=100:指定第几页,以及每页的记录数。
- ?sortby=name&order=asc:指定返回结果按照哪个属性排序,以及排序顺序。
- ?animal_type_id=1:指定筛选条件。
- 参数的设计允许存在冗余,即允许API路径和URL参数偶尔有重复。比如,GET /zoo/ID/animals 与 GET /animals?zoo_id=ID 的含义是相同的。
2.2 响应状态码
-
正常响应(响应状态码2xx):
- 200:常规请求
- 201:创建成功
- 204:用户删除数据成功。
-
重定向响应(响应状态码3xx):
- 301:永久重定向
- 302:临时重定向
-
客户端异常(响应状态码4xx):
- 400:用户发出的请求有错误,服务器没有进行新建或修改数据的操作,该操作是幂等的。
- 403:请求无权限
- 404:请求路径不存在
- 405:请求方法不存在
-
服务器异常(响应状态码5xx):
- 500:服务器异常
详细可见:https://www.ruanyifeng.com/blog/2014/05/restful_api.html
2.3 响应结果
-
响应数据要有状态码、状态信息以及数据本身。
{ "status": 0, "msg": "ok", "results": [ { "name": "百年孤独", "price": 33.60, }, ... ] }
-
需要url请求的资源。
{ "status": 0, "msg": "ok", "results": [ { "name": "百年孤独", "price": 33.60, "img": "https://image.xxxx.com/bngd.png" }, ... ] }
-
针对不同操作,服务器向用户返回的结果应该符合以下规范:
- GET /collection:返回资源对象的列表(数组)
- GET /collection/resource:返回单个资源对象
- POST /collection:返回新生成的资源对象
- PUT /collection/resource:返回完整的资源对象
- PATCH /collection/resource:返回完整的资源对象
- DELETE /collection/resource:返回一个空文档
【部分内容参考自】
- 什么是接口测试?为什么要做接口测试?:https://www.cnblogs.com/zoraliu66/p/6743126.html
- 理解RESTful架构:http://www.ruanyifeng.com/blog/2011/09/restful.html
- RESTful API 设计指南:https://www.ruanyifeng.com/blog/2014/05/restful_api.html
- Restful 接口规范:https://www.cnblogs.com/17vv/p/11890532.html
以上是关于自动化测试接口测试之RESTful接口的主要内容,如果未能解决你的问题,请参考以下文章
(转)接口自动化测试 – Java+TestNG 测试 Restful Web Service
零成本实现接口自动化测试 – Java+TestNG 测试Restful service
零成本实现接口自动化测试 – Java+TestNG 测试Restful service
Python接口自动化测试工具(Pytest+Allure+jsonpath+xlrd+excel支持Restful接口规范)建议收藏