CN117609079A - 基于调用关系网络进行测试的方法、装置、设备和介质 - Google Patents

基于调用关系网络进行测试的方法、装置、设备和介质 Download PDF

Info

Publication number
CN117609079A
CN117609079A CN202311649917.XA CN202311649917A CN117609079A CN 117609079 A CN117609079 A CN 117609079A CN 202311649917 A CN202311649917 A CN 202311649917A CN 117609079 A CN117609079 A CN 117609079A
Authority
CN
China
Prior art keywords
interface
target
systems
interfaces
determining
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN202311649917.XA
Other languages
English (en)
Inventor
邓乐乐
陈杰
陈彦旭
刘惠
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Agricultural Bank of China
Original Assignee
Agricultural Bank of China
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Agricultural Bank of China filed Critical Agricultural Bank of China
Priority to CN202311649917.XA priority Critical patent/CN117609079A/zh
Publication of CN117609079A publication Critical patent/CN117609079A/zh
Pending legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/3668Software testing
    • G06F11/3672Test management
    • G06F11/3688Test management for test execution, e.g. scheduling of test suites
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/3668Software testing
    • G06F11/3672Test management
    • G06F11/3676Test management for coverage analysis

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • Quality & Reliability (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

本发明实施例提供一种基于调用关系网络进行测试的方法、装置、设备和介质,涉及测试技术领域。该方法包括:确定目标接口;查询预先建立的接口调用关系网络确定目标接口的关联接口;对关联接口进行测试。本发明提供的技术方案,实现了基于接口调用关系网络对系统中的接口进行测试的功能,使得测试人员可以从全链路测试角度对系统进行测试,提高了测试效率,避免了点对点管理形式存在的测试效率较低的问题;同时,可以直接对目标接口的直接接口和间接接口进行测试,无需通过逐级传导的方式进行测试,节省了测试时间,进一步提高了测试效率,从而提升了用户体验。

Description

基于调用关系网络进行测试的方法、装置、设备和介质
技术领域
本发明实施例涉及测试技术领域,尤其涉及一种基于调用关系网络进行测试的方法、装置、设备和介质。
背景技术
随着业务的不断发展,原来的单系统服务逐渐扩展到多系统服务,并且大型系统的每条业务线都是由各个子系统服务互相调用完成。
目前,针对系统接口服务之间的调用,基本上都是以点对点的形式进行管理,即管理任意两个直接关联系统的消费关系,而没有采用全链路的形式展示各个子系统之间的消费关系。
在实现本发明的过程中,发明人发现,点对点的管理形式导致测试人员难以获取到完整的接口或者系统调用链路,引起以下两个方面的缺点:一方面,在故障测试过程中,需要下游消费方逐个联系上游系统,以确定问题来源,造成排查环境和数据问题困难,导致测试效率较低;另一方面,在技术改造过程中,上游系统改造难以确定下游影响范围,造成下游系统的回归测试需要逐级传导,以确定测试范围,导致测试效率较低。
发明内容
本发明实施例提供一种基于调用关系网络进行测试的方法、装置、设备和介质,使得测试人员可以从全链路测试角度对系统进行测试,提高了测试效率,节省了测试时间,从而提升了用户体验。
第一方面,本发明实施例提供的基于调用关系网络进行测试的方法,该方法包括:
确定目标接口;
查询预先建立的接口调用关系网络确定目标接口的关联接口,关联接口包括目标接口的直接接口和间接接口,直接接口为与目标接口直接连接的接口,间接接口为与目标接口间接连接的接口,接口调用关系网络包括节点和边,节点包括多个系统中的接口,边包括多个系统中的接口的连接关系;
对关联接口进行测试。
本发明实施例的方案,可以确定目标接口;查询预先建立的接口调用关系网络确定目标接口的关联接口;对关联接口进行测试。上述技术方案中,首先从多个系统所包含的接口中确定出目标接口,例如,可以对多个系统所包含的接口进行监测,并将报错的接口确定为目标接口,或者,可以将多个系统中进行技术改造的系统接口确定为目标接口;然后从预先建立的接口调用关系网络中查询出目标接口的关联接口,即与目标接口存在直接调用关系的直接接口,以及与目标接口存在间接调用关系的间接接口,最后对关联接口所包含的直接接口和间接接口进行测试,实现了基于接口调用关系网络对系统中的接口进行测试的功能,使得测试人员可以从全链路测试角度对系统进行测试,提高了测试效率,避免了点对点管理形式存在的测试效率较低的问题;同时,可以直接对目标接口的直接接口和间接接口进行测试,无需通过逐级传导的方式进行测试,节省了测试时间,进一步提高了测试效率,从而提升了用户体验。
第二方面,本发明实施例提供的基于调用关系网络进行测试的装置,该装置包括:
第一确定模块,用于确定目标接口;
第二确定模块,用于查询预先建立的接口调用关系网络确定目标接口的关联接口,关联接口包括目标接口的直接接口和间接接口,直接接口为与目标接口直接连接的接口,间接接口为与目标接口间接连接的接口,接口调用关系网络包括节点和边,节点包括多个系统中的接口,边包括多个系统中的接口的连接关系;
测试模块,用于对关联接口进行测试。
第三方面,本发明实施例提供的电子设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,处理器执行程序时实现如本发明任一实施例的基于调用关系网络进行测试的方法。
第四方面,本发明实施例提供的计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现如本发明任一实施例的基于调用关系网络进行测试的方法。
本发明中第二方面、第三方面以及第四方面的描述,可以参考第一方面的详细描述;并且,第二方面、第三方面以及第四方面描述的有益效果,可以参考第一方面的有益效果分析,此处不再赘述。
在本发明中,上述基于调用关系网络进行测试的装置的名字对设备或功能模块本身不构成限定,在实际实现中,这些设备或功能模块可以以其他名称出现。只要各个设备或功能模块的功能和本发明类似,属于本发明权利要求及其等同技术的范围之内。
本发明的这些方面或其他方面在以下的描述中会更加简明易懂。
附图说明
为了更清楚地说明本发明的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本发明的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。
图1是本发明实施例提供的基于调用关系网络进行测试的方法的一个流程示意图;
图2是本发明实施例提供的建立接口调用关系网络的一个示例图;
图3是本发明实施例提供的接口调用链路图的一个示例图;
图4是本发明实施例提供的系统调用链路图的一个示例图;
图5是本发明实施例提供的基于调用关系网络进行测试的装置的一个结构示意图;
图6是本发明实施例提供的电子设备的一个结构示意图。
具体实施方式
为了使本技术领域的人员更好地理解本发明方案,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分的实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都应当属于本发明保护的范围。
需要说明的是,本发明的说明书和权利要求书及上述附图中的术语“第一”、“第二”等是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的本发明的实施例能够以除了在这里图示或描述的那些以外的顺序实施。此外,术语“包括”和“具有”以及他们的任何变形,意图在于覆盖不排他的包含,例如,包含了一系列步骤或单元的过程、方法、系统、产品或设备不必限于清楚地列出的那些步骤或单元,而是可包括没有清楚地列出的或对于这些过程、方法、产品或设备固有的其它步骤或单元。
图1是本发明实施例提供的基于调用关系网络进行测试的方法的一个流程示意图,本发明实施例提供的基于调用关系网络进行测试的方法可适用于需要对大型系统中的各个子系统和接口进行测试的场景中,该方法可以由本发明实施例提供的基于调用关系网络进行测试的装置来执行,该装置可采用软件和/或硬件的方式实现。在一个具体的实施例中,该装置可以集成在电子设备中,例如电子设备可以是计算机、服务器等。执行本方法的执行主体为电子设备的微控制器。
参见图1,该方法具体包括如下步骤:
S110、确定目标接口。
其中,目标接口是从多个系统的接口中确定出的一个接口。可选的,目标接口可以包括报错接口和技改接口。报错接口为多个系统的接口中出现错误的接口。技改接口为多个系统中进行技术改造的系统接口。
具体地,一种实现方式中,在多个系统进行工作的任意时刻,微控制器可以获取多个系统所包含的所有接口,例如,可以直接从接口管理系统中获取各个系统所包含的接口,或者,可以从日志系统中提取出各个系统所包含的接口。之后,微控制器可以对多个系统所包含的接口进行监测,以监测是否存在报错接口,如果监测到报错接口,则表明系统出现了错误,此时将报错接口确定为目标接口,以对目标接口及其相关接口进行测试,并排查出故障来源;如果未监测到报错接口,则表明系统未出现错误,此时无需进行测试。
另一种实现方式中,在对多个系统中的某个系统进行技术改造的过程中,微控制器可以从接口管理系统和日志系统中获取出进行技术改造的接口,并将进行了技术改造的接口确定为技改接口,然后将技改接口确定为目标接口,以对技术改造所影响的多个接口进行测试。
S120、查询预先建立的接口调用关系网络确定目标接口的关联接口。
其中,接口调用关系网络为预先建立的关系网络,用于表示多个系统中各个接口之间的调用关系,可以包括节点和边,节点包括多个系统中的接口,边包括多个系统中的接口的连接关系,边的方向为接口之间的调用方向。
关联接口包括目标接口的直接接口和间接接口,直接接口为与目标接口直接连接的接口,间接接口为与目标接口间接连接的接口。
微控制器可以预先建立接口调用关系网络。具体而言,可以直接从接口管理系统或者日志系统中获取多个系统所包含的所有接口,以及各个接口之间的调用方向,然后根据调用方向对接口之间的调用关系进行处理,得到多个调用关系对,最后根据多个调用关系对构建网络,得到接口调用关系网络。如图2所示是本发明实施例提供的建立接口调用关系网络的一个示例图,图2中的圆圈为节点,代表多个系统中的接口;节点之间的连接线为边,代表两个接口之间存在调用关系;边的方向(箭头指向)代表接口之间的调用方向,例如,节点0指向节点1,表示接口1调用或者消费接口0。
具体地,微控制器可以根据目标接口查询接口调用关系网络,得到与目标接口存在直接调用关系的直接接口以及存在间接调用关系的间接接口。
示例性的,如图2所示,当目标接口为接口7时,可以根据图2中的接口调用关系网络,得到接口7的直接接口为接口5,并得到接口7的间接接口为接口0、接口2和接口3。
S130、对关联接口进行测试。
具体地,在确定目标接口的关联接口之后,微控制器可以对目标接口的各个关联接口进行测试。例如,当目标接口为报错接口时,可以首先对关联接口所包含的目标接口的直接接口进行测试,然后对关联接口所包含的目标接口的间接接口进行测试,直至测试出故障来源;当目标接口为技改接口时,可以首先确定关联接口所在的系统,然后对该系统所包含的关联接口进行测试,直至测试出技术改造是否为接口引入新的错误。
本发明实施例的方案,可以确定目标接口;查询预先建立的接口调用关系网络确定目标接口的关联接口;对关联接口进行测试。上述技术方案中,首先从多个系统所包含的接口中确定出目标接口,例如,可以对多个系统所包含的接口进行监测,并将报错的接口确定为目标接口,或者,可以将多个系统中进行技术改造的系统接口确定为目标接口;然后从预先建立的接口调用关系网络中查询出目标接口的关联接口,即与目标接口存在直接调用关系的直接接口,以及与目标接口存在间接调用关系的间接接口,最后对关联接口所包含的直接接口和间接接口进行测试,实现了基于接口调用关系网络对系统中的接口进行测试的功能,使得测试人员可以从全链路测试角度对系统进行测试,提高了测试效率,避免了点对点管理形式存在的测试效率较低的问题;同时,可以直接对目标接口的直接接口和间接接口进行测试,无需通过逐级传导的方式进行测试,节省了测试时间,进一步提高了测试效率,从而提升了用户体验。
可选的,在一个具体应用场景中,本发明实施例提供的基于调用关系网络进行测试的方法可以应用在故障定位测试的场景中,具体包括如下:
对多个系统中的接口进行监测,当监测到报错接口时,将报错接口确定为目标接口;查询预先建立的接口调用关系网络确定目标接口的关联接口;对直接接口进行故障定位测试;若直接接口正常,则对间接接口进行故障定位测试。
其中,故障定位测试为排查出系统的故障来源的方法。
具体地,在故障定位测试的场景中,可以首先监测多个系统中的接口,以确定是否存在报错接口。具体而言,可以选取多个系统中的任一接口为当前接口,并监测当前接口,如果当前接口为报错接口,则将当前接口确定为目标接口;如果当前接口不是报错接口,则继续选取其他接口为当前接口,以监测其他接口是否为报错接口。
在确定目标接口之后,可以根据目标接口查询预先建立的接口调用关系网络,得到目标接口的关联接口,即目标接口的直接接口和间接接口。一种实现方式中,在确定目标接口之后,可以根据接口调用关系网络中边的方向,利用网络路径算法计算接口调用关系网络中目标接口的调用链路,得到目标接口的调用链路图。其中,网络路径算法可以为快速扩展随机树(Rapidly-Exploring Random Trees,简称RRT)方法或者概率路图(Probabilistic Road Map,简称PRM)方法,本发明实施例对此不做具体限定。
在确定目标接口的关联接口之后,可以首先对目标接口的直接接口进行故障定位测试,以确定直接接口是否发生了故障,即,如果直接接口发生了故障,则表明直接接口是故障来源,此时故障定位测试结束;如果直接接口没有发生故障,则表明直接接口不是故障来源,此时可以继续对目标接口的间接接口进行故障定位测试,直至测试出故障来源。
示例性的,如图3所示是本发明实施例提供的接口调用链路图的一个示例图,图3中节点0、节点1、节点2、节点3、节点4、节点5、节点6以及加粗的边组成了目标接口6的全部调用链路,其中,节点4和节点5与目标接口6直接连接,因此接口4和接口5为目标接口6的直接接口;节点0、节点1、节点2和节点3与目标接口6间接连接,因此接口0、接口1、接口2和接口3为目标接口6的间接接口。之后,首先测试接口4和接口5,如果接口4和接口5都没有故障,则继续测试接口1、接口2和接口3,当发现接口1、接口2和接口3中的接口1发生了故障时,对接口1进行故障修复,此时故障定位测试结束;当接口1、接口2和接口3都没有故障时,继续测试接口0,直至测试出故障来源。
本发明实施例的方案,首先将报错接口确定为目标接口,接着基于接口调用关系网络确定出目标接口的直接接口和间接接口,然后先对直接接口进行故障定位测试,再对间接接口进行故障定位测试,实现了直接对目标接口的关联接口进行故障定位测试的功能,无需通过逐级传导的方式进行故障定位测试,提高了测试效率,节省了测试时间,从而提升了用户体验;同时,提高了故障定位测试的计算效率,降低了故障定位测试的实现复杂度,使得故障定位测试的实现更加简单。
可选的,在另一个具体应用场景中,本发明实施例提供的基于调用关系网络进行测试的方法可以应用在因技术改造而需要进行回归测试的场景中,具体包括如下:
从多个系统的接口中确定出技改接口,将技改接口确定为目标接口;查询预先建立的接口调用关系网络确定目标接口的关联接口;确定关联接口所在的系统,得到关联系统;通知关联系统对对应的关联接口进行回归测试。
其中,回归测试为对系统的某个功能进行技术改造之后,重新对系统中的各个接口进行测试,以确认技术改造是否引入新的错误或者导致其他功能产生错误的方法。
可选的,在建立接口调用关系网络之后,可以从接口管理系统和日志系统中获取出接口与各个系统之间的所属关系,然后根据接口与各个系统之间的所属关系计算接口调用关系网络中各个系统的调用链路,同时可以得到多个系统的系统调用关系网络。其中,系统调用关系网络用于表示各个系统之间的调用关系,可以包括节点和边,节点包括多个系统,边包括根据接口调用关系网络确定的多个系统的连接关系,边的方向为系统之间的调用方向。
具体地,在回归测试的场景中,可以首先从多个系统中获取进行技术改造的系统,得到技改系统,然后根据系统调用关系网络获取出技术系统所包含的接口中被技术改造影响的接口,得到技改接口,并将技改接口确定为目标接口。
在确定目标接口之后,可以根据目标接口查询预先建立的接口调用关系网络,得到目标接口的关联接口,即目标接口的直接接口和间接接口。之后,可以根据目标接口的关联接口以及接口与各个系统之间的所属关系确定出关联接口所在的系统,得到关联系统,并通知关联系统对关联系统所包含的每一个关联接口进行回归测试,以对技术改造所影响的多个接口进行回归测试。具体而言,可以选取关联接口中的任一接口为当前关联接口,并对当前关联接口进行回归测试,如果当前关联接口出现错误,则可以对当前关联接口进行修复,并在修复完成时选取其他关联接口为当前关联接口,以继续对技术改造所影响的多个接口进行测试;如果当前关联接口未出现错误,则可以选取其他关联接口为当前关联接口,以继续对技术改造所影响的多个接口进行测试。
示例性的,如图4所示是本发明实施例提供的系统调用链路图的一个示例图,可以根据接口与各个系统之间的所属关系确定图4中的接口0属于系统S0,接口1、接口2和接口3属于系统S1,接口4和接口5属于系统S2,接口6和接口7属于系统S3,因此可以根据接口0至接口7的接口调用关系网络得到系统S0至系统S3的系统调用关系网络,并得到系统S3的系统调用链路。一种实现方式中,在对系统S0的某一功能进行技术改造之后,可以直接确定技改接口为接口0,即确定目标接口为接口0,关联接口为接口1至接口7,并确定关联系统为系统S1至系统S3,然后通知关联系统S1对关联接口1、关联接口2和关联接口3进行回归测试,关联系统S2对关联接口4和关联接口5进行回归测试,以及关联系统S3对关联接口6和关联接口7进行回归测试。另一种实现方式中,在对系统S0的某一功能进行技术改造之后,系统S0可以通过系统调用链路图确定技术改造只影响了系统S1的接口1,由此微控制器确定后续只需对以接口1为根节点的接口调用链路(即接口1-接口4-接口6)进行回归测试,并确定目标接口(即技改接口)为接口1,关联接口为接口4和接口6,然后确定关联系统为系统S2和系统S3,并通知关联系统S2对关联接口4进行回归测试,以及关联系统S3对关联接口6进行回归测试。
本发明实施例的方案,首先将技改接口确定为目标接口,接着基于接口调用关系网络确定出目标接口的关联接口,即直接接口和间接接口,然后确定关联接口所在的系统,得到关联系统,最后通知关联系统对关联系统所包含的每一个关联接口进行回归测试,可以直接通过关联接口确定技术改造所影响的范围,即确定需要进行回归测试的接口,无需通过逐级传导的方式进行回归测试,提高了测试效率,节省了测试时间,从而提升了用户体验;同时,提高了回归测试的计算效率,降低了回归测试的实现复杂度,使得回归测试的实现更加简单。
可选的,在又一个具体应用场景中,本发明实施例提供的基于调用关系网络进行测试的方法可以应用在需要识别多个系统中的重要接口和重要系统的场景中,具体包括如下:
根据接口调用关系网络确定目标系统中每个接口的接口度,根据目标系统中每个接口的接口度计算目标系统中每个接口的接口中心性,根据多个系统中每个接口的接口中心性从多个系统的接口中确定出重要接口;根据系统调用关系网络和接口调用关系网络确定目标系统中的每个接口连接的其他系统的接口,根据目标系统中的每个接口连接的其他系统的接口确定目标系统的系统度,根据目标系统的系统度计算目标系统的系统中心性,根据多个系统中每个系统的系统中心性从多个系统中确定出重要系统。
其中,目标接口是目标系统的接口,目标系统是多个系统中的任一系统。其他系统是多个系统中除目标系统之外的系统。
接口度是接口的度,即在接口调用关系网络中与该接口连接的所有边的数量,表示该接口调用了多少上游接口以及被多少下游接口调用。接口中心性是接口的度中心性,是在网络分析中刻画接口中心性的最直接度量指标,用于表示接口在接口调用关系网络中的重要性;当一个接口的接口度越大时,该接口的接口中心性越高,也即该接口在接口调用关系网络中越重要。重要接口是接口中心性最高或者大于中心性阈值的接口。其中,中心性阈值是预先设置的数值,用户可以根据实际使用需求调整并设置该中心性阈值,本发明实施例对此不做具体限定。
系统度是系统的度,即系统的所有接口连接的其他系统的接口的数量之和,系统度越大,表明该系统与其他系统的交互越频繁。系统中心性是系统的度中心性,是在网络分析中刻画系统中心性的最直接度量指标,用于表示系统在系统调用关系网络中的重要性;当一个系统的系统度越大时,该系统的系统中心性越高,也即该系统在系统调用关系网络中越重要。重要系统是系统中心性最高或者大于中心性阈值的系统。
具体地,在用户想要识别多个系统中的重要接口的任意时刻,可以选取多个系统中的任一系统为目标系统,并获取目标系统中的所有接口,然后根据接口调用关系网络确定目标系统中每个接口的接口度,并根据目标系统中每个接口的接口度计算目标系统中每个接口的接口中心性IN,即:
其中,IN表示接口N的接口中心性,nN表示接口调用关系网络中接口的数量,Ndegree表示该接口N的接口度。
示例性的,如图2所示的接口调用关系网络,图2中接口的数量nN为8,与接口2连接的边的数量为3,即接口2的接口度Ndegree为3,因此,根据上述接口中心性的计算公式可以得到接口2的接口中心性。
之后,选取多个系统中的其他系统为目标系统,并重复上述过程,以得到多个系统中每个接口的接口中心性,并根据多个系统中每个接口的接口中心性确定出重要接口,例如,将每个接口的接口中心性进行比较,选取出接口中心性的最大值,并将接口中心性的最大值对应的接口确定为重要接口;或者,将每个接口的接口中心性与中心性阈值进行比较,并将接口中心性大于中心性阈值的接口确定为重要接口。
同时,在用户想要识别多个系统中的重要系统的任意时刻,可以选取多个系统中的任一系统为目标系统,并根据系统调用关系网络和接口调用关系网络,确定出目标系统中连接其他系统的接口,得到连接接口,接着根据接口调用关系网络确定每一个连接接口的接口度,并计算各个连接接口的接口度之和,得到目标系统的系统度,然后根据目标系统的系统度计算目标系统的系统中心性IS,即:
其中,IS表示系统S的系统中心性,nS表示多个系统中系统的数量,N∈S表示系统S包括的所有接口。αi表示接口N的边是否与其他系统相连,若相连,则αi为1;否则αi为0。表示遍历接口N的所有的边,计算接口N与其他系统相连的边的个数。
示例性的,如图4所示的系统调用关系网络和接口调用关系网络,当确定目标系统为系统S1时,可以得到目标系统S1中连接其他系统的连接接口,即连接接口为接口1、接口2和接口3,并根据接口调用关系网络确定出接口1的接口度为2、接口2的接口度为3和接口3的接口度为2,因此可以得到目标系统S1的系统度为7,即每一个连接接口的接口度之和。最后可以根据上述系统中心性的计算公式得到目标系统S1的系统中心性。
之后,选取多个系统中的其他系统为目标系统,并重复上述过程,以得到多个系统中每个系统的系统中心性,并根据多个系统中每个系统的系统中心性确定出重要系统,例如,可以选取系统中心性的最大值对应的系统或者系统中心性大于中心性阈值的系统为重要系统。
本发明实施例的方案,可以根据接口调用关系确定出每个接口的接口度以及接口中心性,并可以选取接口中心性的最大值对应的接口或者接口中心性大于中心性阈值的接口为重要接口,同时可以根据系统调用关系网络和接口调用关系网络确定出每个系统的系统度以及系统中心性,并可以选取系统中心性的最大值对应的系统或者系统中心性大于中心性阈值的系统为重要系统,实现了根据接口中心性和系统中心性识别重要接口和重要系统的功能,可以在回归测试或者监控系统时重点关注重要接口和重要系统,进而保障系统的稳定运行,从而提升了用户体验;同时,提高了识别重要接口和重要系统的计算效率,降低了识别重要接口和重要系统的实现复杂度,使得识别重要接口和重要系统的实现更加简单。
可选的,在再一个具体应用场景中,本发明实施例提供的基于调用关系网络进行测试的方法可以应用在需要识别多个系统中的关键接口和关键系统的场景中,具体包括如下:
根据接口调用关系网络确定目标系统中每个接口的中介中心性,根据多个系统中每个接口的中介中心性从多个系统的接口中确定出关键接口;根据系统调用关系网络确定目标系统的中介中心性,根据多个系统中每个系统的中介中心性从多个系统中确定出关键系统。
其中,中介中心性是网络中某个节点被其他节点以最短路径通过的数量与网络中最短路径总数量之比,用于衡量节点处于其他任意两个节点的最短路径之中的概率;当一个接口的中介中心性越高时,表明该接口在接口调用关系网络中越关键;当一个系统的中介中心性越高时,表明该系统在系统调用关系网络中越关键。
关键接口为中介中心性最高或者大于中心性阈值的接口。关键系统为中介中心性最高或者大于中心性阈值的系统。
具体地,在用户想要识别多个系统中的关键接口的任意时刻,可以选取多个系统中的任一系统为目标系统,并获取目标系统中的所有接口,然后根据接口调用关系网络确定目标系统中每个接口的中介中心性Cn,即:
其中,Cn表示接口n的中介中心性,σmk(n)代表从接口m到接口k之间的最短路径中经过接口n的最短路径数,σmk表示从接口m到接口k之间的最短路径总数。
之后,选取多个系统中的其他系统为目标系统,并重复上述过程,以得到多个系统中每个接口的中介中心性,并根据多个系统中每个接口的中介中心性确定出关键接口,例如,可以选取中介中心性的最大值对应的接口或者中介中心性大于中心性阈值的接口为关键接口。
同时,在用户想要识别多个系统中的关键系统的任意时刻,可以选取多个系统中的任一系统为目标系统,并根据系统调用关系网络和上述中介中心性的计算公式得到目标系统的中介中心性。之后,选取多个系统中的其他系统为目标系统,并重复上述过程,以得到多个系统中每个系统的中介中心性,并根据多个系统中每个系统的中介中心性确定出关键系统,例如,可以选取中介中心性的最大值对应的系统或者中介中心性大于中心性阈值的系统为关键系统。
本发明实施例的方案,可以根据接口调用关系确定出每个接口的中介中心性,并可以选取中介中心性的最大值对应的接口或者中介中心性大于中心性阈值的接口为关键接口,同时可以根据系统调用关系网络确定出每个系统的中介中心性,并可以选取中介中心性的最大值对应的系统或者中介中心性大于中心性阈值的系统为关键系统,实现了根据中介中心性识别关键接口和关键系统的功能,可以在回归测试或者监控系统时重点关注关键接口和关键系统,进而保障系统的稳定运行,从而提升了用户体验;同时,提高了识别关键接口和关键系统的计算效率,降低了识别关键接口和关键系统的实现复杂度,使得识别关键接口和关键系统的实现更加简单。
图5是本发明实施例提供的基于调用关系网络进行测试的装置的一个结构示意图,该装置适用于执行本发明实施例提供的基于调用关系网络进行测试的方法,如图5所示,该装置具体可以包括:
第一确定模块510,用于确定目标接口;
第二确定模块520,用于查询预先建立的接口调用关系网络确定目标接口的关联接口,关联接口包括目标接口的直接接口和间接接口,直接接口为与目标接口直接连接的接口,间接接口为与目标接口间接连接的接口,接口调用关系网络包括节点和边,节点包括多个系统中的接口,边包括多个系统中的接口的连接关系;
测试模块530,用于对关联接口进行测试。
一实施例中,第一确定模块510具体用于:
对多个系统中的接口进行监测,当监测到报错接口时,将报错接口确定为目标接口。
一实施例中,测试模块530具体用于:
对直接接口进行故障定位测试;
若直接接口正常,则对间接接口进行故障定位测试。
一实施例中,第一确定模块510还用于:
从多个系统的接口中确定出技改接口,将技改接口确定为目标接口。
一实施例中,测试模块530还用于:
确定关联接口所在的系统,得到关联系统;
通知关联系统对对应的关联接口进行回归测试。
一实施例中,目标接口是目标系统的接口,目标系统是多个系统中的系统,该装置还包括第三确定模块,第三确定模块具体用于:
根据接口调用关系网络确定目标系统中每个接口的接口度,根据目标系统中每个接口的接口度计算目标系统中每个接口的接口中心性,根据多个系统中每个接口的接口中心性从多个系统的接口中确定出重要接口;
根据系统调用关系网络和接口调用关系网络确定目标系统中的每个接口连接的其他系统的接口,根据目标系统中的每个接口连接的其他系统的接口确定目标系统的系统度,根据目标系统的系统度计算目标系统的系统中心性,根据多个系统中每个系统的系统中心性从多个系统中确定出重要系统,其他系统是多个系统中除目标系统之外的系统;
其中,系统调用关系网络包括节点和边,节点包括多个系统,边包括根据接口调用关系网络确定的多个系统的连接关系。
一实施例中,该装置还包括第四确定模块,第四确定模块具体用于:
根据接口调用关系网络确定目标系统中每个接口的中介中心性,根据多个系统中每个接口的中介中心性从多个系统的接口中确定出关键接口;
根据系统调用关系网络确定目标系统的中介中心性,根据多个系统中每个系统的中介中心性从多个系统中确定出关键系统。
本领域的技术人员可以清楚地了解到,为描述的方便和简洁,仅以上述各功能模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能模块完成,即将装置的内部结构划分成不同的功能模块,以完成以上描述的全部或者部分功能。上述描述功能模块的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
本发明实施例的装置,可以确定目标接口;查询预先建立的接口调用关系网络确定目标接口的关联接口;对关联接口进行测试。上述技术方案中,首先从多个系统所包含的接口中确定出目标接口,例如,可以对多个系统所包含的接口进行监测,并将报错的接口确定为目标接口,或者,可以将多个系统中进行技术改造的系统接口确定为目标接口;然后从预先建立的接口调用关系网络中查询出目标接口的关联接口,即与目标接口存在直接调用关系的直接接口,以及与目标接口存在间接调用关系的间接接口,最后对关联接口所包含的直接接口和间接接口进行测试,实现了基于接口调用关系网络对系统中的接口进行测试的功能,使得测试人员可以从全链路测试角度对系统进行测试,提高了测试效率,避免了点对点管理形式存在的测试效率较低的问题;同时,可以直接对目标接口的直接接口和间接接口进行测试,无需通过逐级传导的方式进行测试,节省了测试时间,进一步提高了测试效率,从而提升了用户体验。
图6是本发明实施例提供的电子设备的一个结构示意图。图6示出了适于用来实现本发明实施方式的示例性电子设备11的框图。图6显示的电子设备11仅仅是一个示例,不应对本实施例的功能和使用范围带来任何限制。
如图6所示,电子设备11以通用计算电子设备的形式表现。电子设备11的组件可以包括但不限于:一个或者多个处理器或者处理单元16,系统存储器28,连接不同系统组件(包括系统存储器28和处理单元16)的总线18。
总线18表示几类总线结构中的一种或多种,包括存储器总线或者存储器控制器,外围总线,图形加速端口,处理器或者使用多种总线结构中的任意总线结构的局域总线。举例来说,这些体系结构包括但不限于工业标准体系结构(ISA)总线,微通道体系结构(MAC)总线,增强型ISA总线、视频电子标准协会(VESA)局域总线以及外围组件互连(PCI)总线。
电子设备11典型地包括多种计算机系统可读介质。这些介质可以是任何能够被电子设备11访问的可用介质,包括易失性和非易失性介质,可移动的和不可移动的介质。
系统存储器28可以包括易失性存储器形式的计算机系统可读介质,例如随机存取存储器(RAM)30和/或高速缓存存储器32。电子设备11可以进一步包括其它可移动/不可移动的、易失性/非易失性计算机系统存储介质。仅作为举例,存储系统34可以用于读写不可移动的、非易失性磁介质(图6未显示,通常称为“硬盘驱动器”)。尽管图6中未示出,可以提供用于对可移动非易失性磁盘(例如“软盘”)读写的磁盘驱动器,以及对可移动非易失性光盘(例如CD-ROM,DVD-ROM或者其它光介质)读写的光盘驱动器。在这些情况下,每个驱动器可以通过一个或者多个数据介质接口与总线18相连。系统存储器28可以包括至少一个程序产品,该程序产品具有一组(例如至少一个)程序模块,这些程序模块被配置以执行本发明各实施例的功能。
具有一组(至少一个)程序模块42的程序/实用工具40,可以存储在例如系统存储器28中,这样的程序模块42包括但不限于操作系统、一个或者多个应用程序、其它程序模块以及程序数据,这些示例中的每一个或某种组合中可能包括网络环境的实现。程序模块42通常执行本发明所描述的实施例中的功能和/或方法。
电子设备11也可以与一个或多个外部设备14(例如键盘、指向设备、显示器24等)通信,还可与一个或者多个使得用户能与该电子设备11交互的设备通信,和/或与使得该电子设备11能与一个或多个其它计算设备进行通信的任何设备(例如网卡,调制解调器等)通信。这种通信可以通过输入/输出(I/O)接口22进行。并且,电子设备11还可以通过网络适配器20与一个或者多个网络(例如局域网(LAN),广域网(WAN)和/或公共网络,例如因特网)通信。
如图6所示,网络适配器20通过总线18与电子设备11的其它模块通信。应当明白,尽管图6中未示出,可以结合电子设备11使用其它硬件和/或软件模块,包括但不限于:微代码、设备驱动器、冗余处理单元、外部磁盘驱动阵列、RAID系统、磁带驱动器以及数据备份存储系统等。
处理单元16通过运行存储在系统存储器28中的程序,从而执行各种功能应用以及页面显示,例如实现本实施例所提供的基于调用关系网络进行测试的方法,该方法包括:
确定目标接口;
查询预先建立的接口调用关系网络确定目标接口的关联接口,关联接口包括目标接口的直接接口和间接接口,直接接口为与目标接口直接连接的接口,间接接口为与目标接口间接连接的接口,接口调用关系网络包括节点和边,节点包括多个系统中的接口,边包括多个系统中的接口的连接关系;
对关联接口进行测试。
当然,本领域技术人员可以理解,处理器还可以实现本发明任意实施例所提供的基于调用关系网络进行测试的方法的技术方案。
本发明提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现例如本发明所提供的基于调用关系网络进行测试的方法,该方法包括:
确定目标接口;
查询预先建立的接口调用关系网络确定目标接口的关联接口,关联接口包括目标接口的直接接口和间接接口,直接接口为与目标接口直接连接的接口,间接接口为与目标接口间接连接的接口,接口调用关系网络包括节点和边,节点包括多个系统中的接口,边包括多个系统中的接口的连接关系;
对关联接口进行测试。
本实施例的计算机存储介质,可以采用一个或者多个计算机可读的介质的任意组合。计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质。计算机可读存储介质例如可以是但不限于:电、磁、光、电磁、红外线、或者半导体的系统、装置或者器件,或者任意以上的组合。计算机可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或者多个导线的电连接、便携式计算机磁盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或者闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本文件中,计算机可读存储介质可以是任何包含或者存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。
计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或者上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。
计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、RF等等,或者上述的任意合适的组合。
可以以一种或者多种程序设计语言或者其组合来编写用于执行本发明操作的计算机程序代码,程序设计语言包括面向对象的程序设计语言,诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如“C”语言或者类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或者服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络,包括局域网(LAN)或者广域网(WAN),连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
本领域普通技术人员应该明白,上述的本发明的各模块或者各步骤可以用通用的计算装置来实现,它们可以集中在单个计算装置上,或者分布在多个计算装置所组成的网络上,可选地,他们可以用计算机装置可执行的程序代码来实现,从而可以将它们存储在存储装置中由计算装置来执行,或者将它们分别制作成各个集成电路模块,或者将它们中的多个模块或者步骤制作成单个集成电路模块来实现。这样,本发明不限制于任何特定的硬件和软件的结合。
另外,本发明技术方案中对数据的获取、存储、使用、处理等均符合国家法律法规的相关规定。
注意,上述仅为本发明的较佳实施例及所运用技术原理。本领域技术人员会理解,本发明不限于这里的特定实施例,对本领域技术人员来说能够进行各种明显的变化、重新调整和替代而不会脱离本发明的保护范围。因此,虽然通过以上实施例对本发明进行了较为详细的说明,但是本发明不仅仅限于以上实施例,在不脱离本发明构思的情况下,还可以包括更多其他等效实施例,而本发明的范围由所附的权利要求范围决定。

Claims (10)

1.一种基于调用关系网络进行测试的方法,其特征在于,所述方法包括:
确定目标接口;
查询预先建立的接口调用关系网络确定所述目标接口的关联接口,所述关联接口包括所述目标接口的直接接口和间接接口,所述直接接口为与所述目标接口直接连接的接口,所述间接接口为与所述目标接口间接连接的接口,所述接口调用关系网络包括节点和边,所述节点包括多个系统中的接口,所述边包括所述多个系统中的接口的连接关系;
对所述关联接口进行测试。
2.根据权利要求1所述的方法,其特征在于,所述确定目标接口,包括:
对所述多个系统中的接口进行监测,当监测到报错接口时,将所述报错接口确定为所述目标接口。
3.根据权利要求2所述的方法,其特征在于,所述对所述关联接口进行测试,包括:
对所述直接接口进行故障定位测试;
若所述直接接口正常,则对所述间接接口进行故障定位测试。
4.根据权利要求1所述的方法,其特征在于,所述确定目标接口,包括:
从所述多个系统的接口中确定出技改接口,将所述技改接口确定为所述目标接口。
5.根据权利要求4所述的方法,其特征在于,所述对所述关联接口进行测试,包括:
确定所述关联接口所在的系统,得到关联系统;
通知所述关联系统对对应的关联接口进行回归测试。
6.根据权利要求1所述的方法,其特征在于,所述目标接口是目标系统的接口,所述目标系统是所述多个系统中的系统,所述方法还包括:
根据所述接口调用关系网络确定所述目标系统中每个接口的接口度,根据所述目标系统中每个接口的接口度计算所述目标系统中每个接口的接口中心性,根据所述多个系统中每个接口的接口中心性从所述多个系统的接口中确定出重要接口;
根据系统调用关系网络和所述接口调用关系网络确定所述目标系统中的每个接口连接的其他系统的接口,根据所述目标系统中的每个接口连接的其他系统的接口确定所述目标系统的系统度,根据所述目标系统的系统度计算所述目标系统的系统中心性,根据所述多个系统中每个系统的系统中心性从所述多个系统中确定出重要系统,所述其他系统是所述多个系统中除所述目标系统之外的系统;
其中,所述系统调用关系网络包括节点和边,所述节点包括所述多个系统,所述边包括根据所述接口调用关系网络确定的所述多个系统的连接关系。
7.根据权利要求6所述的方法,其特征在于,所述方法还包括:
根据所述接口调用关系网络确定所述目标系统中每个接口的中介中心性,根据所述多个系统中每个接口的中介中心性从所述多个系统的接口中确定出关键接口;
根据所述系统调用关系网络确定所述目标系统的中介中心性,根据所述多个系统中每个系统的中介中心性从所述多个系统中确定出关键系统。
8.一种基于调用关系网络进行测试的装置,其特征在于,所述装置包括:
第一确定模块,用于确定目标接口;
第二确定模块,用于查询预先建立的接口调用关系网络确定所述目标接口的关联接口,所述关联接口包括所述目标接口的直接接口和间接接口,所述直接接口为与所述目标接口直接连接的接口,所述间接接口为与所述目标接口间接连接的接口,所述接口调用关系网络包括节点和边,所述节点包括多个系统中的接口,所述边包括所述多个系统中的接口的连接关系;
测试模块,用于对所述关联接口进行测试。
9.一种电子设备,包括存储器、处理器及存储在所述存储器上并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述程序时实现如权利要求1至7中任一项所述的基于调用关系网络进行测试的方法。
10.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1至7中任一项所述的基于调用关系网络进行测试的方法。
CN202311649917.XA 2023-12-04 2023-12-04 基于调用关系网络进行测试的方法、装置、设备和介质 Pending CN117609079A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202311649917.XA CN117609079A (zh) 2023-12-04 2023-12-04 基于调用关系网络进行测试的方法、装置、设备和介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202311649917.XA CN117609079A (zh) 2023-12-04 2023-12-04 基于调用关系网络进行测试的方法、装置、设备和介质

Publications (1)

Publication Number Publication Date
CN117609079A true CN117609079A (zh) 2024-02-27

Family

ID=89959547

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202311649917.XA Pending CN117609079A (zh) 2023-12-04 2023-12-04 基于调用关系网络进行测试的方法、装置、设备和介质

Country Status (1)

Country Link
CN (1) CN117609079A (zh)

Similar Documents

Publication Publication Date Title
CN108388489B (zh) 一种服务器故障诊断方法、系统、设备及存储介质
CN109960635B (zh) 实时计算平台的监控和报警方法、系统、设备及存储介质
CN108322320B (zh) 业务生存性分析方法及装置
CN110178121B (zh) 一种数据库的检测方法及其终端
CN110647447A (zh) 用于分布式系统的异常实例检测方法、装置、设备和介质
CN113657715A (zh) 一种基于核密度估计调用链的根因定位方法及系统
CN110674034A (zh) 一种健康检查方法、装置及电子设备和存储介质
CN115373888A (zh) 故障定位方法、装置、电子设备和存储介质
CN110515758B (zh) 一种故障定位方法、装置、计算机设备及存储介质
CN113518367B (zh) 5g网络切片下基于服务特征的故障诊断方法及系统
CN114257493A (zh) 网络节点的故障预警方法、装置、介质及电子设备
CN112966056A (zh) 一种信息处理方法、装置、设备、系统及可读存储介质
CN110688305B (zh) 测试环境同步方法、装置、介质、电子设备
CN116737491A (zh) 异常监控方法、装置、设备、介质及产品
CN117609079A (zh) 基于调用关系网络进行测试的方法、装置、设备和介质
CN114706371A (zh) 整车网络不休眠诊断方法、装置、电子设备及存储介质
CN113887101A (zh) 网络模型的可视化方法、装置、电子设备及存储介质
CN112579402A (zh) 一种应用系统故障定位的方法和装置
CN113590424B (zh) 一种故障监控方法、装置、设备及存储介质
CN109901997B (zh) 金融系统升级方法及装置、电子设备、存储介质
CN117714515A (zh) 一种远程调试方法、装置、设备及存储介质
CN114385476A (zh) 性能测试结果分析方法、装置、电子设备以及存储介质
CN112711487A (zh) 数据源管控方法、装置、管控服务器及存储介质
CN113760590A (zh) 故障处理方法、装置、电子设备和计算机可读介质
CN117061455A (zh) 一种数据中心算网资源管理方法、系统及计算装置

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination