接口测试方法及装置与流程

文档序号:15462362发布日期:2018-09-18 18:28阅读:149来源:国知局

本发明涉及计算机技术领域,具体而言,涉及一种接口测试方法及装置。



背景技术:

随着软件技术发展,越来越多软件通过平台化为用户提供服务,第三方可以根据平台提供接口定制自己需要服务,因此如今软件经常涉及接口测试。接口是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。接口测试是向接口提交输入数据,获取返回结果并分析结果是否符合预期的测试。接口测试中可能会涉及各种系统命令、测试工具,甚至编程技术。

目前大部分在软件研发过程中都是通过手工编写各种类型的接口用例,完成用例编写后然后运用一些市面已有的工具进行手动的运行用例,造成效率低下,影响项目进度等等一系列问题。



技术实现要素:

有鉴于此,本发明实施例的目的在于提供一种接口测试方法及装置,以改善上述问题。

第一方面,本发明实施例提供了一种接口测试方法,所述方法包括:在检测到用户发起待测接口调用请求时,获取待测接口的接口测试用例以及获取服务器根据所述待测接口调用请求返回的请求结果;利用所述接口测试用例对所述待测接口进行测试,以获取测试结果;将所述请求结果与所述测试结果进行比对,获得一比对结果;根据所述比对结果判断所述待测接口是否合格,其中,在判断结果为是时,表明所述待测接口为合格,在判断结果为否时,表明所述待测接口为不合格。

进一步地,在用户发起待测接口调用请求时,获取待测接口的接口测试用例以及获取服务器根据所述待测接口调用请求返回的请求结果之后,所述方法还包括:根据所述待测接口的类型对所述接口测试用例进行分类,以根据同一类的接口测试用例对对应的同类型的待测接口进行测试从而获得已测接口的覆盖率。

进一步地,在检测到用户发起待测接口调用请求时,获取待测接口的接口测试用例,包括:在检测到用户发起待测接口调用请求时,获取所述待测接口的数据;将所述待测接口的数据按照预设规则进行转换,以获得接口测试用例。

进一步地,在检测到用户发起待测接口调用请求时,获取待测接口的接口测试用例以及获取服务器根据所述待测接口调用请求返回的请求结果之后,所述方法还包括:获取数据库根据所述待测接口调用请求对获得的所述接口测试用例进行校验后返回的验证结果;根据所述验证结果判断所述接口测试用例是否完善。

进一步地,根据所述验证结果判断所述接口测试用例是否完善之后,所述方法还包括:在判断所述接口测试用例不完善时,利用所述数据库的闪回操作完善所述接口测试用例。

第二方面,本发明实施例提供了一种接口测试装置,所述装置包括:数据获取模块,用于在检测到用户发起待测接口调用请求时,获取待测接口的接口测试用例以及获取服务器根据所述待测接口调用请求返回的请求结果;测试模块,用于利用所述接口测试用例对所述待测接口进行测试,以获取测试结果;结果比对模块,用于将所述请求结果与所述测试结果进行比对,获得一比对结果;判断模块,用于根据所述比对结果判断所述待测接口是否合格,其中,在判断结果为是时,表明所述待测接口为合格,在判断结果为否时,表明所述待测接口为不合格。

进一步地,所述装置还包括:用例分类模块,用于根据所述待测接口的类型对所述接口测试用例进行分类,以根据同一类的接口测试用例对对应的同类型的待测接口进行测试从而获得已测接口的覆盖率。

进一步地,所述数据获取模块,具体用于在检测到用户发起待测接口调用请求时,获取所述待测接口的数据;将所述待测接口的数据按照预设规则进行转换,以获得接口测试用例。

进一步地,所述装置还包括:校验结果获取模块,用于获取数据库根据所述待测接口调用请求对获得的所述接口测试用例进行校验后返回的验证结果;完善判断模块,用于根据所述验证结果判断所述接口测试用例是否完善。

进一步地,所述装置还包括:闪回操作模块,用于在判断所述接口测试用例不完善时,利用所述数据库的闪回操作完善所述接口测试用例。

本发明实施例的有益效果是:

本发明实施例提供了一种接口测试方法及装置,该方法首先在检测到用户发起待测接口调用请求时,获取待测接口的接口测试用例以及获取服务器根据所述待测接口调用请求返回的请求结果,然后利用所述接口测试用例对所述待测接口进行测试,以获取测试结果,将所述请求结果与所述测试结果进行比对,获得一比对结果,然后根据所述比对结果判断所述待测接口是否合格,其中,在判断结果为是时,表明所述待测接口为合格,在判断结果为否时,表明所述待测接口为不合格,本方法中,通过自动获得接口测试用例,自动对接口进行测试以及自动判断接口是否合格,进而提高了接口测试效率。

