CN112306851A - 一种自动化测试方法和装置 - Google Patents
一种自动化测试方法和装置 Download PDFInfo
- Publication number
- CN112306851A CN112306851A CN201910706775.3A CN201910706775A CN112306851A CN 112306851 A CN112306851 A CN 112306851A CN 201910706775 A CN201910706775 A CN 201910706775A CN 112306851 A CN112306851 A CN 112306851A
- Authority
- CN
- China
- Prior art keywords
- test
- test instruction
- tested
- equipment
- receiving
- 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
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/36—Preventing errors by testing or debugging software
- G06F11/3668—Software testing
- G06F11/3672—Test management
- G06F11/3688—Test management for test execution, e.g. scheduling of test suites
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/36—Preventing errors by testing or debugging software
- G06F11/3664—Environments for testing or debugging software
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/36—Preventing errors by testing or debugging software
- G06F11/3668—Software testing
- G06F11/3672—Test management
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)
- Debugging And Monitoring (AREA)
Abstract
本发明公开了自动化测试方法和装置,涉及计算机技术领域。该方法的一具体实施方式包括接收脚本执行机发送的测试指令,根据测试指令中携带的被测设备编码,查找对应的测试节点;将测试指令转发给对应的测试节点,以使测试节点将测试指令发送至与之对应的被测设备;接收被测设备执行测试指令的结果,并返回给脚本执行机。从而,本发明的实施方式能够实现对大量设备进行远程自动化测试。
Description
技术领域
本发明涉及计算机技术领域,尤其涉及一种自动化测试方法和装置。
背景技术
目前市面上手机及其它智能设备越来越多,针对这些设备上的应用进行自动化测试时,希望能够覆盖更多的设备,以提高应用的兼容性。然而,被测设备通常价格较高,尤其是一些自主研发的硬件设备,难以保证测试人员人手一套,需要有一套灵活、高效的***和方法,来管理现有的被测设备,对其进行充分利用。
在实现本发明过程中,发明人发现现有技术中至少存在如下问题:
目前在自动化测试时,对被测设备的部署,主要有以下几种方案:将设备通过USB线连接在本地电脑,直接在本地电脑执行测试脚本。或者将设备通过USB线连接到服务器,并把自动化脚本发送到该服务器上去执行。还或者利用云测试平台(例如testin,mtc等)提供多种设备用来测试,可将测试脚本发送至平台,并选择相应的设备来执行。
显而易见的,对于第一种测试人员需要不停的对设备进行借出和归还,效率很低。对于第二种,因为公司内网的限制,电脑之间无法互相访问,服务器只能放在机房,而被测设备无法放进机房去管理。对于第三种,可提供大量的设备供测试,但基于安全考虑公司内部的应用不便于放到外部去测试,同时对于自主研发的硬件设备,云测试平台也无法提供测试。
发明内容
有鉴于此,本发明实施例提供一种自动化测试方法和装置,能够实现对大量设备进行远程自动化测试。
为实现上述目的,根据本发明实施例的一个方面,提供了一种自动化测试方法,包括接收脚本执行机发送的测试指令,根据测试指令中携带的被测设备编码,查找对应的测试节点;将测试指令转发给对应的测试节点,以使测试节点将测试指令发送至与之对应的被测设备;接收被测设备执行测试指令的结果,并返回给脚本执行机。
可选地,接收脚本执行机发送的测试指令之后,包括:
根据测试指令中携带的被测设备编码,查询被测设备是否空闲,若是则占用被测设备,否则在预设的可超时时间内,定时查询被测设备是否空闲;
接收被测设备执行测试指令的结果之后,包括:释放被测设备。
可选地,所述占用被测设备,包括:
调用设备远程管理***的接口,将用户标识上传至设备远程管理***,以占用被测设备;其中,用户标识为任意字符串,在设备远程管理***的页面中生成,且与用户账号关联。
可选地,接收脚本执行机发送的测试指令之前,包括:
接收脚本执行机的连接请求,进而与脚本执行机建立连接;其中,根据脚本中的配置信息,与脚本执行机建立连接。
另外,根据本发明实施例的一个方面,提供了一种自动化测试装置,包括接收模块,用于接收脚本执行机发送的测试指令,根据测试指令中携带的被测设备编码,查找对应的测试节点;转发模块,用于将测试指令转发给对应的测试节点,以使测试节点将测试指令发送至与之对应的被测设备;返回模块,用于接收被测设备执行测试指令的结果,并返回给脚本执行机。
可选地,所述接收模块接收脚本执行机发送的测试指令之后,包括:
根据测试指令中携带的被测设备编码,查询被测设备是否空闲,若是则占用被测设备,否则在预设的可超时时间内,定时查询被测设备是否空闲;
所述返回模块接收被测设备执行测试指令的结果之后,包括:释放被测设备。
可选地,所述接收模块占用被测设备,包括:
调用设备远程管理***的接口,将用户标识上传至设备远程管理***,以占用被测设备;其中,用户标识为任意字符串,在设备远程管理***的页面中生成,且与用户账号关联。
可选地,所述接收模块接收脚本执行机发送的测试指令之前,包括:
接收脚本执行机的连接请求,进而与脚本执行机建立连接;其中,根据脚本中的配置信息,与脚本执行机建立连接。
根据本发明实施例的另一个方面,还提供了一种电子设备,包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现上述任一自动化测试实施例所述的方法。
根据本发明实施例的另一个方面,还提供了一种计算机可读介质,其上存储有计算机程序,所述程序被处理器执行时实现上述任一基于自动化测试实施例所述的方法。
上述发明中的一个实施例具有如下优点或有益效果:本发明通过接收脚本执行机发送的测试指令,根据测试指令中携带的被测设备编码,查找对应的测试节点;将测试指令转发给对应的测试节点,以使测试节点将测试指令发送至与之对应的被测设备;接收被测设备执行测试指令的结果,并返回给脚本执行机。因此,本发明能够可以在远程设备上执行本地测试脚本,并且使测试设备易于管理和维护,且利用率达到最大化。
上述的非惯用的可选方式所具有的进一步效果将在下文中结合具体实施方式加以说明。
附图说明
附图用于更好地理解本发明,不构成对本发明的不当限定。其中:
图1是根据本发明实施例的自动化测试方法的主要流程的示意图;
图2是根据本发明一个实施例的远程脚本分发***的示意图;
图3是根据本发明另一实施例的自动化测试方法的主要流程的示意图;
图4是根据本发明又一实施例的自动化测试方法的主要流程的示意图;
图5是根据本发明再一实施例的自动化测试方法的主要流程的示意图;
图6是根据本发明实施例的自动化测试装置的主要模块的示意图;
图7是本发明实施例可以应用于其中的示例性***架构图;
图8是适于用来实现本发明实施例的终端设备或服务器的计算机***的结构示意图。
具体实施方式
以下结合附图对本发明的示范性实施例做出说明,其中包括本发明实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本发明的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
图1是根据本发明第一实施例的自动化测试方法的主要流程的示意图,基于远程服务器,所述自动化测试方法可以包括:
步骤S101,接收脚本执行机发送的测试指令,根据测试指令中携带的被测设备编码,查找对应的测试节点。
较佳地,由于本发明特别可以针对大量被测设备进行自动化测试,创造性地为了防止设备使用冲突,以及有效管理被测设备,在执行步骤S101接收脚本执行机发送的测试指令之后,可以根据测试指令中携带的被测设备编码,查询被测设备是否空闲。根据查询结果,如果空闲则占用被测设备,如果不空闲则在预设的可超时时间内,定时查询被测设备是否空闲。
进一步地,如果在可超时时间内被测设备一直繁忙(不空闲),则结束此次测试操作,并标记原因。
作为可参考的实施例,在执行步骤S101之前可以先接收脚本执行机的连接请求,进而与脚本执行机建立连接。其中,根据脚本中的配置信息,与脚本执行机建立连接。
所述的配置信息是Appium框架(Appium是由nodejs的express框架写的HttpServer)的服务器初始化参数(Desired Capabilities),例如UDID是被测设备编码,具有唯一性。当与远程服务器(远程服务器可以作为Selenium Grid Hub,接受测试指令的入口)建立连接时,通过该配置信息远程服务器可获得必要的一些参数信息。
值得说明的是,Selenium Grid是一款支持分布式测试的工具,分为SeleniumGrid Hub和Selenium Grid Node两种角色。其中Selenium Grid Hub是中心,只有一个,Selenium Grid Node是节点,可以有多个,Selenium Grid Hub接收要执行的测试信息,包括在哪些平台和哪些设备执行等。Selenium Grid Hub知道每个注册了的Selenium GridNode的配置。根据测试信息,Selenium Grid Hub选择符合需求的Selenium Grid Node进行测试。在该实施例中,因为测试指令中指定了设备的UDID(设备唯一编号),进而SeleniumGrid Hub能够确保将脚本准确的分发到指定被测设备上执行。
另外,若干个测试节点可以设置在一个本地服务器上,Selenium Grid Node(测试节点)与被测设备一一对应。进一步地,每台本地服务器可以通过USB hub连接多个被测设备。
步骤S102,将测试指令转发给对应的测试节点,以使测试节点将测试指令发送至与之对应的被测设备。
步骤S103,接收被测设备执行测试指令的结果,并返回给脚本执行机。
较佳地,如果在执行步骤S101接收脚本执行机发送的测试指令之后占用了被测设备,则在执行步骤S103接收被测设备执行测试指令的结果之后便可以释放被测设备。
值得说明的是,本发明采用了设备远程管理***对被测设备进行占用或释放,具体的实施过程包括:调用设备远程管理***的接口,将用户标识上传至设备远程管理***,以占用被测设备。
其中,用户标识为任意字符串,在设备远程管理***的页面中生成,且与用户账号关联。而用户为测试人员,用户账号是每名测试人员在设备远程管理***上的一个账号。
另外,设备远程管理***例如STF等等,优选地,本发明采用了STF***。STF(smartphone test farm)是一套开源的Android设备远程管理***。
作为一个具体的实施例,如图2所示,Test Script Executor是脚本执行机,Selenium Grid Hub Service是远程服务器,Service in office1……n是指本地服务器1……本地服务器n。其中,在每个本地服务器上设置有n个Selenium Grid Node Service,而每一个Selenium Grid Node Service对应一个被测设备。
作为更进一步地具体实施例,设备远程管理***可以基于STF搭建,STF(smartphone test farm)是一款能够通过浏览器远程管理智能设备的开源***,STF***的架构采用了微服务架构。其中,本地执行脚本的办公电脑,可以通过浏览器访问STF***,远程观看设备画面,以及远程控制设备。本地连接被测设备的服务器,即本地服务器可以有多个。在机房中的服务器,即远程服务器,STF主服务各模块都部署在远程服务器上。
较佳地,如果STF***中连接被测设备的服务器是Windows***,并不支持STF服务的部署。因此,可以将Provider模块同样部署在远程服务器上,并且将远程服务器上的adbclient连接到本地服务器上的adb server(通过adb的–H参数指定adbhost),从而实现了stf-provider模块和被测设备的分离。
其中,adb是Android调试桥(Android Debug Bridge)一个通用命令行工具,其允许与模拟器实例或连接的Android设备进行通信。adb主要分为三个部分:
adb daemon:后台程序,该组件在Android设备上运行,当打开Android设备的开发者模式,并启用USB调试功能后,Android设备或模拟器就会运行一个adb dadmon进程。
adb server:该组件管理客户端和后台程序之间的通信。服务器在开发计算机上作为后台进程运行。
adb client:该组件发送命令。客户端在开发计算机上运行。您可以通过adb命令从命令行终端调用客户端。adb client默认与本机的adb server通信,也可以通过指定参数与远程机器的adb server通信。
因此,根据上面所述的各种实施例,本发明通过机房中转服务器进行STF部署以及脚本分发,突破了办公网内不可互相访问的限制,同时做到被测设备可以安置在工位上,便于对大量被测设备的管理。同时在远程执行自动化脚本的过程中,引入STF的接口对远程设备进行占用和释放,避免设备使用冲突。
图3是根据本发明另一实施例的自动化测试方法的主要流程的示意图,基于远程服务器,所述自动化测试方法可以包括:
步骤S301,接收脚本执行机的连接请求,进而与脚本执行机建立连接。
在实施例中,根据脚本中的配置信息,与脚本执行机建立连接。
步骤S302,接收脚本执行机发送的测试指令。
步骤S303,根据测试指令中携带的被测设备编码,查询被测设备是否空闲,若是则进行步骤S304,否则在预设的可超时时间内,定时查询被测设备是否空闲,即在预设的可超时时间内,定时执行步骤S303。
步骤S304,调用设备远程管理***的接口,将用户标识上传至设备远程管理***,以占用被测设备。
步骤S305,根据测试指令中携带的被测设备编码,查找对应的测试节点。
步骤S306,将测试指令转发给对应的测试节点,以使测试节点将测试指令发送至与之对应的被测设备。
步骤S307,接收被测设备执行测试指令的结果。
步骤S308,调用设备远程管理***的接口,释放被测设备。
步骤S309,返回执行测试指令的结果至脚本执行机。
图4是根据本发明又一实施例的自动化测试方法的主要流程的示意图,基于脚本执行机、远程服务器和本地服务器,所述自动化测试方法可以包括:
步骤S401,脚本执行机根据脚本中的配置信息,与远程服务器建立连接。
在实施例中,当脚本执行机开始执行脚本时,会根据脚本中的配置信息,与远程服务器建立连接。
较佳地,个人办公电脑作为脚本执行机,以执行测试脚本。远程服务器可以放置在远程机房中。
其中,所述的配置信息是Appium框架(Appium是由nodejs的express框架写的HttpServer)的服务器初始化参数(Desired Capabilities),例如UDID是被测设备编码,具有唯一性。当与远程服务器(远程服务器可以作为Selenium Grid Hub,接受测试指令的入口)建立连接时,通过该配置信息远程服务器可获得必要的一些参数信息。
步骤S402,脚本执行机将脚本中的测试指令发送给远程服务器(Selenium GridHub)。
其中,所述的脚本中测试指令是测试过程中对被测设备的具体操作。例如:点击某个按钮,输入某些文字等等。
步骤S403,远程服务器根据测试指令中携带的被测设备编码,查找对应的测试节点。
在实施例中,远程服务器根据测试指令中携带的Capability信息,指定了被测设备编码UDID,该被测设备编码UDID具备唯一性,从而确保每条测试指令都能准确发送到指定的被测设备上。其中,Selenium Grid Node(测试节点)与被测设备一一对应。
步骤S404,远程服务器将测试指令转发给对应的测试节点(Selenium GridNode),进而测试节点(Selenium Grid Node)再将测试指令发送至与之对应的被测设备上。
在实施例中,本地服务器上启动若干Selenium Grid Node服务,每个服务与一台被测设备关联,并注册到远程服务器(Selenium Grid Hub)上。
步骤S405,被测设备执行测试指令,并将执行结果返回给脚本执行机。
在实施例中,被测设备将执行结果依次通过测试节点、远程服务器返回给脚本执行机。
图5是根据本发明再一实施例的自动化测试方法的主要流程的示意图,基于脚本执行机、远程服务器和本地服务器,所述自动化测试方法可以包括:
步骤501,脚本执行机根据脚本中的配置信息,与远程服务器建立连接。
步骤S502,脚本执行机将脚本中的测试指令发送给远程服务器。
步骤S503,远程服务器根据测试指令中携带的被测设备编码,查询被测设备是否空闲,若是则进行步骤S504,否则在预设的可超时时间内,定时查询被测设备是否空闲。
较佳地,远程服务器根据测试指令中携带的被测设备编码,通过设备远程管理***(例如STF)提供的接口查询被测设备是否空闲。进一步地,如果通过设备远程管理***(例如STF)提供的接口查询被测设备不空闲,则在预先设定的可超时时间内,每隔一段时间就根据测试指令中携带的被测设备编码,通过设备远程管理***(例如STF)提供的接口查询被测设备是否空闲,一旦被测设备空闲,继续执行步骤S504。
优选地,如果在可超时时间内被测设备一直繁忙,则结束测试(退出该流程),并标记原因。
作为一个具体实施例,可以通过STF***提供的HTTP接口,在测试脚本中对被测设备进行占用和释放,避免了多脚本执行时可能发生的冲突。
步骤S504,远程服务器占用被测设备。
较佳地,远程服务器调用设备远程管理***(例如STF)的接口占用被测设备。
进一步地,远程服务器调用设备远程管理***的接口占用被测设备时,需要将用户token上传至设备远程管理***,该用户token可以在设备远程管理***的页面中生成,与用户账号关联。远程服务器占用该被测设备后,设备远程管理***的页面上可以显示该被测设备正在被哪个用户使用,且其他用户无法使用。
其中,所述的用户为测试人员,而用户账号是每名测试人员在设备远程管理***上的一个账号。token是任意字符串。
另外,STF(smartphone test farm)是一套开源的Android设备远程管理***。
步骤S505,远程服务器根据测试指令中携带的被测设备编码,查找对应的测试节点。
步骤S506,远程服务器将测试指令转发给对应的测试节点,进而测试节点再将测试指令发送至与之对应的被测设备上。
步骤S507,被测设备执行测试指令,并将执行结果返回给脚本执行机。
在实施例中,被测设备将执行结果依次通过测试节点、远程服务器返回给脚本执行机。
步骤S508,远程服务器释放被测设备。
图6是根据本发明实施例的自动化测试装置,如图6所示,所述自动化测试装置600包括接收模块601、转发模块602和返回模块603。其中,接收模块601接收脚本执行机发送的测试指令,根据测试指令中携带的被测设备编码,查找对应的测试节点。转发模块602将测试指令转发给对应的测试节点,以使测试节点将测试指令发送至与之对应的被测设备。返回模块603接收被测设备执行测试指令的结果,并返回给脚本执行机。
作为一个较佳地实施例,所述接收模块601接收脚本执行机发送的测试指令之后,可以根据测试指令中携带的被测设备编码,查询被测设备是否空闲,若是则占用被测设备,根据测试指令中携带的被测设备编码,查找对应的测试节点。否则在预设的可超时时间内,定时查询被测设备是否空闲。
另外,所述返回模块603接收被测设备执行测试指令的结果之后,可以释放被测设备。
进一步地实施例,所述接收模块601占用被测设备时,可以调用设备远程管理***的接口,将用户标识上传至设备远程管理***,以占用被测设备。其中,用户标识为任意字符串,在设备远程管理***的页面中生成,且与用户账号关联。
还值得说明的是,所述接收模块601接收脚本执行机发送的测试指令之前,需要接收脚本执行机的连接请求,进而与脚本执行机建立连接。其中,根据脚本中的配置信息,与脚本执行机建立连接。
需要说明的是,在本发明所述自动化测试方法和所述自动化测试装置在具体实施内容上具有相应关系,故重复内容不再说明。
图7示出了可以应用本发明实施例的自动化测试方法或自动化测试装置的示例性***架构700。
如图7所示,***架构700可以包括终端设备701、702、703,网络704和服务器705。网络704用以在终端设备701、702、703和服务器705之间提供通信链路的介质。网络704可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户可以使用终端设备701、702、703通过网络704与服务器705交互,以接收或发送消息等。终端设备701、702、703上可以安装有各种通讯客户端应用,例如购物类应用、网页浏览器应用、搜索类应用、即时通信工具、邮箱客户端、社交平台软件等(仅为示例)。
终端设备701、702、703可以是具有显示屏并且支持网页浏览的各种电子设备,包括但不限于智能手机、平板电脑、膝上型便携计算机和台式计算机等等。
服务器705可以是提供各种服务的服务器,例如对用户利用终端设备701、702、703所浏览的购物类网站提供支持的后台管理服务器(仅为示例)。后台管理服务器可以对接收到的产品信息查询请求等数据进行分析等处理,并将处理结果(例如目标推送信息、产品信息--仅为示例)反馈给终端设备。
需要说明的是,本发明实施例所提供的自动化测试方法一般由服务器705执行,相应地,自动化测试装置一般设置于服务器705中。
应该理解,图7中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
下面参考图8,其示出了适于用来实现本发明实施例的终端设备的计算机***800的结构示意图。图8示出的终端设备仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图8所示,计算机***1100包括中央处理单元(CPU)801,其可以根据存储在只读存储器(ROM)802中的程序或者从存储部分1108加载到随机访问存储器(RAM)803中的程序而执行各种适当的动作和处理。在RAM803中,还存储有***800操作所需的各种程序和数据。CPU801、ROM802以及RAM803通过总线804彼此相连。输入/输出(I/O)接口805也连接至总线804。
以下部件连接至I/O接口805:包括键盘、鼠标等的输入部分806;包括诸如阴极射线管(CRT)、液晶显示器(LCD)等以及扬声器等的输出部分807;包括硬盘等的存储部分808;以及包括诸如LAN卡、调制解调器等的网络接口卡的通信部分809。通信部分809经由诸如因特网的网络执行通信处理。驱动器810也根据需要连接至I/O接口805。可拆卸介质811,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器810上,以便于从其上读出的计算机程序根据需要被安装入存储部分808。
特别地,根据本发明公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本发明公开的实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分809从网络上被下载和安装,和/或从可拆卸介质811被安装。在该计算机程序被中央处理单元(CPU)801执行时,执行本发明的***中限定的上述功能。
需要说明的是,本发明所示的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的***、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本发明中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行***、装置或者器件使用或者与其结合使用。而在本发明中,计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行***、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、RF等等,或者上述的任意合适的组合。
附图中的流程图和框图,图示了按照本发明各种实施例的***、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,上述模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图或流程图中的每个方框、以及框图或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的***来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本发明实施例中所涉及到的模块可以通过软件的方式实现,也可以通过硬件的方式来实现。所描述的模块也可以设置在处理器中,例如,可以描述为:一种处理器包括接收模块、转发模块和返回模块。其中,这些模块的名称在某种情况下并不构成对该模块本身的限定。
作为另一方面,本发明还提供了一种计算机可读介质,该计算机可读介质可以是上述实施例中描述的设备中所包含的;也可以是单独存在,而未装配入该设备中。上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被一个该设备执行时,使得该设备包括:接收脚本执行机发送的测试指令,根据测试指令中携带的被测设备编码,查找对应的测试节点;将测试指令转发给对应的测试节点,以使测试节点将测试指令发送至与之对应的被测设备;接收被测设备执行测试指令的结果,并返回给脚本执行机。
根据本发明实施例的技术方案,能够实现对大量设备进行远程自动化测试。
上述具体实施方式,并不构成对本发明保护范围的限制。本领域技术人员应该明白的是,取决于设计要求和其他因素,可以发生各种各样的修改、组合、子组合和替代。任何在本发明的精神和原则之内所作的修改、等同替换和改进等,均应包含在本发明保护范围之内。
Claims (10)
1.一种自动化测试方法,其特征在于,包括:
接收脚本执行机发送的测试指令,根据测试指令中携带的被测设备编码,查找对应的测试节点;
将测试指令转发给对应的测试节点,以使测试节点将测试指令发送至与之对应的被测设备;
接收被测设备执行测试指令的结果,并返回给脚本执行机。
2.根据权利要求1所述的方法,其特征在于,接收脚本执行机发送的测试指令之后,包括:
根据测试指令中携带的被测设备编码,查询被测设备是否空闲,若是则占用被测设备,否则在预设的可超时时间内,定时查询被测设备是否空闲;
接收被测设备执行测试指令的结果之后,包括:释放被测设备。
3.根据权利要求2所述的方法,其特征在于,所述占用被测设备,包括:
调用设备远程管理***的接口,将用户标识上传至设备远程管理***,以占用被测设备;其中,用户标识为任意字符串,在设备远程管理***的页面中生成,且与用户账号关联。
4.根据权利要求1-3任一所述的方法,其特征在于,接收脚本执行机发送的测试指令之前,包括:
接收脚本执行机的连接请求,进而与脚本执行机建立连接;其中,根据脚本中的配置信息,与脚本执行机建立连接。
5.一种自动化测试装置,其特征在于,包括:
接收模块,用于接收脚本执行机发送的测试指令,根据测试指令中携带的被测设备编码,查找对应的测试节点;
转发模块,用于将测试指令转发给对应的测试节点,以使测试节点将测试指令发送至与之对应的被测设备;
返回模块,用于接收被测设备执行测试指令的结果,并返回给脚本执行机。
6.根据权利要求5所述的装置,其特征在于,所述接收模块接收脚本执行机发送的测试指令之后,包括:
根据测试指令中携带的被测设备编码,查询被测设备是否空闲,若是则占用被测设备,否则在预设的可超时时间内,定时查询被测设备是否空闲;
所述返回模块接收被测设备执行测试指令的结果之后,包括:释放被测设备。
7.根据权利要求6所述的装置,其特征在于,所述接收模块占用被测设备,包括:
调用设备远程管理***的接口,将用户标识上传至设备远程管理***,以占用被测设备;其中,用户标识为任意字符串,在设备远程管理***的页面中生成,且与用户账号关联。
8.根据权利要求5-7任一所述的装置,其特征在于,所述接收模块接收脚本执行机发送的测试指令之前,包括:
接收脚本执行机的连接请求,进而与脚本执行机建立连接;其中,根据脚本中的配置信息,与脚本执行机建立连接。
9.一种电子设备,其特征在于,包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1-4中任一所述的方法。
10.一种计算机可读介质,其上存储有计算机程序,其特征在于,所述程序被处理器执行时实现如权利要求1-4中任一所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910706775.3A CN112306851A (zh) | 2019-08-01 | 2019-08-01 | 一种自动化测试方法和装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910706775.3A CN112306851A (zh) | 2019-08-01 | 2019-08-01 | 一种自动化测试方法和装置 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN112306851A true CN112306851A (zh) | 2021-02-02 |
Family
ID=74485853
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910706775.3A Pending CN112306851A (zh) | 2019-08-01 | 2019-08-01 | 一种自动化测试方法和装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112306851A (zh) |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113225223A (zh) * | 2021-04-21 | 2021-08-06 | 武汉思普崚技术有限公司 | 一种pc终端web认证过程的自动化测试方法 |
CN113285849A (zh) * | 2021-04-06 | 2021-08-20 | 武汉虹信科技发展有限责任公司 | 基于微服务的设备测试方法及装置 |
CN113360365A (zh) * | 2020-03-03 | 2021-09-07 | 北京同邦卓益科技有限公司 | 一种流程测试方法和流程测试*** |
CN113965950A (zh) * | 2021-09-30 | 2022-01-21 | 中国科学院计算技术研究所 | 一种支持远程无线通信链路测试的虚实协同平台 |
CN115242912A (zh) * | 2022-09-23 | 2022-10-25 | 中教云智数字科技有限公司 | 一种基于stf的手机自动化测试的方法 |
-
2019
- 2019-08-01 CN CN201910706775.3A patent/CN112306851A/zh active Pending
Cited By (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113360365A (zh) * | 2020-03-03 | 2021-09-07 | 北京同邦卓益科技有限公司 | 一种流程测试方法和流程测试*** |
CN113360365B (zh) * | 2020-03-03 | 2024-04-05 | 北京同邦卓益科技有限公司 | 一种流程测试方法和流程测试*** |
CN113285849A (zh) * | 2021-04-06 | 2021-08-20 | 武汉虹信科技发展有限责任公司 | 基于微服务的设备测试方法及装置 |
CN113225223A (zh) * | 2021-04-21 | 2021-08-06 | 武汉思普崚技术有限公司 | 一种pc终端web认证过程的自动化测试方法 |
CN113225223B (zh) * | 2021-04-21 | 2022-08-02 | 武汉思普崚技术有限公司 | 一种pc终端web认证过程的自动化测试方法 |
CN113965950A (zh) * | 2021-09-30 | 2022-01-21 | 中国科学院计算技术研究所 | 一种支持远程无线通信链路测试的虚实协同平台 |
CN115242912A (zh) * | 2022-09-23 | 2022-10-25 | 中教云智数字科技有限公司 | 一种基于stf的手机自动化测试的方法 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN112306851A (zh) | 一种自动化测试方法和装置 | |
US20190228303A1 (en) | Method and apparatus for scheduling resource for deep learning framework | |
CN112860451A (zh) | 一种基于SaaS的多租户数据处理方法和装置 | |
CN109218041B (zh) | 用于服务器***的请求处理方法和装置 | |
CN111786939B (zh) | 物联网管理平台测试的方法、装置和*** | |
CN110321252B (zh) | 一种技能服务资源调度的方法和装置 | |
CN111090423A (zh) | 一种webhook框架***和实现主动调用、实现事件触发的方法 | |
CN114500481B (zh) | 业务请求处理方法、***和装置 | |
CN111414154A (zh) | 前端开发的方法、装置、电子设备和存储介质 | |
CN113282444A (zh) | 用于业务流程调试的可视化方法和装置 | |
CN109976919A (zh) | 一种消息请求的传输方法和装置 | |
CN113127335B (zh) | 一种***测试的方法和装置 | |
CN111767176B (zh) | 一种远程控制终端设备的方法和装置 | |
CN112579406B (zh) | 一种日志调用链生成方法和装置 | |
CN111953718B (zh) | 一种页面调试方法和装置 | |
CN109271238A (zh) | 支持多种编程语言的任务调度装置和方法 | |
CN111488268A (zh) | 自动化测试的调度方法和调度装置 | |
CN113779122B (zh) | 导出数据的方法和装置 | |
CN112306791B (zh) | 一种性能监控的方法和装置 | |
CN112860447B (zh) | 一种不同应用间的交互方法和*** | |
CN113704079B (zh) | 基于Protobuf的接口测试方法和装置 | |
CN110909269B (zh) | 一种日志上报的方法和装置 | |
CN113448652A (zh) | 一种请求处理方法和装置 | |
CN112559001A (zh) | 更新应用的方法和装置 | |
CN113760487A (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 |