一、后台服务的基本分层结构
二、 测试前的准备
1、了解接口的业务功能
2、接口的入参、个数、类型、是否有默认值
3、返回结果的结构、类型、范围
4、了解有多少调用方,明确调用方的需求
三、接口测试在测什么
定义:接口测试是测试系统组件间接口的一种测试。接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点。测试的重点是要检查数据的交换,传递和控制管理过程,以及系统间的相互逻辑依赖关系等。
3.1 接口层
1、接口可用性:比如服务是不是通的,请求服务会不会timeout,或返回一些常见的错误码,比如http404,500等
2、是否符合接口定义:比如请求参数可选,必选要求,返回结果参数集合是否正确,格式是否正确
3、接口参数取值是否符合业务定义:比如支付金额不能 <=0
3.2 业务逻辑
1、业务流程
2、业务处理的原子性:比如一次转账涉及到金额变更和流水记录,当其中一个失败是,两个都要回滚
3、业务处理的并发控制:比如给同一个配送员“同时”进行多个配送单的结算,配送员的余额是一个共享资源
4、业务处理的防重控制:比如同一笔支付订单不能支付两次
3.3 数据存取
1、数据库连接是否正常:连接参数是否正确
2、业务数据是否写入到DB:比如有分库分表逻辑的时候,是否写入到正确的库和表
3、读取是否正常:是否能查询到正确的业务数据
3.4 Data正确性
四、接口测试目标
1、覆盖要求:接口层逻辑、业务逻辑、数据存取逻辑
2、正确性要求:响应结果、持久化数据存取正确、并发控制正确性、业务处理原子性、业务处理的防重正确性
五、接口测试方法
5.1 接口导向的集成测试—基本版
1、以接口的方式access服务
2、组合接口参数取值以满足功能覆盖要求
3、校验接口返回结果以验证服务的正确性
例子🌰
5.2 接口导向的集成测试—进阶版
1、以接口的方式access服务
2、组合接口参数取值+外部参数(DB,依赖的服务返回)以满足功能覆盖要求
3、校验接口返回结果+DB(或其他输出形式)以验证服务的正确性
5.3 接口导向的集成测试注意事项
1、服务的输入参数不仅包括接口参数,还包括一些接口不可见的参数,比如DB,比如依赖服务的返回
2、服务的处理接口不仅包含接口返回结果,还包含一些接口不可见的处理结果,比如DB
六、接口测试工具
1、HTTP接口测试工具:POSTMAN、SOAPUI、curl命令
2、Thrift测试、MQ测试:自定义接口client+测试框架(比如java的testng、python的unittest)
七、接口自动化
7.1 Java自动化测试框架——TestNG
1、使用注解来表示case
2、支持测试用例分组执行
3、支持并发测试case编写
4、提供了验证函数:Assertions
5、生成测试结果报告
7.2 自动化执行与报告
1、整个测试项目目是基于maven构建的,使用Maven-SureFire-Plugin插件来执行case
2、在maven构建生命周期的test阶段运行测试用例,产生两种不同形式的测试结果报告:纯文本与.xml文件
3、命令:mvn test