草帽路飞UU 发表于 2022-7-27 15:46:10

史上最详细的接口测试,一篇学会接口

本帖最后由 草帽路飞UU 于 2022-8-10 16:29 编辑

大多数人对于接口测试都觉得是一种高大上的测试,觉得学会接口测试就可以从小白测试员,变成了高级测试员,但其实接口测试只是测试的基础内容

什么是接口
接口泛指实体把自己提供给外界的一种抽象化物(可以为另一实体),用以由内部操作分离出外部沟通方法,使其能被内部修改而不影响外界其他实体与其交互的方式。

人类与电脑等信息机器或人类与程序之间的接口称为用户界面。电脑等信息机器硬件组件间的接口叫硬件接口。电脑等信息机器软件组件间的接口叫软件接口。
在计算机中,接口是计算机系统中两个独立的部件进行信息交换的共享边界。这种交换可以发生在计算机软、硬件,外部设备或进行操作的人之间,也可以是它们的结合。

接口测试主要用于外部系统与系统之间以及内部各个子系统之间的交互点,定义特定的交互点,然后通过这些交互点来,通过一些特殊的规则也就是协议,来进行数据之间的交互。

你要买一俩车,你不用知道车在工厂里面需要什么原理,怎么构造模型,怎么制作,你只要到能找到窗口,给出你要买车的信号,窗口返回给你一个车的相关信息的信号。接口也是这样,你不用理解程序内部是怎么样的,你只要理解你给出请求从而得到的请求是正确的,即你发出A的数据,必须得到B的返回,而不是C。
为什么要做接口测试
在了解为什么要接口测试之前,我们需要了解以下几点:1.越底层,越稳定。2.越底层,越高效。3.越底层,越低成本。4.越底层,越难实施。
接口测试测试系统组件间接口的一种测试。接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点。测试的重点是要检查数据的交换,传递和控制管理过程,以及系统间的相互逻辑依赖关系等。就如同之前的买车时,我们需要确定你给出的是买车信号,返回的是相关车辆信息,而不是买房信息。
接口测试的模板

请求协议:

http — 普通的http请求,默认端口为80
https — 加密的http请求,传输数据更加安全,默认端口为443
ftp — 文件传输协议,主要用来传输文件,默认端口为21
请求IP:就是指提供接口的系统所部署的服务器地址,可以是直接的IP地址,也可以是域名

请求端口:如果不填端口,都是默认端口,否则需要填写端口号

接口路径:指系统提供的接口在什么位置

接口参数:参数在接口路径后,用“?”来表示路径地址完了,剩下的都是参数了,用“&”来区分参数个数,

http中的常用请求方式
这个请求方式,作为一位测试人员,不需要担心不知道该项目请求方式是什么,一般情况是在开发文档中有具体的说明请求方式是什么,不过我们有时候需要有自我的判断这个地方用什么接口合适,比如输入密码的地方一定要用post方法,绝对不能用get的方法。

序号 方法 描述
      1      GET      请求指定的页面信息,并返回实体主体。
      2      HEAD      类似于get请求,只不过返回的响应中没有具体的内容,用于获取报头
      3      POST      向指定资源提交数据进行处理请求(例如提交表单或者上传文件)。数据被包含在请求体中。POST请求可能会导致新的资源的建立和/或已有资源的修改。
      4      PUT      从客户端向服务器传送的数据取代指定的文档的内容。
      5      DELETE      请求服务器删除指定的页面。
      6      CONNECT      HTTP/1.1协议中预留给能够将连接改为管道方式的代理服务器。
      7      OPTIONS      允许客户端查看服务器的性能。
      8      TRACE      回显服务器收到的请求,主要用于测试或诊断。
      9      PATCH      实体中包含一个表,表中说明与该URI所表示的原内容的区别。
      10      MOVE      请求服务器将指定的页面移至另一个网络地址。
      11      COPY      请求服务器将指定的页面拷贝至另一个网络地址。
      12      LINK      请求服务器建立链接关系。
      13      UNLINK      断开链接关系。
      14      WRAPPED      允许客户端发送经过封装的请求。
      15      Extension-mothed      在不改动协议的前提下,可增加另外的方法。



接口测试的重点
目的:测试接口的正确性和稳定性;

原理:模拟客户端向服务器发送请求报文,服务器接收请求报文后对相应的报文做处理并向客户端返回应答,客户端接收应答的过程;

重点:检查数据的交换,传递和控制管理过程,还包括处理的次数;

核心:持续集成是接口测试的核心;

优点:为高复杂性的平台带来高效的缺陷监测和质量监督能力,平台越复杂,系统越庞大,接口测试的效果越明显(提高测试效率,提升用户体验,降低研发成本);

用例设计重点:通常情况下主要测试最外层的两类接口:数据进入系统接口(调用外部系统的参数为本系统使用)和数据流出系统接口(验证系统处理后的数据是否正常);

接口测试质量评估标准

业务功能覆盖是否完整
业务规则覆盖是否完整
参数验证是否达到要求(边界、业务规则)
接口异常场景覆盖是否完整
接口覆盖率是否达到要求
代码覆盖率是否达到要求
性能指标是否满足要求
安全指标是否满足要求
接口模拟测试

接口:https://api.apiopen.top/getWangYiNews

请求类型:POST

在线测试:https://www.sojson.com/httpRequest/

