一、问题引入
后端开发人员常常会问,接口测试到底测试什么?如何进行?以下是对接口测试的简要概述:
测试什么?
如何进行?
目前的后端调用主要是基于http协议的接口,测试方法主要有两种:
使用工具模拟请求的发送与接收。常用的工具包括postman、JMeter等; 使用代码模拟请求的发送与接收。例如:Java自带的Webb、RestTemplete、HttpClient或其他;对于GET请求,可以通过直接在浏览器中输入URL进行测试。
二、接口测试
什么是接口?
举例:
1. 12306是一个网站,所有的数据都存储在12306上。12306提供一整套接口,通过调用这些接口我们可以获取到里面的数据。比如:在携程/艺龙等第三方平台上购买票,实际就是通过调用12306提供的接口来获取库存等信息;
2.windows是一个封装好的系统,理论上用户无法在Windows中进行任何操作,但Windows提供了一整套接口,通过调用这些接口我们可以操作Windows执行某些行为;
通过接口,我们可以对一个封装好的整体进行操作,包括获取和操作数据。类库就是提供的一整套接口,类库提供的各个方法/函数等类成员就是各个接口,平常编写的类也算提供了接口,类是整体,类的成员函数就是接口。
什么是接口测试?
模拟客户端向服务器发送报文请求,服务器接收请求报文后对相应的报文进行处理并向客户端返回应答,客户端接收应答的过程。
两大类:
1.代码内部接口调用,代码A与代码B在组合时,必然需要定义一些名称以及参数、类型,这种在测试中一般划分在白盒测试中,对内部逻辑进行测试,目前未接触。
2.系统与系统之间,通过网络数据的传递进行交互,这种在测试中一般划分在黑盒测试中,也就是看不到代码,但可以通过各种手段将网络数据发送到接口从而得到接口的响应信息,达到测试的目标。
这里主要阐述第二种黑盒层面上的功能测试,主要是服务端接口。
【测试思路】
1.单接口:在业务场景上没有上下游依赖,一个接口的功能直接是一个测试模块。这种情况下,可以直接测试该接口,从构造参数->发请求->校验结果。
2.多接口:接口之间有数据流转,共同形成一个完整的业务流程,比如:一个完成交易流程,包含下单->支付->退款等。针对这类型的接口,可以考虑从业务场景上去覆盖(熟悉业务是自动化的基础)。
【测试数据】
1.手动构造数据
如果是只测试一次的接口,可以使用手动造数据,比如:测试下单接口时需要测试deal,可以直接手动上单,测试的时候使用到什么数据就写什么数据。
2.调用其他API
可以直接通过调用其他API的方式准备测试数据,比如:测试退款、赔付接口时需要订单号,可以直接调用创建订单接口构造出想要的订单类型。
3.自动化工具构造数据
【测试工具】
可以选择Postman、Jmeter等工具。
三、接口测试自动化
测试步骤
实现方法
使用JAVA+maven+TestNG进行服务端的自动化接口测试
1.驱动测试:可以使用java、或者python、其他语言。
2.管理测试数据:包括测试用例的管理,数据录入、测试结果显示等,可以使用CSV、excel、xml、Text纯文本格式。
CSV格式:常用于入参数较简单。在真正的测试执行时,每次会读取一条CSV记录,每个字段作为一个参数,传给@Test方法。文件格式如下:代码语言:JavaScript代码运行次数:0运行复制“`javascript Num,Price,PayItemNum,Voucher,NeedVisitor,FeeCharge #可以加其他参数3,10000,3,5000,0,30003,10000,3,5000,0,30003,10000,3,5000,0,30001,10000,1,5000,0,3000
<pre class="brush:php;toolbar:false"> Text格式:可用于处理参数是json的接口。K- V结构,可以将所有接口的入参数都存进去,然后读取相应的key来获取value,并可以修改value值。文件格式如下:代码语言:javascript代码运行次数:0<svg fill="none" height="16" viewbox="0 0 16 16" width="16" xmlns="http://www.w3.org/2000/svg"><path d="M6.66666 10.9999L10.6667 7.99992L6.66666 4.99992V10.9999ZM7.99999 1.33325C4.31999 1.33325 1.33333 4.31992 1.33333 7.99992C1.33333 11.6799 4.31999 14.6666 7.99999 14.6666C11.68 14.6666 14.6667 11.6799 14.6667 7.99992C14.6667 4.31992 11.68 1.33325 7.99999 1.33325ZM7.99999 13.3333C5.05999 13.3333 2.66666 10.9399 2.66666 7.99992C2.66666 5.05992 5.05999 2.66659 7.99999 2.66659C10.94 2.66659 13.3333 5.05992 13.3333 7.99992C13.3333 10.9399 10.94 13.3333 7.99999 13.3333Z" fill="currentcolor"></path></svg>运行<svg fill="none" height="16" viewbox="0 0 16 16" width="16" xmlns="http://www.w3.org/2000/svg"><path clip-rule="evenodd" d="M4.5 15.5V3.5H14.5V15.5H4.5ZM12.5 5.5H6.5V13.5H12.5V5.5ZM9.5 2.5H3.5V12.5H1.5V0.5H11.5V2.5H9.5Z" fill="currentcolor" fill-rule="evenodd"></path></svg>复制```javascript "host": "","port": "","headers": {},"basic": { "path": "", "method": "post", "data": { "subTitle":"", "joinType": 1, "ratioModifiable": 0, "departCityId": 50, }
3.模拟发送一个请求
举例:Webb发送
代码语言:javascript代码运行次数:0运行复制“`javascript //POST请求String req = “testurl”String reqBody = JsonUtils.object2Json(Request, false); //上方的测试数据Webb webb = Webb.create(); JSONObject result = webb.post(req).useCaches(false).body(reqBody).ensureSuccess().asJsonObject().getBody();//发送一个post请求//GET请求Webb webb = Webb.create();JSONObject result = webb.get(“testurl”) .header(“date”,getGMT(date)) .header(“Content-Type”,”application/json;charset=utf-8″)//发送一个get请求,有头部信 .ensureSuccess().asJsonObject().getBody();
<pre class="brush:php;toolbar:false"> 4.预期结果与实际结果进行对比 <p>代码语言:javascript代码运行次数:0<svg fill="none" height="16" viewbox="0 0 16 16" width="16" xmlns="<a href="https://www.php.cn/link/c9041cfd2a40932691855abd98fd219a">http://www.w3.org/2000/svg"><path</a> d="M6.66666 10.9999L10.6667 7.99992L6.66666 4.99992V10.9999ZM7.99999 1.33325C4.31999 1.33325 1.33333 4.31992 1.33333 7.99992C1.33333 11.6799 4.31999 14.6666 7.99999 14.6666C11.68 14.6666 14.6667 11.6799 14.6667 7.99992C14.6667 4.31992 11.68 1.33325 7.99999 1.33325ZM7.99999 13.3333C5.05999 13.3333 2.66666 10.9399 2.66666 7.99992C2.66666 5.05992 5.05999 2.66659 7.99999 2.66659C10.94 2.66659 13.3333 5.05992 13.3333 7.99992C13.3333 10.9399 10.94 13.3333 7.99999 13.3333Z" fill="currentcolor"></path></svg>运行<svg fill="none" height="16" viewbox="0 0 16 16" width="16" xmlns="<a href="https://www.php.cn/link/c9041cfd2a40932691855abd98fd219a">http://www.w3.org/2000/svg"><path</a> clip-rule="evenodd" d="M4.5 15.5V3.5H14.5V15.5H4.5ZM12.5 5.5H6.5V13.5H12.5V5.5ZM9.5 2.5H3.5V12.5H1.5V0.5H11.5V2.5H9.5Z" fill="currentcolor" fill-rule="evenodd"></path></svg>复制```javascript // 断言,判断用例执行成功或失败(实际值,预期值)Assert.assertEquals(Actual value, expected value
5.可生成简单的测试报告
6.可选择集成jenkins,完成持续构建
结语:本文主要分享了如何进行接口测试,包括接口自动化,欢迎大家一起交流~万水千山总是情,点个“在看” 行不行!!!