本发明的其他特征和优点将在随后的说明书阐述,并且,部分地从说明书中变得显而易见,或者通过实施本发明实施例了解。本发明的目的和其他优点可通过在所写的说明书、权利要求书、以及附图中所特别指出的结构来实现和获得。

附图说明

为了更清楚地说明本发明实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本发明的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。

图1示出了一种可应用于本申请实施例中的电子设备的结构框图;

图2为本发明实施例提供的一种接口测试方法的流程图;

图3为本发明实施例提供的一种接口测试装置的结构框图。

具体实施方式

下面将结合本发明实施例中附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。通常在此处附图中描述和示出的本发明实施例的组件可以以各种不同的配置来布置和设计。因此,以下对在附图中提供的本发明的实施例的详细描述并非旨在限制要求保护的本发明的范围,而是仅仅表示本发明的选定实施例。基于本发明的实施例,本领域技术人员在没有做出创造性劳动的前提下所获得的所有其他实施例,都属于本发明保护的范围。

应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。同时,在本发明的描述中,术语“第一”、“第二”等仅用于区分描述,而不能理解为指示或暗示相对重要性。

请参照图1,图1示出了一种可应用于本申请实施例中的电子设备100的结构框图。电子设备100可以包括接口测试装置、存储器101、存储控制器102、处理器103、外设接口104。

所述存储器101、存储控制器102、处理器103、外设接口104各元件相互之间直接或间接地电性连接,以实现数据的传输或交互。例如,这些元件相互之间可通过一条或多条通讯总线或信号线实现电性连接。所述接口测试装置包括至少一个可以软件或固件(firmware)的形式存储于所述存储器101中或固化在所述接口测试装置的操作系统(operating system,OS)中的软件功能模块。所述处理器103用于执行存储器101中存储的可执行模块,例如所述接口测试装置包括的软件功能模块或计算机程序。

其中,存储器101可以是,但不限于,随机存取存储器(Random Access Memory,RAM),只读存储器(Read Only Memory,ROM),可编程只读存储器(Programmable Read-Only Memory,PROM),可擦除只读存储器(Erasable Programmable Read-Only Memory,EPROM),电可擦除只读存储器(Electric Erasable Programmable Read-Only Memory,EEPROM)等。其中,存储器101用于存储程序,所述处理器103在接收到执行指令后,执行所述程序,前述本发明实施例任一实施例揭示的流过程定义的服务器所执行的方法可以应用于处理器103中,或者由处理器103实现。

