关于接口测试
接口定义
接口泛指实体把自己提供给外界的一种抽象化物,用以由内部操作分离出外部沟通方法,使其能被修改内部而不影响外界其他实体与其交互的方式。
举例:有各种各样的接口,比如电视遥控器的操作界面上的各种按钮 ,电脑上主板的网卡,插槽,硬盘数据线插槽, 软件菜单,DOS命令窗口,软件API函数
注意:接口不关注内部具体实现---过程,而是关注功能实现---结果。
接口分类
根据接口的定义和特性,可以分为以下两类:
1. 外部接口
说明:说明资源实体本身同外界环境的交互方式。
接口分类:
(软件产品为例说明)
1. 用户接口----方便用户与软件产品交互方式,沟通方式。
常见说明示例:
外部接口的用户界面部分按Windows应用软件用户界面的规范来设计,界面设计风格与XXX环境保持一致,采用XXX以及对话框等方式作为用户界面,便于用户使用。
用户接口分类
命令接口:软件产品向用户提供了命令接口供用户使用或管理软件产品。
图形接口:用户可通过鼠标、菜单和对话框来完成对软件产品的相关操作。图形用户接口元素包括窗口、图标、菜单和对话框等
程序接口:软件产品提供给软件开发人员进行编程的接口,俗称API。
2. 硬件接口----软件产品与其它硬件资源之间的接口。
常见说明示例:
Inter或其他系列的微型计算机,内存XXXG以上,硬盘XXXG以上。
3. 软件接口----软件产品同其它应用软件/系统之间的接口。
常见说明示例:
本软件运行于XXX软件及以上版本上,整个环境需要运行在Windows某某版本及更高版本并装有XXX(依赖软件)的操作系统之上。
4. 通信接口---指定软件产品采用的网络传输等通信接口。
常见说明示例:
本软件使用的xxx通信协议。
2. 内部接口
说明:说明软件内部各个模块/系统元素之间的接口或规范,软件各个模块间数据交换的格式等。
常用说明示例:软件内部的接口是通过XXX来进行交换的。用户使用XXX软件……可以说软件的各个模块之间主要通过XXX来进行关联,传送数据并交换信息,从而降低软件模块间的耦合程度。
接口测试
1. 侠义定义
通常,我们软件测试中所说的接口测试,是指外部接口中用于与外部系统交互接口及软件系统内部模块/组件或子系统之间的内部接口测试。例如:
1、系统与系统之间的调用,比如银行会提供接口供电子商务网站调用,或者说,支付宝会提供接口给淘宝调用
2、上层服务对下层服务的调用,比如service层会调用DAO层的接口,而应用层又会调用服务层提供的接口
3、服务之间的调用,比如注册用户时,会先调用用户查询的服务,查看该用户是否已经注册。
注意:
1.不管是内部接口还是外部接口,表现形式一般是以API形式出现
2.代码角度看接口
interface 动物 { void 叫(); }
class 狗 implements 动物 { void 叫() { System.out.println("汪"); } }
class 猫 implements 动物 { void 叫() { System.out.println("喵"); } }
这里,叫() 就可以接口函数,反正我不管你叫()函数里面是怎么样实现的,我只认接口叫()。如上,对猫和狗的叫声不一样,也就是说实现不一样,但是接口一样都是叫(),猫也好,狗也好,都调用叫()。如果不是采用接口形式,而是对猫采用猫叫(),对狗采用狗叫(),当外界环境变化,比如,来的是狐狸叫,那就要修改函数为狐狸叫(),那就麻烦了。
通常比较规范的接口文档都应该具备类似下图中的特点:包含接口名,参数名,参数类型,参数含义说明,取值限制,是否可空等
2. 适用情况
接口测试一般以用于多系统间交互开发,或者拥有多个子系统的应用系统开发的测试。接口测试适用于为其他系统提供服务的底层框架系统和中心服务系统,主要测试这些系统对外部提供的接口,验证其正确性和稳定性。接口测试同样适用于一个上层系统中的服务层接口。
3. 接口测试和单元测试
接口测试和单元测试之间并无严格的界限划分,根据接口的定义和特性,建议把接口测试同单元测试进行区别看待。个人理解两者之间主要区别在于:
1.单 元测试从代码角度对函数代码的逻辑进行测试,考虑的是函数内部实现,逻辑结构,一般由开发人员执行,而接口测试则是站在用户角度对函数接口定义进行的测 试,考虑的是数据的交换,传递和控制管理过程及系统间的相互逻辑依赖,一般由测试人员执行。可以把接口测试看成是功能黑盒测试,如下:
输入接口参数值->API接口->查看接口的输出
2.一个接口函数可能会包含多个单元模块,所以接口测试和单元测试并不是完全相同的。
3. 接口测试是要满足需求的,有自己特定的业务定义,接口测试所依赖的也是需求说明书,做接口测试的时候,更多的需要从业务的角度去考虑如何测试这个接口
4. 接口测试可以看成是单元测试和集成测试中的一部分。
4. 测试流程
需求评审->接口定义->用例设计->测试执行->结果分析
注:.接口一般是开发人员定义的