什么是接口
接口一般来说有两种:一种是程序内部的接口;一种是系统对外的接口。
什么是接口
Webservice接口和http api接口是最常用的两种接口
Webservice接口是走soap协议通过http传输,请求报文和返回报文都是xml格式的,通过工具(如:soapui)进行调用和测试
Http api接口是走http协议,通过路径来区分调用的方法,请求报文都是key-value形式的,返回报文一般都是json串,常用的请求方式有:get、post
什么是接口测试
接口测试是对系统组件间接口的测试,它属于功能测试。其实接口测试和普通功能测试的区别就在于:功能测试是在页面上点点点,在页面上输入值,提交数据看结果,而接口测试没有页面,通过接口规范文档上的调用地址、请求参数,拼接报文,然后发送请求,检查返回结果
咱们测的都是程序对外部的接口,接口其实就是各种操作数据库。通常软件由前端(客户端)及后端(服务端、server端)组成,前端主要是负责展示效果,后端负责业务逻辑处理。比如付款操作时,前端进行付款可成功,其实后端也同样需要校验才能付款金额是否正确,界面操作只能判断前端(客户端)是否校验,只有对前后端之间的该接口进行测试才能判断后端(服务端、server端)是否也进行检验
接口测试的必要性
一、可以发现很多在页面上操作发现不了的bug
二、检查系统的异常处理能力
三、 检查系统的安全性、稳定性
四、前端随便变,接口测好了,后端不用变
接口测试的流程
一、需求评审,熟悉业务和需求
二、开发提供接口文档
三、编写接口测试用例
四、用例评审
五、提测后开始测试
六、提交测试报告
接口规范文档 是接口测试的重要依据。接口文档至少包括:
1、接口说明
2、调用url
3、请求方法(getpost)
4、请求参数、参数类型、请求参数说明
5、返回参数说明
如何测接口-Http 接口
有了接口文档后,可根据接口文档来拼接参数调用接口。接口请求报文拼接有:
1、最简单的一种是:url?param=value¶m2=value 问题前面是请求url,后面是请求的参数名和参数值,多个参数用&连接
如:http://httpbin.org/get?key2=value2&key1=value1
2、还有一种就是:入参是json串格式的。这种格式不能把参数直接连在url中,需要写在请求的body里面,可借助工具Postman
常用的请求有:GET和POST。GET请求通常用来接收数据,POST请求通常用来发送数据;测GET请求可直接用浏览器就能发请求,不需要借助工具,GET请求 没有请求体(body),只有请求头(header),请求的参数只能写在url里面或者cookie里面;POST请求既有请求头(header)也有请求体(body),请求参数 放在请求体(body)里面,从而需要借助工具进行发送请求
发送请求后,Http会返回一个状态码表示是否请求成功,状态码有三位,其中开头一位确定了状态类型:
① 2xx: 表示请求发送成功,常见200
② 3xx: 代表重定向,要完成请求必须进行更进一步的操作,或把请求重定向到别的地方了,最常见的是302
③ 4xx: 客户端错误,请求有语法错误或请求无法实现,常见的有:
400代表客户端发送的请求有语法错误,不能被服务器所理解;
401代表访问的页面没有授权;
403服务器收到请求,但是拒绝提供服务,比如没有权限访问这个页面;
404请求的资源不存在,比如输入错的URL没有这个页面。
④ 5xx: 代表服务器有异常,常见的有:
500代表服务器内部异常;
503服务器当前不能处理客户端的请求,一段时间后可能恢复正常;
504代表服务器端超时,没返回结果。
如何测接口-Webservice 接口
不需要拼接报文,直接把webservice地址或wsdl文件(这两个都由开发人员提供)直接在soapui导入,就可以看到所有接口及报文,直接填写参数发送请求,查看返回结果就可以了
接口测试用例设计
1、通过性验证:首先保证测试的接口是可以用的,按文档正常传入,查看是否可以返回正确的结果
2、参数组合: 按接口文档中对参数的要求进行有目的的组合。比如有一个收藏接口,参数有:id,flag(值为1时为收藏,值为0时为取消收藏),则需要对flag的两种情况分别与id组合测试
3、接口安全:
① 绕过正常值验证
② 绕过身份授权验证
③ 参数是否加密,加密规则是否容易破解
④ 密码安全规则,密码的复杂程度校验
4、异常验证:不按照接口文档上的要求输传参,来验证接口对异常情况的校验。主要检查点有三方面:必传非必传、参数类型、入参长度
5、根据业务逻辑进行设计测试用例,比如注册接口,短信验证码30分钟有效;做任务接口,需要完成初级任务才能做中级任务.....
接口测试用例模板
进行接口测试,也需要编写测试用例,因而就有接口测试模板了。模板其实没有定性,可根据公司项目情况增减相关描述,公司统一模板就好。参考模板中体现字段有:
1、项目 是哪个项目的
2、模块 测试接口是属于哪个模块的
3、用例id
4、接口名称
5、用例标题 这个测试用例功能描述
6、请求方式 GET/POST
7、请求url URL地址
8、请求参数
9、前置条件 执行当前请求依赖的条件,不满足就不能正确执行
10、结果验证 预期结果
11、请求报文
12、返回报文
13、测试结果 通过/失败
14、测试人员