接口测试简介
1) 什么是接口测试
开始学习接口自动化测试之前,我们先要来了解什么是接口,以及什么是接口测试。
我们都知道,测试从级别上划分可以分为
◆ 组件测试
◆ 集成测试
◆ 系统测试
◆ 验收测试
其中在集成测试这个阶段,一个最主要的测试活动就是接口测试。
在组件测试中,我们对单个组件自身的功能性能等指标进行验证,上升到集成测试级别,我们则进一步去验证组件之间的交互和集成,而组件之间的交互,就是通过"接口"来达成的。
所以一定程度上,集成测试和接口测试概念是大幅度重叠的。(就组件集成/接口测试而言,其实还有系统集成测试)
比如在主流的web项目中,前端和后端之间的交互,就要通过接口,也是我们这个系列要应对的主要任务。
2)为什么要做接口测试
我经常喜欢用一台汽车做为例子来讲述组件,集成和系统测试之间的关系。
比如,现在有一台汽车需要做质量检测,那么我们可以怎么测试?
◆ 组件测试→测试这台汽车的各个部件(如发动机、底盘、变速箱、制动器、转向系统、轮毂轮胎)
◆ 集成测试→测试这台汽车各部件之间的联动(变速箱如何控制发动机的运作?转向系统如何对轮毂产生影响?)
◆ 系统测试→ 测试这台汽车做为一个整体的功能性能
有一个疑问是,难道我在系统测试这个级别,就不能测试上述例子中的“变速箱如何控制发动机的运作”指标吗?
其实一定程度而言是可以的,这也是为什么在过去一段时间内,其实大量的测试人员是被堆积在系统测试级别的。
但随着我们的行业越来越发展,测试理念越来越先进,测试人员的技能储备也更加丰富,现在的IT项目中已经越来越重视测试的左移和测试的深度。
接口测试在笔者看来,其最大的好处莫过于如下两点:
1、可以尽早的让测试介入项目,更早的发现和解决问题。比如在整体系统还未开发完毕时,部分接口其实已经可供测试了。
2、可以从更底层的角度进行测试,从而弥补系统测试级别容易忽略和难以触发的一些测试。
完备的接口测试可以给项目质量带来远超系统测试的收益,参考测试金字塔理论:
3) HTTP请求的类别
本系列会主要应对是http类型的接口测试
我们先通过一个表格来列举出8种http请求的类别定义,具体请求方法的实际应用我们在后续的自动化实例中再进一步探讨
在实际工作中,最常见的是GET以及POST方法。
2接口自动化工具准备
1)必备工具
要搭建http接口测试环境,我们需要以下的东西:
◆ JDK:推荐使用1.8
◆ 集成开发环境:这里我们使用eclipse
◆ 自动化构建管理:Maven
◆ 其他相应的依赖包我们通过maven管理
2)JDK的安装
JDK的下载安装和环境变量配置网上有大量教程,本文不再赘述
3)Eclipse的安装
eclipse的安装也非常简单,本文不再赘述
4)Maven的安装
Maven的下载安装和环境变量配置网上有大量教程,本文不再赘述
以上不再赘述的部分如果遇到问题,可以加开开老师微信:1397658968
3接口自动化项目
在eclipse中新建一个maven项目MavenAPIProject,打开项目自带的pom.xml文件,加入以下依赖信息:
<!-- https://mvnrepository.com/artifact/org.apache.httpcomponents/httpclient -->
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>4.5.2</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.apache.httpcomponents/httpcore -->
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpcore</artifactId>
<version>4.4.4</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.testng/testng -->
<dependency>
<groupId>org.testng</groupId>
<artifactId>testng</artifactId>
<version>6.8.8</version>
<scope>test</scope>
</dependency>
修改完毕后保存,就可以看到eclipse会在后台开始去自动下载并添加以上所有项目依赖的jar包。
我们现在主要引入的是httpclient、httpcore以及testNG三个依赖包:
◆ httpclient是一个高效的、最新的、功能丰富的支持 HTTP 协议的客户端编程工具包,我们用它来创建和管理请求;
◆ HttpCore是对HTTP协议的基础封装的一套组件,我们测试接口过程中会用到其中的底层网络方法;
◆ testNG是一套单元测试框架,为我们提供测试入口和测试组织,后续如果用到其他依赖包我们再去添加。