Api接口测试总是似懂非懂,只因这个原理没搞清楚
前言
掌握了http协议,就掌握了接口测试
笔者在网络上看过不少接口测试教程,一上来就开始讲怎么操作工具,而不告诉读者为什么要这么操作。读者可能照猫画虎成功了,也可能操作失败了但不知为何出错。
因此,本文作为接口测试的入门第一课首先会给大家了解到执行接口测试每一步操作的目的和原理,由此大家才能从理论到实践上掌握接口测试,并且熟练之后有自己的创造性发挥。
本文所用的接口测试工具为Apifox,请大家在往下读之前先安装注册好工具。
Apifox官方下载地址:http://www.apifox.cn
目录
接口测试测什么
接口测试的对象:服务器接口
服务器接口与前端通信的方式:http协议
Apifox接口测试原理
用Apifox构建第一个接口请求
正文
接口测试测什么
接口测试主要是测试系统 组件间接口的一种测试,主要用于测试服务器与前端(web浏览器,APP)之间的数据交互接口。 测试的重点是要检查接口参数传递的正确性,接口功能实现的正确性,输出结果的正确性,以及对各种异常情况的容错处理的完整性和合理性。
前言
掌握了http协议,就掌握了接口测试
笔者在网络上看过不少接口测试教程,一上来就开始讲怎么操作工具,而不告诉读者下载地址:http://www.apifox.cn
x 由引文对接口测试的定义可得,接口测试的对象是服务器接口,接口测试的内容包括:接口参数检验,接口功能实现是否正确,接口异常情况容错处理。
接口测试的内容是《Apifox接口测试》系列教程后面的内容,本文主要讲解服务器接口,前端如何通过http协议与服务器通信,Apifox等接口测试工具如何实现接口测试。
接口测试的对象:服务器接口
API指的是一组预先定义好的函数,来让系统或外部的其他组件可以执行它内部实现的功能,但又无须访问源代码或者理解其内部逻辑。
在需求开发过程中,前后端分离开发,两端的研发人员会共同定义好接口,编写接口文档,此后的开发过程中需要遵循这份协议文档。
因此接口测试也是一种黑盒测试,测试人员需要根据接口文档来对服务器Api进行测试,来检测约定的功能是否正确实现,是否有对异常情况做容错处理。
而接口文档的编写是依据前后端数据传输的协议——Http协议进行的。
要会用接口文档,首先先理解http协议。
服务器接口与前端通信的方式:http协议
服务器和前端通过互相发送http报文完成数据交互。本小节将介绍如何创建http报文,以及如何理解报文的每一个部分,了解完就可以掌握接口测试的基础内容。
http报文的三个组成部分 http报文是一个格式化数据块。报文类型包括客户端请求,服务器响应。它们由3个部分组成:
起始行(start line) 对报文进行描述
首部块(header) 包含属性 Content-Type: Content-Length:
主体(body) 包含文本或二进制数据,可以为空
请求报文的格式
<method><request-URL><version>
<headers>
<entity-body>
响应报文的格式
<version><status><reason-phrase>
<headers>
<entity-body>
各个字段的含义如下:
方法(method):前端希望对服务器执行的操作,包含get,post,put,delete等方法;
方法 | 功能 |
---|---|
GET | 从服务器获取数据 |
POST | 向服务器发送要处理的数据 |
HEAD | 只从服务器获取文档的首部 |
DELETE | 从服务器上删除数据 |
PUT | 向服务器提交数据 |
请求url(request-URL):所请求资源路径,通过它可找到资源放置的位置。 格式类似于:https://www.apifox.cn/help/app/contact-us/
版本(version):报文所使用的http版本,格式类似于:HTTP/1.0
首部(headers):可以有0个或多个首部,常见的首部如下:
实体主体(entity-body):包含一个数据块,支持多种数据格式,如html页面,图片,视频,源代码等等。
状态码(status-code):描述请求结果,成功或者失败。
原因短语(reason-phrase):原因短语是状态码的可读版本,只对人类有意义。
这些字段初学者会觉得非常抽象难以理解和记忆,但当后面接触到api文档和用apifox做接口测试的时候,就会顿悟——api文档里的参数和方法,url的含义和接口测试界面每个空格要填什么,返回值代表什么含义。
请耐心继续往下读。
读懂API文档
对于测试人员,准备接口测试所需要的文档有产品需求文档+API文档。
需求文档用于梳理接口为何这么设计、是否合理;
针对单个接口,接口文档用于获取:接口描述,请求说明,返回说明。
以百度开放API,文字识别接口为例:我们想要使用它的文本识别功能,需要去调用它的接口,那么需要了解发起这个文本识别接口请求,每个字段需要填什么内容。
*注:Apifox的ApiHub中,收集了大量开放的API,初学者可选取某个api深入了解接口文档,或作为接口测试的练习物料,注意有些接口需要先获取使用权限。
Api Hub收集的开放API
Apifox接口测试原理
对于服务器来说,Apifox也是一个前端,只不过其他前端的接口请求由研发人员在代码里封装好,在特定条件下被触发发起请求,而Apifox中,接口请求由用户手动封装,手动发起。
Apifox界面
看完Apifox接口测试的界面,读者想必能发现,整个界面就是让读者手动构建出一个http请求出来,上两节我们讲的抽象的http协议终于落了地。
因此一个最基础的http接口测试所需要做的步骤就是手动填写完成并发出一个http请求,校验参数。
step1.选择请求方法->填写请求url->填写url参数->填写body参数和header参数(如果有)
step2.手动发送请求
step3.查看返回参数是否正常,是否符合接口文档的约定
用Apifox构建你第一个测试请求
在铺垫完上述那么多理论基础之后,大家终于可以开始上手使用apifox来做接口测试了。
练习1:用get请求获取html页面
step1:在apifox的新建接口tab输入“http://www.baidu.com”,请求方法选择GET,header参数,url参数,body参数均为空,接着点击send按钮。
step2:查看返回值,可以看到请求回来的数据是一个html页面,即百度首页,我们点击‘preview’按钮,可以看到一个完整的页面显示出来
点击preview tab
练习2:获取百度开放API的acess_token,即获得使用api的授权
step1:查看百度开放api获取acess_token的接口文档,获取请求方法和请求参数
step2:根据接口文档描述的,在apifox接口测试界面选择post方法,在params里填写3个请求参数, (client_id和client_secret需要创建应用后才能获得,没有可以先去创建)
填写请求参数
step3:点击下方实际请求tab,可以看到apifox实际发出的接口请求形式 如下:
step4:查看返回参数可看到返回了我们需要的acess_token 字段:
练习完成。大家可以利用自己公司内部的接口文档/外部开放api继续进行练习巩固。
复习题
1.写出http协议请求报文和相应报文的格式,并说明每个字段的含义。
2.api文档有哪几部分组成,在接口测试中分别发挥什么作用
3.复述用Apifox做简单接口测试的步骤。
Api接口测试总是似懂非懂,只因这个原理没搞清楚的更多相关文章
- 初步探究Android App API接口测试--实战
一.Android App API接口测试 1.如何学好Android App API接口测试 postman可以用来实现API接口自动化测试,但是也有弊端,无法实现接口测试数据的参数化,为了达到接口 ...
- 实战Rest API接口测试
一.Android App API接口测试 1.如何学好Android App API接口测试 postman可以用来实现API接口自动化测试,但是也有弊端,无法实现接口测试数据的参数化,为了达到接口 ...
- HTTP API接口测试利器PostMan介绍
一.什么是API接口测试? API接口有多种,个人将其划分为三类.第一种是函数级别的,测试需要对接口的各个参数进行测试,如:Int getResult(String key, String ID, I ...
- api接口测试工具和接口文档管理工具
api接口测试工具和接口文档管理工具 1.postman(https://www.getpostman.com) Postman 是一个很强大的 API调试.Http请求的工具.她可是允许用户发送任何 ...
- PDF怎么旋转页面,只需几步轻松搞定!
有时候我们下载一个PDF文件里面有页面是旋转的情况,用手机看的时候可以把手机旋转过来看,那么用电脑的时候总不可能也转过来看吧,笔记本是可以的台式的是不行的,这个时候我们就需要把PDF文件中旋转的页面转 ...
- python+requests+unittest API接口测试
黑熊再网上查找了下接口测试相关的资料,大都重点是以数据驱动的形式,见用例维护在文本或表格中,而没有说明怎么样去生成想要的用例, 问题: 测试接口时,比如参数a,b,c,我要先测a参数,有(不传,为空, ...
- 使用JMeter3.0实战之分布式并发测试以及web API接口测试
简介: 该文档是以Apche JMeter-3.0为例进行编写的,通过网上的学习资料和官方文档的说明手册学习后,进行项目操作实践,将测试的过程记录下提供给大家学习. 本博文的内容主要是进行配置JMet ...
- REST API接口测试
背景介绍 为什么要做借口测试? 很多系统关联都是基于接口来实现的,接口测试可以将复杂的系统关联进行简化. 接口功能比较单一,能够比较好的进行测试覆盖,也相对容易实现自动化持续集成. 接口相当于界面功能 ...
- Web Api 接口测试工具:WebApiTestClient
前言:这两天在整WebApi的服务,由于调用方是Android客户端,Android开发人员也不懂C#语法,API里面的接口也不能直接给他们看,没办法,只有整个详细一点的文档呗.由于接口个数有点多,每 ...
随机推荐
- OC-引用计数器,内存管理,野指针
总结 全局断点 →-->+-->Add Exception Breakpoint 开启僵尸监听 打开Edit scheme -->Diagnostics-->Enable Zo ...
- 关系型数据库和非关系型数据库区别、oracle与mysql的区别
一.关系型数据库 关系型数据库,是指采用了关系模型来组织数据的数据库. 关系模型是在1970年由IBM的研究员E.F.Codd博士首先提出的,在之后的几十年中,关系模型的概念得到了充分的发展并逐 ...
- @Deprecated注解功能
@Deprecated注解功能 标记不建议使用的方法,但是仍然可以用 当方法有更好的方法替换时,但是此方法还有使用时可以使用该注解
- 阿里云发布CloudOps白皮书,ECS自动化运维套件新升级
12月10 日,2021云上架构与运维峰会上,阿里云发布业界首部<云上自动化运维白皮书>(简称CloudOps白皮书),并在其中提出了CloudOps成熟度模型.同时,阿里云还宣布了ECS ...
- 《手把手教你》系列技巧篇(五十一)-java+ selenium自动化测试-字符串操作-下篇(详解教程)
1.简介 自动化测试中进行断言的时候,我们可能经常遇到的场景.从一个字符串中找出一组数字或者其中的某些关键字,而不是将这一串字符串作为结果进行断言.这个时候就需要我们对字符串进行操作,宏哥这里介绍两种 ...
- 【antd】form表单默认值设置
问题: 在antd的form表单的api里面有个"initialValues"可以设置默认值.但是表单没有更新 <Form name="test" for ...
- CF60A Where Are My Flakes? 题解
Content 有人发现他的麦片不见了,原来是室友把它藏在了 \(n\) 个盒子中的一个,另外还有 \(m\) 个提示,有两种: \(\texttt{To the left of }x\):麦片在第 ...
- SP8374 PARKET1 - PARKET 题解
Content 有一个 \(l\times w\) 大小的网格,其四周均被染成了红色,其余部分是棕色,已知红色网格与棕色网格的数量,求 \(l\) 与 \(w\) 的值. Solution 接下来给各 ...
- 【嵌入式AI】全志 XR806 OpenHarmony 鸿蒙系统固件烧录
欢迎关注我的公众号 [极智视界],回复001获取Google编程规范 O_o >_< o_O O_o ~_~ o_O 大家好,我是极智视界,本教程详细记录了 ...
- java 多线程:线程安全问题synchronized关键字解决
背景: 多个线程同时修改一个变量时,有概率导致两次修改其中某些次被覆盖. 例如:如下案例一个变量值为3,三个线程同时对其-1,如果按顺序执行,每次减完的结果应该是2,1,0.但实际运行中有可能变为0, ...