如何做接口测试?

2022-04-26 13:21:09 浏览数 (1)

你好,我是小牛。

今天来聊聊接口测试,现在是2020年了,打开招聘网站随便点开一个招聘帖子,几乎都可以看到岗位JD要求写着有接口测试经验优先。其重要性可见一斑!

目前,凡是好一点稍具规模的公司哪怕是大厂外包也几乎都要求会接口测试,接口测试已经成为测试工程师的必备基础技能。

但是,还是了解到不少小伙伴所在的公司不做接口测试验证,只做web,app UI层面的校验。甚至,有些公司测试人员数据库都不需要校验,只是纯粹的黑盒测试,俗称点点点。这些公司都不建议久待,短时间做个跳板还行。

接口测试本质上也是功能测试的一种,属于后端服务器测试。但是它的影响范围要远广于web,app层面。原因很简单,因为目前很多公司,服务架构都是多端公用一套接口。

也就是说,和用户直接交互的UI界面,web,app,小程序,H5,它们有可能都是公用一套接口逻辑。后端如果服务器挂了,或者出bug了,这些终端可能都会出问题。所以,做接口测试就非常有必要了!

因为一个软件大部分的校验逻辑都在后端,前端仅仅是用来向用户展示数据以及输入数据。这就可以用来解释为什么公司的CTO一般都是后端程序猿出身。因为,后端远比前端要为复杂,需要考虑架构设计,并发,数据库架构存储......

由于关注小牛的不少读者都是转行过来的,之前完全没IT基础,所以接口理解起来就是个很抽象的东西,不像前端页面那样直观。先来聊聊什么是接口?

简单来说,比如电脑的USB接口,你插上U盘就能拷贝数据,完全不需要关注电脑内部是如何实现的,USB接口就像一个桥梁一样将U盘和电脑连接到了一起,用来传输数据。

具体回到软件上来说,接口其实就是连接前端页面和后端的桥梁,主要就是用来传输数据,数据格式一般是json字符串。前端就包括web,app,H5等等,所以它们可以共用一套接口逻辑,只要定义好入参,暴露给这些终端调用就可以了。

具体到工作中来接口测试是怎么做的呢?以小牛公司为例,公司架构根据业务的不同划分为多个组,每个组都承担相应的业务。然后,这些不同组之间是如何协作交互的呢?没错,就是通过接口之间互相调用!

一般做接口测试时,开发都会提供相应的接口文档,接口文档上面定义了这个接口的url是什么,入参是如何定义的,返回信息是什么.....有同学会问,没有接口文档怎么办?这时候,你可以使用抓包工具进行抓包,然后查看分析即可。

对于公司规模较大,业务比较复杂,关联系统比较多时。拿到一个接口我们应该首先分析这个接口的上下游是谁?发起方是谁?这些接口之间调用逻辑是什么?把这些问题先搞明白再去具体分析这个接口的入参返参之类的。

最后才是测试这个接口,具体接下来怎么测试就要结合公司具体业务来讲了。

说了这么多,接口测试如何重要,那么作为萌新小白应该如何学习接口测试呢?重点来了!

首先,你要学习网络协议知识,因为大部分接口都是基于http协议的,当然还有其它的比如dubbo协议。其次,你需要学习两款测试工具,postman用来调用接口,fiddler用来抓包定位bug,当然,你使用浏览器自带的F12也是可以的。

最后,再说一下,为什么让大家一定要掌握好接口测试?

原因也简单,因为它是你后续深入进阶学习自动化和性能测试的基础。拿接口自动化来说,这是目前公司使用性价比最高的自动化,原因就在于ui自动化成本太高,经常页面大改,可能整个框架就废了,所以很多公司都优先做接口自动化,比较稳定,目前需求最多的。所以找工作,优先学习掌握接口自动化!

再来说说性能测试,目前做的最多的就是接口压测了,至于并发啊,负载啊全部是基于接口的,所以你说一下,接口测试重要不!当然性能测试水比较深,远不止这么简单,难点在于分析性能瓶颈,你需要对服务器以及数据库等做监控,然后分别排查分析,配合开发,找到系统瓶颈在哪里...... 最后总结一下,接口测试不仅仅是你找工作的必备技能,更是你以后深入学习自动化以及性能测试的基础。除非,你想一直做点点点工程师,不然自动化测试和性能测试重要性不言而喻。当然,也不是你想点就一直能点的,非常容易就被淘汰!

0 人点赞