1 什么是接口测试?
接口测试是测试系统组件间接口的一种测试。接口测试主要用于检测外部系统与系统之间以及内部各个
子系统之间的交互点。测试的重点是要检查数据的交换、传递和控制管理过程,以及系统间的相互逻辑依赖关系等。
2 为什么要做接口测试?
接口测试介于单元测试与系统测试之间,单元测试一般由开发完成(不要相信开发)
接口是各种系统功能的基础,一旦接口出现问题可能会引起许多系统功能的问题并且不容易定位
开展接口测试可以及早发现问题,有效降低测试成本
接口一般较UI相对稳定,利于进行自动化和持续集成
3 接口测试都测什么?
接口测试一般有以下岗位实施:
手工测试岗:先提测接口再提出功能,兼做接口自动化
服务端测试岗:梳理代码,审核接口实现逻辑是否与业务设计一致,技术实现逻辑的合理性,异常流测试,接口压测及安全性测试
测试开发岗:专职做接口(或UI)的自动化用例开发,测试工具开发
4 业务逻辑
4 怎样掌握接口测试?
1 了解OSI网络模型,TCP/UDP协议,掌握HTTP/HTTPS协议,了解RPC, Web Service及REST,理解Session和Cookie
2 掌握常用的接口测试工具如curl命令,Postman,Jmeter,LR,SoupUI,AB等
3 掌握基本的抓包工具如Chrome开发者工具,Fiddler,Charles,Wireshark,tcpdumps等
4掌握一门编程语言Python或Java
5 了解Nginx, Apache, Tomcat等服务器中间件
6 掌握数据库基本查询命令,及一些NoSQL(如Redis)操作,用于检查响应结果
7 掌握基本的Linux日子查询和筛选命令
5 接口测试重难点
动态变量参数化
接口依赖及中间变量问题
异步接口结果验证问题
相应参数及嵌套很多的验证问题
接口测试框架的稳定性问题
资源清理问题
多接口场景测试
6 常见软件默认端口
Apache/Nginx(HTTP服务): 80 https:443
Tomcat: 8080
Oracle: 1521
MySQL: 3306
SQL Server: 1433
PostgreSQL: 5432
MongoDB: 27017
Redis: 6379
Memcached: 11211
查看端口命令
Windows: netstat -ano|findstr 端口号
Linux: netstat -ano|grep 端口号
7 常见接口类型?
HTTP接口,RPC接口,Web Service接口, Dubble接口,RESTful接口,其中RESTful接口是基于HTTP接口的,Web Service及Dubble属于RPC接口
HTTP接口:通过HTTP协议传输的接口,可以传输文本表单数据,也可以传输Json类型的对象数据或xml类型的数据
RPC: 远程方法调用,随着分布式系统的出现,当你需要调用部署到其他服务器上的方法时,需要用到RPC。RPC只是提出了这样一个问题,有很多种解决方案,比如WebService(基于SOAP协议), REST(基于HTTP协议)。
SOAP: 简单面向对象协议,基于HTTP,使用xml作为默认传输格式
Web Service: 基于SOAP协议的一种RPC实现方案。相比传统的HTTP接口只传输文本请求和文本相应,通过Web Service可以直接拿到远程的一个对象,并能够直接调用该对象的属性和方法,比HTTP更高级。
REST/RESTful API: REST,表述性状态转移。一种HTTP接口的设计风格,将一切接口视为资源,要求接口路径同意管理,分版本管理,规定了GET/POST等请求以及HTTP状态码的使用规范,默认使用JSON格式传输。RESTful API即满足REST风格即设计规范的API接口
8 接口测试的流程
1 熟悉API接口文档
2 编写测试用你
3 利用接口测试工具,根据测试用例进行API手工测试或者接口自动化测试
注意事项:没有接口文档,让开发提供
9 接口测试文档
增加课程接口
用来创建一个新的培训课程
请求语法
POST /api/mgr/sq_mgr/ HTTP/1.1
Content-Type: application/x-www-form-urlencoded
url请求参数
无url请求参数
请求体内容
action 必填 填写add_course,表明是为了创建课程
data 必填 存储创建课程的信息,包括名称、描述、显示次序。
为json格式。例如:
{
"name":"初中化学",
"desc":"初中化学课程",
"display_idx":"4"
}
响应语法
HTTP/1.1 200 OK
Content-Type: application/json
头部信息
Content-Type 必填 正常情况下该值将被设为application/json,表示返回 JSON 格式的文本信息。
响应内容
如果请求成功,返回json格式的消息体,如下所示,retcode值为0表示添加成功,id是新加课程对应的ID号
{
"retcode": 0
"id" : 1212
}
说明
增加课程的名称如果已经存在,则会创建失败返回结果为
{
"retcode": 2,
"reason": "同名课程已经存在"
}
10 接口测试样例
11 第三方接口测试库(python)
内置库:httplib,urllib2
第三方库:cn.python-requests.org/zh-CN/latest/