接口测试的关注点:

接口:Http协议接口、Service层接口。

0、接口返回的节点、返回节点对应的值是不是对的;

1、接口有翻页时,页码与页数的异常值测试;

第一页有数据,翻到第二页: 
(1)第二页的数据是否和第一页重复; 
(2)第二页接口有没有报错,页码(一页返回多少个数据)传一个很大的值(一般是100之内,可以改为1000或者String类型的等特殊符号,看接口会不会报错 ); 同样的页数也是。

2、数据库的增删改查,比如一个post接口操作完成后,通过列表页接口看下新的数据是否和刚才的post一致;

比如对一篇帖子发表评论,看一下post请求的接口是否返回了刚刚评论的数据(若没有,是不是缓存、没有写入数据库导致的)

3、每个接口入参的默认值、异常类型、非空校验

(1)这个参数有没有默认值,如果没有默认值是怎么处理的; 
(2) 这个参数必须输入值,若不输值或输入其他值,接口会怎么返回 
(3)接口报错,服务端和客户端都需要做容错

4、接口返回的图片地址能否打开,图片尺寸是否符合需求;

5、当输出参数有联动性时,需要校验返回两参数的实际结果是否都符合需求;

比如一个接口返回汽车的列表,总数的字段 和 列表里的数据是否一致。

6、所有列表页接口必须考虑排序值;

如按时间排序,是否按时间排序

7、所有功能都要考虑兼容旧版本;

接口有改动(增加、减少字段)需要兼容老版本

8、入参支持多个值时,要考虑传的值的个数多的情况下,接口会不会报错;

某一个车型对比的接口,若只需要传9个id,那么当传10个、100个,接口会不会报错,期望接口有个友好的提示

9、输出参数类型。

是int型,不能返回string类型。


接口测试常用工具

1、切换host工具:SwithHosts 
2、抓包: Charles 
3、调试工具:firebug等 
4、辅助测试工具:Postman、HttpRequest、火狐JsonHandle 
5、性能测试工具:LoadRunner、Apache JMeter


常用的HTTP接口知识

HTTP接口

-URL:http[s]://host[:port][abs_path][parameter] 
-Header:头信息,包含了报文的描述信息 
-Method:请求方法 
-Request Parameter:请求参数 
-Response Status:响应状态码(成功是200,失败:400以上500以下是客户端导致的错误如404,500以上是服务端导致的错误)

如调用登录接口

https://xxx.xxx.xxx.xxx:88/login.do?name=quq&pwd=test
  • 1
  • 1

接口使用场景

1、系统与系统之间的调用; 
2、上层服务对下层服务的调用; 
3、系统内,服务与服务之间的调用。

接口测试的case设计 
1、接口参数 
2、接口功能 
3、代码逻辑 
4、异常情况

1、请求参数的必填项和可选项 
2、请求参数的合法输入和非法输入; 
3、请求参数的边界值; 
4、请求参数的异常处理,例如:未带入必填项参数等 
5、基于业务场景的考虑,例如:登录态、权限、依赖性等; 6、涉及到DAO层调用的,考虑数据增删改查的正确性。

接口测试举例:

这里写图片描述

这里写图片描述

存在的问题:两个接口混在了一起,变成了测试发布朋友圈这个功能。

从接口角度: 
1、上传图片及发布朋友圈为两个独立的接口,先分别对两个接口单独做测试; 
2、最后再组合起来确认发朋友圈的业务逻辑是否正确。

所以用例应该这样设计:

这里写图片描述

这里写图片描述

接口测试的实现方式

1、Jmeter 
好:图形化界面,支持编程语言的插件,可录制,上手简单; 
不好:重用度低,复制粘贴较多,遇到加密协议会跪。 
2、Java纯代码(TestNG + OKHttpClient) 
好:灵活,设计得好的话重用度高; 
不好:需要自己封装一些工具类及代码,数据写在代码中改起来不方便。

这里写图片描述

好用的抓包工具 BurpSuite

强大的功能距离 
功能1:筛选某一固定的数据类型,甚至某个文件的扩展名; 
如只显示jpg图片请求

Proxy histroy有一个可以用来在视图中隐藏某些内容的功能,以使其更易于分析和你感兴趣的工作内容的显示过滤。 History Table上方的过滤栏描述了当前的显示过滤器。点击过滤器栏打开要编辑的过滤器选项。该过滤器可以基于以下属性进行配置:

这里写图片描述

功能2:拦截所有jpg图片请求,模拟获取图片超时场景。

总结

这里写图片描述