软件测试:postman、jemter(这两个后期出专门的使用教程)

1、输入相应的数据


2、获取的数据进行分析这一块是表头,一般情况不需要特别记住,只要了解就可以了,注意返回的状态码是否是正确的,有一些时候需要注意加载的时间这一块内容为表主体,也就是我们查看返回的数据是否正确。![在这里插入图片描述](https://img-blog.csdnimg.cn/20210512171300590.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1hzazIxNQ==,size_16,color_FFFFFF,t_70)

草帽路飞UU 发表于 2022-7-27 15:48:40

HTTP状态码列表
状态码        状态码英文名称        中文描述
100        Continue        继续。客户端应继续其请求
101        Switching Protocols        切换协议。服务器根据客户端的请求切换协议。只能切换到更高级的协议,例如,切换到HTTP的新版本协议

200        OK        请求成功。一般用于GET与POST请求
201        Created        已创建。成功请求并创建了新的资源
202        Accepted        已接受。已经接受请求,但未处理完成
203        Non-Authoritative Information        非授权信息。请求成功。但返回的meta信息不在原始的服务器,而是一个副本
204        No Content        无内容。服务器成功处理,但未返回内容。在未更新网页的情况下,可确保浏览器继续显示当前文档
205        Reset Content        重置内容。服务器处理成功,用户终端(例如:浏览器)应重置文档视图。可通过此返回码清除浏览器的表单域
206        Partial Content        部分内容。服务器成功处理了部分GET请求

300        Multiple Choices        多种选择。请求的资源可包括多个位置,相应可返回一个资源特征与地址的列表用于用户终端(例如:浏览器)选择
301        Moved Permanently        永久移动。请求的资源已被永久的移动到新URI,返回信息会包括新的URI,浏览器会自动定向到新URI。今后任何新的请求都应使用新的URI代替
302        Found        临时移动。与301类似。但资源只是临时被移动。客户端应继续使用原有URI
303        See Other        查看其它地址。与301类似。使用GET和POST请求查看
304        Not Modified        未修改。所请求的资源未修改,服务器返回此状态码时,不会返回任何资源。客户端通常会缓存访问过的资源,通过提供一个头信息指出客户端希望只返回在指定日期之后修改的资源
305        Use Proxy        使用代理。所请求的资源必须通过代理访问
306        Unused        已经被废弃的HTTP状态码
307        Temporary Redirect        临时重定向。与302类似。使用GET请求重定向

400        Bad Request        客户端请求的语法错误,服务器无法理解
401        Unauthorized        请求要求用户的身份认证
402        Payment Required        保留,将来使用
403        Forbidden        服务器理解请求客户端的请求,但是拒绝执行此请求
404        Not Found        服务器无法根据客户端的请求找到资源(网页)。通过此代码,网站设计人员可设置"您所请求的资源无法找到"的个性页面
405        Method Not Allowed        客户端请求中的方法被禁止
406        Not Acceptable        服务器无法根据客户端请求的内容特性完成请求
407        Proxy Authentication Required        请求要求代理的身份认证,与401类似,但请求者应当使用代理进行授权
408        Request Time-out        服务器等待客户端发送的请求时间过长,超时
409        Conflict        服务器完成客户端的 PUT 请求时可能返回此代码,服务器处理请求时发生了冲突
410        Gone        客户端请求的资源已经不存在。410不同于404,如果资源以前有现在被永久删除了可使用410代码,网站设计人员可通过301代码指定资源的新位置
411        Length Required        服务器无法处理客户端发送的不带Content-Length的请求信息
412        Precondition Failed        客户端请求信息的先决条件错误
413        Request Entity Too Large        由于请求的实体过大,服务器无法处理,因此拒绝请求。为防止客户端的连续请求,服务器可能会关闭连接。如果只是服务器暂时无法处理,则会包含一个Retry-After的响应信息


草帽路飞UU 发表于 2022-7-27 15:49:33

本帖最后由 草帽路飞UU 于 2022-8-10 16:27 编辑

414      Request-URI Too Large      请求的URI过长(URI通常为网址),服务器无法处理
415      Unsupported Media Type      服务器无法处理请求附带的媒体格式
416      Requested range not satisfiable      客户端请求的范围无效
417      Expectation Failed      服务器无法满足Expect的请求头信息

500      Internal Server Error      服务器内部错误,无法完成请求
501      Not Implemented      服务器不支持请求的功能,无法完成请求
502      Bad Gateway      作为网关或者代理工作的服务器尝试执行请求时,从远程服务器接收到了一个无效的响应
503      Service Unavailable      由于超载或系统维护,服务器暂时的无法处理客户端的请求。延时的长度可包含在服务器的Retry-After头信息中
504      Gateway Time-out      充当网关或代理的服务器,未及时从远端服务器获取请求
505      HTTP Version not supported      服务器不支持请
如果对软件测试、接口测试、自动化测试、技术同行、持续集成、面试经验交流。感兴趣可以进到644956177,群内会有不定期的分享测试资料。
如果文章对你有帮助,麻烦伸出发财小手点个赞,感谢您的支持,你的点赞是我持续更新的动力。

上面这些是我的收集和整理,这些资料,对于【软件测试】的朋友来说应该是最全面的仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你

页: [1]
查看完整版本: 史上最详细的接口测试,一篇学会接口