处理器103可以是一种集成电路芯片,具有信号的处理能力。上述的处理器103可以是通用处理器,包括中央处理器(Central Processing Unit,简称CPU)、网络处理器(Network Processor,简称NP)等;还可以是数字信号处理器(DSP)、专用集成电路(ASIC)、现成可编程门阵列(FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。可以实现或者执行本发明实施例中的公开的各方法、步骤及逻辑框图。通用处理器可以是微处理器或者该处理器103也可以是任何常规的处理器等。

所述外设接口104将各种输入/输出装置耦合至处理器103以及存储器101。在一些实施例中,外设接口104,处理器103以及存储控制器102可以在单个芯片中实现。在其他一些实例中,他们可以分别由独立的芯片实现。

所述外设接口104将各种输入/输入装置耦合至处理器103以及存储器101。在一些实施例中,外设接口104,处理器103以及存储控制器102可以在单个芯片中实现。在其他一些实例中,他们可以分别由独立的芯片实现。

可以理解,图1所示的结构仅为示意,所述电子设备100还可包括比图1中所示更多或者更少的组件,或者具有与图1所示不同的配置。图1中所示的各组件可以采用硬件、软件或其组合实现。

请参照图2,图2为本发明实施例提供的一种接口测试方法的流程图,该方法包括如下步骤:

步骤S110:在检测到用户发起待测接口调用请求时,获取待测接口的接口测试用例以及获取服务器根据所述待测接口调用请求返回的请求结果。

对于接口的测试往往是将接口封装为函数,然后通过调用该函数实现接口功能测试的自动化。其中,用户发起的待测接口调用请求,即为调用该待测接口封装的函数,电子设备在检测到用户发起待测接口调用请求时,根据该待测接口的标识可以获得该待测接口的相关接口数据,即在检测到用户发起待测接口调用请求时,获取所述待测接口的数据,如该待测接口的名称、需传递的测试数据、测试内容、预期结果等数据,然后将这些数据保存为本地文档,然后将所述待测接口的数据按照预设规则进行转换,以获得接口测试用例,例如,将这些数据根据预设的一些格式要求进行转换为接口测试用例。

对待测接口的测试需采用接口测试用例,而获得接口测试用例还需获得相关数据,例如,该待测接口所属的功能模块、用例ID、接口名称、请求参数、结果验证等,所以,在上述获得接口数据后,对该接口数据进行转换后获得接口测试用例,其实是基于接口数据按照预先编写的接口测试用例模板自动生成接口测试用例,从而避免了手动编写接口测试用例带来的复杂操作。

当然,接口测试用例可以为预先生成之后保存的,也就是说,对于每个接口来说,可以预先根据这个接口的数据转换成接口测试用例后进行存储,在获得待测接口调用请求后,可以根据该待测接口的标识从保存的接口测试用例中获得待待测接口对应的接口测试用例。

用户发起的待测接口调用请求会发送至服务器,服务器根据该请求返回一个请求结果,例如,用户向发服务器发起调用显示图片的接口调用请求,服务器接收到该请求向电子设备返回请求结果,如请求成功或请求失败等。

步骤S120:利用所述接口测试用例对所述待测接口进行测试,以获取测试结果。

所述接口测试用例为用户编写好的具有一定格式要求的测试用例,例如,接口测试用例中包括待测接口名、测试标题、测试内容、调用文件名、传递字段、预期结果等。

接口测试用例中包括预期输出结果,当利用接口测试用例对待测接口进行测试后获得该待测接口返回的输出结果后,将该输出结果与预期输出结果进行比较,若输出结果与预期输出结果一致,则将该输出结果作为测试结果进行保存,若输出结果与预期输出结果不一致时,将待测接口返回的输出结果作为测试结果进行保存。

步骤S130:将所述请求结果与所述测试结果进行比对,获得一比对结果。

所述请求结果为上述服务器根据所述待测接口调用请求返回的请求结果,测试结果为利用接口测试用例对所述待测接口进行测试后获得的测试结果,由于服务器接收到用户发起的待测接口调用请求后,若该待测接口无法进行运行,则服务器返回请求失败的请求结果,若该待测接口可以正常运行,则服务器返回请求成功的请求结果,例如,用户发起的待测接口调用请求为图片显示接口调用请求,若该接口可以正常调用,服务器返回的请求结果为请求成功,利用接口测试用例对该接口进行测试后的测试结果为测试成功,所以,在将请求结果与所述测试结果进行比对,获得比对结果,比对结果可以为比对一致或者比对不一致。

步骤S140:根据所述比对结果判断所述待测接口是否合格。

其中,在判断结果为是时,表明所述待测接口为合格,在判断结果为否时,表明所述待测接口为不合格,即若比对结果为比对不一致时,则确定所述待测接口为不合格,若比对结果为比对一致时,则确定所述待测接口为合格,当待测接口为不合格时,则可以重新修改待测接口的相关程序,或者采取其他措施进行拯救等,若待测接口为合格时,则该待测接口可以正常使用,没有问题,从而通过自动对接口进行测试,很大程度上提升了测试效率。

另外,作为一种实施方式,当待测接口为多个时,为了对多个待测接口进行有效测试,则所述方法还包括:

根据所述待测接口的类型对所述接口测试用例进行分类,以根据同一类的接口测试用例对对应的同类型的待测接口进行测试从而获得已测接口的覆盖率。例如,对于某一类型的待测接口类型,可以采用同一个接口测试用例进行测试,如将该待测接口采用按功能进行类型划分,用于进行登录功能的接口划分为同一类型的接口,用于进行注册功能的接口划分为同一类型的接口,而其中属于同一类型的接口可对应于不同的接口测试用例,例如,采用本地服务进行登录的接口和采用外网服务进行登录的接口显然是不一样的,所以,其接口测试样例也不同,具体地,可以定义接口的URL地址相同则该接口为同类型的接口,所以,将这些同类型的接口对应的接口测试样例分为一类,由此,在对同类型的接口进行测试时,可以获得已测试接口的覆盖率,例如,属于登录类型的接口有五个,然后利用接口测试用例对其中的三个接口进行测试,则其已测试接口覆盖率为五分之三,从而可以拓展测试的广度、覆盖范围等。

作为一种实施方式,因为某些接口在测试的时候需要对数据库进行初始化操作,所以首先得对数据库进行初始化,为了对获得的接口测试用例进行完善,所以,在获得接口测试用例之后,还获取数据库根据所述待测接口调用请求对获得的所述接口测试用例进行校验后返回的验证结果,然后根据所述验证结果判断所述接口测试用例是否完善。

具体地,所述数据库中存储有待测接口的相关数据,由于获得的接口测试用例中包含的数据不是很完善,所以数据库还需对接口测试用例进行校验,例如,将接口测试用例中的相关数据与存储的接口数据进行比对,在比对一致时,返回校验通过的验证结果,在比对不一致时,返回校验失败的验证结果,在验证结果为校验通过时判断所述接口测试用例为完善,在验证结果为校验失败时判断所述接口测试用例不完善,则了利用数据库的闪回操作完善所述接口测试用例。

闪回操作是指具有独特而丰富的数据恢复解决方案,能有选择性地撤销一个错误的影响,从人为错误中恢复。在采用闪回技术之前,损坏数据库只需数分钟,而要恢复它则需要数小时,有了闪回技术,纠正错误只需要数分钟的时间。闪回技术支持在所以层面上进行恢复,包括行、事务、表和整个数据库。

所以,本发明实施例中通过自动获得接口测试用例、自动转换接口测试用例、自动分类接口测试用例、快速自动校验数据库、接口返回校验,以及数据库闪回等技术,提升了后台测试的效率、准确性、完整性,适应了日益增长的后台测试需求,大大节约了研发的时间成本。

请参照图3,图3为本发明实施例提供的一种接口测试装置200的结构框图,所述装置包括:

数据获取模块210,用于在检测到用户发起待测接口调用请求时,获取待测接口的接口测试用例以及获取服务器根据所述待测接口调用请求返回的请求结果。

测试模块220,用于利用所述接口测试用例对所述待测接口进行测试,以获取测试结果。

结果比对模块230,用于将所述请求结果与所述测试结果进行比对,获得一比对结果。

判断模块240,用于根据所述比对结果判断所述待测接口是否合格,其中,在判断结果为是时,表明所述待测接口为合格,在判断结果为否时,表明所述待测接口为不合格。

进一步地,所述装置还包括:用例分类模块,用于根据所述待测接口的类型对所述接口测试用例进行分类,以根据同一类的接口测试用例对对应的同类型的待测接口进行测试从而获得已测接口的覆盖率。

进一步地,所述数据获取模块210,具体用于在检测到用户发起待测接口调用请求时,获取所述待测接口的数据;将所述待测接口的数据按照预设规则进行转换,以获得接口测试用例。

进一步地,所述装置还包括:校验结果获取模块,用于获取数据库根据所述待测接口调用请求对获得的所述接口测试用例进行校验后返回的验证结果;完善判断模块240,用于根据所述验证结果判断所述接口测试用例是否完善。

进一步地,所述装置还包括:闪回操作模块,用于在判断所述接口测试用例不完善时,利用所述数据库的闪回操作完善所述接口测试用例。

所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的装置的具体工作过程,可以参考前述方法中的对应过程,在此不再过多赘述。

综上所述,本发明实施例提供了一种接口测试方法及装置,该方法首先在检测到用户发起待测接口调用请求时,获取待测接口的接口测试用例以及获取服务器根据所述待测接口调用请求返回的请求结果,然后利用所述接口测试用例对所述待测接口进行测试,以获取测试结果,将所述请求结果与所述测试结果进行比对,获得一比对结果,然后根据所述比对结果判断所述待测接口是否合格,其中,在判断结果为是时,表明所述待测接口为合格,在判断结果为否时,表明所述待测接口为不合格,本方法中,通过自动获得接口测试用例,自动对接口进行测试以及自动判断接口是否合格,进而提高了接口测试效率。

在本申请所提供的几个实施例中,应该理解到,所揭露的装置和方法,也可以通过其它的方式实现。以上所描述的装置实施例仅仅是示意性的,例如,附图中的流程图和框图显示了根据本发明的多个实施例的装置、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段或代码的一部分,所述模块、程序段或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现方式中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个连续的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或动作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。

另外,在本发明各个实施例中的各功能模块可以集成在一起形成一个独立的部分,也可以是各个模块单独存在,也可以两个或两个以上模块集成形成一个独立的部分。

所述功能如果以软件功能模块的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、磁碟或者光盘等各种可以存储程序代码的介质。

以上所述仅为本发明的优选实施例而已,并不用于限制本发明,对于本领域的技术人员来说,本发明可以有各种更改和变化。凡在本发明的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。

以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应所述以权利要求的保护范围为准。

需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。

当前第1页1 2 3 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1