软件测试方法及装置与流程

文档序号:13675280阅读:159来源:国知局

本发明涉及计算机信息处理技术领域,尤其涉及一种软件测试方法及装置。



背景技术:

随着计算机技术的迅速发展,具有文本编辑、图像处理、语音聊天、播放音视频等功能的各种软件层出不穷,为了保证软件各功能模块能够正常工作,需在软件发布之前,对软件各功能模块进行测试。现有软件测试方法中,在软件的各功能模块上分别设置至少一个埋点,当用户使用到某一功能模块时,会触发预设在该功能模块中的埋点,产生埋点数据并发送给服务器,服务器收集并分析对应的埋点数据,以查找出该软件运行过程中,容易出错的功能模块,并加以改进,从而达到完善软件的目的。

现有软件测试方法中,服务器接收到的埋点数据数量庞大且重复,由开发人员进行定点查找并分析,测试过程工作繁琐且工作量大,存在测试时间较长且人力成本高的问题。若采用专用分析软件(如python软件)分析埋点数据,虽在一定程度上降低测试过程的工作量,但专用分析软件(如python软件)需进行繁琐安装和配置,且需有代码能力较强的专业人员配合才可以完成软件测试过程,存在人力成本较高的问题。



技术实现要素:

鉴于此,本发明提供一种软件测试方法及装置,以解决现有软件测试过程中工作繁琐且工作量大的问题。

本发明解决其技术问题所采用的技术方案是:

第一方面,本发明提供一种软件测试方法,包括:

在客户端上运行待测软件,所述待测软件包括至少一个功能模块,每一功能模块上设有至少一个埋点;

当所述待测软件上的所述埋点被触发时,生成埋点数据,并将所述埋点数据发送给mongodb数据库;所述埋点数据包括埋点id、测试校验代码和参数信息;

使mongodb数据库上配置的awk脚本获取测试校验代码为失败的所述埋点数据,确定为待分析数据;

采用预设分析算法对所述待分析数据中的参数信息进行分析,获取导致所述埋点测试失败的分析结果。

优选地,所述在客户端上运行待测软件,之前还包括:

将所述mongodb数据库安装在所述服务器,完成所述mongodb数据库与所述服务器的信息配置,以使所述mongodb数据库实时监控并获取所述埋点数据;

设置所述awk脚本定时获取所述测试校验代码为失败的埋点数据。

优选地,所述参数信息包括设备型号、设备配置、触发时间、网络类型、网络带宽和网络宽带时延积中的至少一个。

优选地,所述预设分析算法包括工作分解结构算法、资源分解结构算法或组织分解结构算法。

优选地,还包括:

接收客户通过所述客户端向所述服务器发送的查询指令,所述查询指令包括所述埋点id;

基于所述查询指令,获取与所述埋点id相对应的查询结果。

第二方面,本发明还提供一种软件测试装置,包括:

软件运行模块,用于在客户端上运行待测软件,所述待测软件包括至少一个功能模块,每一功能模块上设有至少一个埋点;

埋点数据生成模块,用于当所述待测软件上的所述埋点被触发时,生成埋点数据,并将所述埋点数据发送给mongodb数据库;所述埋点数据包括埋点id、测试校验代码和参数信息;

待分析数据确定模块,用于使mongodb数据库上配置的awk脚本获取测试校验代码为失败的所述埋点数据,确定为待分析数据;

分析结果获取模块,用于采用预设分析算法对所述待分析数据中的参数信息进行分析,获取导致所述埋点测试失败的分析结果。

优选地,还包括:

信息配置模块,用于将所述mongodb数据库安装在所述服务器,完成所述mongodb数据库与所述服务器的信息配置,以使所述mongodb数据库实时监控并获取所述埋点数据;

所述信息配置模块,还用于设置所述awk脚本定时获取所述测试校验代码为失败的埋点数据。

优选地,所述参数信息包括设备型号、设备配置、触发时间、网络类型、网络带宽和网络宽带时延积中的至少一个。

优选地,所述预设分析算法包括工作分解结构算法、资源分解结构算法或组织分解结构算法。

优选地,还包括:

查询指令接收模块,用于接收客户通过所述客户端向所述服务器发送的查询指令,所述查询指令包括所述埋点id;

查询结果获取模块,用于基于所述查询指令,获取与所述埋点id相对应的查询结果。

本发明与现有技术相比具有如下优点:本发明所提供的软件测试方法及装置中,采用mongodb数据库存储客户端运行待测软件过程中触发形成的埋点数据,mongodb数据库是开源的面向文档型数据库,其存储的埋点数据不受存储表的限制,灵活性更强。再通过mongodb数据库上配置的awk脚本对埋点数据进行分析,以获取测试校验代码为失败的所有埋点数据确定为待分析数据,awk脚本具有门槛低、定位简单、数据处理效率快的优点,无需进行繁琐的安装和配置,即可对mongodb数据库中的埋点数据直接操作。再采用预设分析算法对待分析数据中的参数信息进行分析,以获取导致埋点测试失败的分析结果,通过该分析结果可直观显示各参数信息对埋点所在功能模块测试失败的影响,以便于对待测软件进行改善。

附图说明

下面将结合附图及实施例对本发明作进一步说明,附图中:

图1是本发明实施例1中软件测试方法的一流程图。

图2是本发明实施例2中软件测试装置的一原理框图。

具体实施方式

为了对本发明的技术特征、目的和效果有更加清楚的理解,现对照附图详细说明本发明的具体实施方式。

实施例1

图1示出本实施例中的软件测试方法的一流程图。该软件测试方法由客户端和服务器配合,完成对待测软件的测试过程。其中,客户端与服务器之间可通过wifi网络、3g网络或4g网络等无线网络通信相连,也可通过有线网络通信相连。客户端可以是安装有待测软件的智能手机、笔记本、平板电脑、pad或台式电脑等可与服务器通信相连的终端。如图1所示,该软件测试方法包括如下步骤:

s10:在客户端上运行待测软件,待测软件包括至少一个功能模块,每一功能模块上设有至少一个埋点。

具体地,在客户端上安装有待测软件并运行,该待测软件上设有至少一个功能模块,且每一功能模块上设有至少一个埋点,当客户端运行该待测软件的相应功能模块时,该功能模块上的埋点被触发。

s20:当待测软件上的埋点被触发时,生成埋点数据,并将埋点数据发送给mongodb数据库;埋点数据包括埋点id、测试校验代码和参数信息。

具体地,当待测软件上的埋点被触发时,触发生成的埋点数据可体现其测试结果,以便基于该埋点数据进行分析并改进,提高用户对待测软件的满意度。如在一理财产品app中,包括用户登录模块、产品查询模块、上传产品和支付模块等,且用户登录模块包括用户注册、登录界面、找回用户名或找回密码等程序代码,则可在用户注册、登录界面、找回用户名或找回密码等程序代码均设有埋点,当用户通过客户端运行待测软件,并执行用户注册、登录界面、找回用户名或找回密码等相应操作时,客户端分别生成埋点数据并将埋点数据发送给mongodb数据库。

其中,埋点id用于唯一识别埋点的标识,该标识按预设编号规则进行编号。本实施例中,可以按功能模块id+序号这一预设编号规则进行编号,如上述理财产品app中,若用户登录模块的功能模块id为x1,且用户注册的功能模块id为x101,则可用x10101表示设置在用户注册程序代码中设有的第一个埋点。

测试校验代码用于标注埋点对应的程序代码测试是否成功,包括成功和失败两种测试校验代码。本实施例中,测试校验代码可分别用y和n两个字母表示,也可用其他代码表示。通过测试校验代码区分埋点对应的程序代码测试是否成功,基于测试校验代码可将所有埋点数据划分成两类,通过对测试校验代码为失败的埋点数据进行分析,无需专门的开发人员定时排查,可在一定程度上减轻测试过程的工作量,减少测试时间,节省人力成本。

参数信息用于客观体现埋点所在的程序代码的运行环境,其与待测软件测试是否成功密切相关。具体地,参数信息包括设备型号、设备配置、触发时间、网络类型、网络带宽和网络宽带时延积中的至少一个。

本实施例中,设备型号是安装有待测软件的客户端的内部编号,该设备型号与客户端的性能相关联。以智能手机为例,每一智能手机厂家在生产相应品牌的智能手机时,以设备型号来区分不同版本的智能手机,如iphone4、iphone5等。设备配置可以是客户端上安装的操作系统,如安卓系统、ios操作系统、windows系统、linux系统等,或者可以是安装在客户端上的处理器或其他硬件的型号,如i5或i7处理器。触发时间可以是运行该待测软件的时间,该触发时间与客户端运行网络相关,一般情况下,在网络高峰触发待测软件的失败率会比在网络低峰触发待测软件的失败率高。网络类型是客户端与服务器通信所采用的网络,可以是有线网络,也可以是wifi网络、3g网络或4g网络等无线网络。网络带宽是单位时间内传输的数据量,即数据传输率。网络宽带时延积是链路上最大比特数。

进一步地,客户端发送的埋点数据直接存储在mongodb数据库中,而mongodb数据库是一种开源且面向文档型数据库,相比于sql等表结构存储的关系型数据库,其灵活性更强,以便于实现对存储在mongodb数据库中的埋点数据进行分析。

s30:使mongodb数据库上配置的awk脚本获取测试校验代码为失败的埋点数据,确定为待分析数据。

其中,awk脚本是一种强大的文本分析工具,可对存储在mongodb数据库中所有埋点数据逐行读入,再以空格或其他默认分隔符将埋点数据进行分隔,并对分隔的内容进行分析处理。本实施例中,采用mongodb数据库上配置的awk脚本对所有埋点数据进行分析,获取测试校验代码为失败的埋点数据,将其确定为待分析数据,以便基于待分析数据确定导致埋点所在的程序代码测试失败的原因,以基于失败原因对待测软件进行改进。可以理解地,可直接采用awk脚本将测试校验代码为失败的埋点数据确定为待分析数据,而无需再安装其他运行环境,具有门槛低、定位简单、数据处理效率快的优点,无需进行繁琐安装和配置,也无需代码能力较强的专业人员配合完成测试,进一步降低待测软件测试过程的人力成本。

s40:采用预设分析算法对待分析数据中的参数信息进行分析,获取导致埋点测试失败的分析结果。

具体地,mongodb数据库上配置的awk脚本先将所有测试校验代码为失败的所有埋点数据确定为待分析数据,无需专门的开发人员定时排查,可在一定程度上减轻测试过程中的工作量,节省人力成本。采用预设分析算法对所有待分析数据中的参数信息进行分析,可获取导致该埋点对应的程序代码测试失败的原因,以形成分析结果,分析过程自动化,无需配置专业人员进行分析,有利于降低分析成本。

具体地,预设分析算法包括工作分解结构算法、资源分解结构算法或组织分解结构算法。工作分解结构(workbreakdowmstructure,简称wbs)算法以可交付成果为导向,对项目要素进行的分组,它归纳和定义了项目的整个工作范围,每下降一层代表对项目工作的更详细定义。资源分解结构(resoureebreakdowmstructure,简称rbs)算法是按照资源种类和形式而划分的资源层级结构,它是项目分解结构的一种,通过它可以在资源需求细节上制定进度计划,并可以通过汇总的方式向更高一层汇总资源需求和资源可用性。组织分解结构(organizationalbreakdowmstructure,简称obs)算法是项目组织结构图的一种非凡形式,描述负责每个项目活动的具体组织单元,它将工作包与相关部门或单位分层次、有条理地联系起来的一种项目组织安排图形。

本实施例中,工作分解结构(workbreakdowmstructure,简称wbs)算法是指按一定分类原则,将所有参数信息先分为设备型号、设备配置、触发时间、网络类型、网络带宽和网络宽带时延积等大类,再将每一大类再细分为若干小类,然后再将每一小类进一步细分成若干小组……,依次类推,以将所有参数信息划分成不可再分割的分类类别,然后判断每一分类类别的参数信息是否与待测软件测试失败相关联,其目的性明确,以避免分析过程中遗漏影响待测软件相应功能模块测试成功或失败的相关参数信息。具体地,每一不可再分割的分类类别对应一类别id;可采用控制变量法判断每一分类类别id对应的参数信息是否与待测软件测试失败相关联,以确定影响待测软件成功运行的相差参数信息。

本实施例所提供的软件测试方法中,采用mongodb数据库存储客户端运行待测软件过程中触发形成的埋点数据,mongodb数据库是开源的面向文档型数据库,其存储的埋点数据不受存储表的限制,灵活性更强。再通过mongodb数据库上配置的awk脚本对埋点数据进行分析,以获取测试校验代码为失败的所有埋点数据确定为待分析数据,awk脚本具有门槛低、定位简单、数据处理效率快的优点,无需进行繁琐的安装和配置,即可对mongodb数据库中的埋点数据直接操作。再采用预设分析算法对待分析数据中的参数信息进行分析,以获取导致埋点测试失败的分析结果,通过该分析结果可直观显示各参数信息对埋点所在功能模块测试失败的影响,以便于对待测软件进行改善。

在一具体实施方式中,由于待测软件上的埋点数据被触发时,需将触发生成的埋点数据发送给对应的mongodb数据库,需进行相应的配置,以保证埋点数据直接发送给mongodb数据库且awk脚本可对mongodb数据库中的埋眯数据进行分析。因此,该软件测试方法中,步骤s10之前还包括如下步骤:

s01:将mongodb数据库安装在服务器,完成mongodb数据库与服务器的信息配置,以使mongodb数据库实时监控并获取埋点数据。

具体地,在服务器上运行mongodb数据库安装程序,运行mongod命令,以将mongodb数据库安装在服务器上。然后在服务器上创建数据目录,并启动服务器,等待服务器与客户端连接。mongod一般在没有参数的情况下会默认数据目录/data/db,若不存在就会启动失败;本实施例中,创建数据目录为mkdir-p/data/db。再给mongodb数据库配置27017端口以监听服务器,配置28017端口以监听http请求,当客户端访问http://服务器地址28017,即实现客户端与服务器连接。

步骤s01中,完成mongodb数据库与服务器之间的信息配置,由于mongodb数据库支持存储数据类型比较复杂的数据,以使mongodb数据库可实时监控服务器接收到的http请求,当客户端上传埋点数据服务器时,可直接存储在mongodb数据库中,无需转换成存储表结构再存储。

s02:设置awk脚本定时获取测试校验代码为失败的埋点数据。

具体地,预先设置awk脚本定时获取测试校验代码为失败的埋点数据,以确定为待分析数据,awk脚本具有门槛低、定位简单等优点,无需专门的测试人员定点排查,有利于提高测试效率。通过awk脚本定时获取测试校验代码为失败的埋点数据并采用预设分析算法进行分析,可定时获取分析结果;而无需人工监控。

在一具体实施方式中,该软件测试方法还包括如下步骤:

s50:接收客户通过客户端向服务器发送的查询指令,查询指令包括埋点id。

具体地,客户(如测试人员或开发人员)可向客户端输入查询指令,客户端接收到该查询指令后,将该查询指令发送给服务器。该查询指令可以仅包括一个埋点id,以查询影响特定埋点所在的程序代码的参数信息,也可以是功能模块id,该功能模块包括至少一个埋点id,以查询影响特定功能模块的参数信息。

s60:基于查询指令,获取与埋点id相对应的查询结果。

其中,该查询结果为与埋点id相对应的分析结果。具体地,服务器上的mongodb数据库在接收到查询指令后,可获取采用预设分析算法对与查询指令中的埋点id对应的所有待分析数据进行分析的分析结果,并将该分析结果作为查询结果输出。客户端显示查询结果,以便客户基于查询结果对该埋点id对应的程序代码或功能模块进行改善。

可以理解地,本实施例所提供的软件测试方法中,采用面向文档的mongodb数据库和擅长处理文档行列的awk脚本配合,可直接对上传到mongodb数据库中的所有埋点数据进行筛选、对比、统计、定时输出或循环输出等操作。而且,该软件测试方法中,可基于客户端原有的开发环境,无需对客户端的运行环境进行改变,在不牺牲用户体验、不延迟数据请求的基础上实现将埋点数据实时或批量上传到服务器的mongodb数据库中,轻便简洁且可移植性高。

实施例2

图2示出本实施例中的软件测试装置的一原理框图。该软件测试装置包括客户端和服务器,通过客户端和服务器配合,完成对待测软件的测试过程。其中,客户端与服务器之间可通过wifi网络、3g网络或4g网络等无线网络通信相连,也可通过有线网络通信相连。客户端可以是安装有待测软件的智能手机、笔记本、平板电脑、pad或台式电脑等可与服务器通信相连的终端。如图2所示,该软件测试装置包括软件运行模块10、埋点数据生成模块20、待分析数据确定模块30、分析结果获取模块40、信息配置模块50、查询指令接收模块60和查询结果获取模块70。

软件运行模块10,用于在客户端上运行待测软件,待测软件包括至少一个功能模块,每一功能模块上设有至少一个埋点。

具体地,在客户端上安装有待测软件并运行,该待测软件上设有至少一个功能模块,且每一功能模块上设有至少一个埋点,当客户端运行该待测软件的相应功能模块时,该功能模块上的埋点被触发。

埋点数据生成模块20,用于当待测软件上的埋点被触发时,生成埋点数据,并将埋点数据发送给mongodb数据库;埋点数据包括埋点id、测试校验代码和参数信息。

具体地,当待测软件上的埋点被触发时,触发生成的埋点数据可体现其测试结果,以便基于该埋点数据进行分析并改进,提高用户对待测软件的满意度。如在一理财产品app中,包括用户登录模块、产品查询模块、上传产品和支付模块等,且用户登录模块包括用户注册、登录界面、找回用户名或找回密码等程序代码,则可在用户注册、登录界面、找回用户名或找回密码等程序代码均设有埋点,当用户通过客户端运行待测软件,并执行用户注册、登录界面、找回用户名或找回密码等相应操作时,客户端分别生成埋点数据并将埋点数据发送给mongodb数据库。

其中,埋点id用于唯一识别埋点的标识,该标识按预设编号规则进行编号。本实施例中,可以按功能模块id+序号这一预设编号规则进行编号,如上述理财产品app中,若用户登录模块的功能模块id为x1,且用户注册的功能模块id为x101,则可用x10101表示设置在用户注册程序代码中设有的第一个埋点。

测试校验代码用于标注埋点对应的程序代码测试是否成功,包括成功和失败两种测试校验代码。本实施例中,测试校验代码可分别用y和n两个字母表示,也可用其他代码表示。通过测试校验代码区分埋点对应的程序代码测试是否成功,基于测试校验代码可将所有埋点数据划分成两类,通过对测试校验代码为失败的埋点数据进行分析,无需专门的开发人员定时排查,可在一定程度上减轻测试过程的工作量,减少测试时间,节省人力成本。

参数信息用于客观体现埋点所在的程序代码的运行环境,其与待测软件测试是否成功密切相关。具体地,参数信息包括设备型号、设备配置、触发时间、网络类型、网络带宽和网络宽带时延积中的至少一个。

本实施例中,设备型号是安装有待测软件的客户端的内部编号,该设备型号与客户端的性能相关联。以智能手机为例,每一智能手机厂家在生产相应品牌的智能手机时,以设备型号来区分不同版本的智能手机,如iphone4、iphone5等。设备配置可以是客户端上安装的操作系统,如安卓系统、ios操作系统、windows系统、linux系统等,或者可以是安装在客户端上的处理器或其他硬件的型号,如i5或i7处理器。触发时间可以是运行该待测软件的时间,该触发时间与客户端运行网络相关,一般情况下,在网络高峰触发待测软件的失败率会比在网络低峰触发待测软件的失败率高。网络类型是客户端与服务器通信所采用的网络,可以是有线网络,也可以是wifi网络、3g网络或4g网络等无线网络。网络带宽是单位时间内传输的数据量,即数据传输率。网络宽带时延积是链路上最大比特数。

进一步地,客户端发送的埋点数据直接存储在mongodb数据库中,而mongodb数据库是一种开源且面向文档型数据库,相比于sql等表结构存储的关系型数据库,其灵活性更强,以便于实现对存储在mongodb数据库中的埋点数据进行分析。

待分析数据确定模块30,用于使mongodb数据库上配置的awk脚本获取测试校验代码为失败的埋点数据,确定为待分析数据。

其中,awk脚本是一种强大的文本分析工具,可对存储在mongodb数据库中所有埋点数据逐行读入,再以空格或其他默认分隔符将埋点数据进行分隔,并对分隔的内容进行分析处理。本实施例中,采用mongodb数据库上配置的awk脚本对所有埋点数据进行分析,获取测试校验代码为失败的埋点数据,将其确定为待分析数据,以便基于待分析数据确定导致埋点所在的程序代码测试失败的原因,以基于失败原因对待测软件进行改进。可以理解地,可直接采用awk脚本将测试校验代码为失败的埋点数据确定为待分析数据,而无需再安装其他运行环境,具有门槛低、定位简单、数据处理效率快的优点,无需进行繁琐安装和配置,也无需代码能力较强的专业人员配合完成测试,进一步降低待测软件测试过程的人力成本。

分析结果获取模块40,用于采用预设分析算法对待分析数据中的参数信息进行分析,获取导致埋点测试失败的分析结果。

具体地,mongodb数据库上配置的awk脚本先将所有测试校验代码为失败的所有埋点数据确定为待分析数据,无需专门的开发人员定时排查,可在一定程度上减轻测试过程中的工作量,节省人力成本。采用预设分析算法对所有待分析数据中的参数信息进行分析,可获取导致该埋点对应的程序代码测试失败的原因,以形成分析结果,分析过程自动化,无需配置专业人员进行分析,有利于降低分析成本。

具体地,预设分析算法包括工作分解结构算法、资源分解结构算法或组织分解结构算法。工作分解结构(workbreakdowmstructure,简称wbs)算法以可交付成果为导向,对项目要素进行的分组,它归纳和定义了项目的整个工作范围,每下降一层代表对项目工作的更详细定义。资源分解结构(resoureebreakdowmstructure,简称rbs)算法是按照资源种类和形式而划分的资源层级结构,它是项目分解结构的一种,通过它可以在资源需求细节上制定进度计划,并可以通过汇总的方式向更高一层汇总资源需求和资源可用性。组织分解结构(organizationalbreakdowmstructure,简称obs)算法是项目组织结构图的一种非凡形式,描述负责每个项目活动的具体组织单元,它将工作包与相关部门或单位分层次、有条理地联系起来的一种项目组织安排图形。

本实施例中,工作分解结构(workbreakdowmstructure,简称wbs)算法是指按一定分类原则,将所有参数信息先分为设备型号、设备配置、触发时间、网络类型、网络带宽和网络宽带时延积等大类,再将每一大类再细分为若干小类,然后再将每一小类进一步细分成若干小组……,依次类推,以将所有参数信息划分成不可再分割的分类类别,然后判断每一分类类别的参数信息是否与待测软件测试失败相关联,其目的性明确,以避免分析过程中遗漏影响待测软件相应功能模块测试成功或失败的相关参数信息。具体地,每一不可再分割的分类类别对应一类别id;可采用控制变量法判断每一分类类别id对应的参数信息是否与待测软件测试失败相关联,以确定影响待测软件成功运行的相差参数信息。

本实施例所提供的软件测试装置中,采用mongodb数据库存储客户端运行待测软件过程中触发形成的埋点数据,mongodb数据库是开源的面向文档型数据库,其存储的埋点数据不受存储表的限制,灵活性更强。再通过mongodb数据库上配置的awk脚本对埋点数据进行分析,以获取测试校验代码为失败的所有埋点数据确定为待分析数据,awk脚本具有门槛低、定位简单、数据处理效率快的优点,无需进行繁琐的安装和配置,即可对mongodb数据库中的埋点数据直接操作。再采用预设分析算法对待分析数据中的参数信息进行分析,以获取导致埋点测试失败的分析结果,通过该分析结果可直观显示各参数信息对埋点所在功能模块测试失败的影响,以便于对待测软件进行改善。

在一具体实施方式中,由于待测软件上的埋点数据被触发时,需将触发生成的埋点数据发送给对应的mongodb数据库,需进行相应的配置,以保证埋点数据直接发送给mongodb数据库且awk脚本可对mongodb数据库中的埋眯数据进行分析。因此,该软件测试装置还包括信息配置模块50。

信息配置模块50,用于将mongodb数据库安装在服务器,完成mongodb数据库与服务器的信息配置,以使mongodb数据库实时监控并获取埋点数据。

具体地,在服务器上运行mongodb数据库安装程序,运行mongod命令,以将mongodb数据库安装在服务器上。然后在服务器上创建数据目录,并启动服务器,等待服务器与客户端连接。mongod一般在没有参数的情况下会默认数据目录/data/db,若不存在就会启动失败;本实施例中,创建数据目录为mkdir-p/data/db。再给mongodb数据库配置27017端口以监听服务器,配置28017端口以监听http请求,当客户端访问http://服务器地址28017,即实现客户端与服务器连接。

信息配置模块50可完成mongodb数据库与服务器之间的信息配置,由于mongodb数据库支持存储数据类型比较复杂的数据,以使mongodb数据库可实时监控服务器接收到的http请求,当客户端上传埋点数据服务器时,可直接存储在mongodb数据库中,无需转换成存储表结构再存储。

信息配置模块50,还用于设置awk脚本定时获取测试校验代码为失败的埋点数据。

具体地,预先设置awk脚本定时获取测试校验代码为失败的埋点数据,以确定为待分析数据,awk脚本具有门槛低、定位简单等优点,无需专门的测试人员定点排查,有利于提高测试效率。通过awk脚本定时获取测试校验代码为失败的埋点数据并采用预设分析算法进行分析,可定时获取分析结果;而无需人工监控。

在一具体实施方式中,该软件测试装置还包括查询指令接收模块60和查询结果获取模块70。

查询指令接收模块60,用于接收客户通过客户端向服务器发送的查询指令,查询指令包括埋点id。

具体地,客户(如测试人员或开发人员)可向客户端输入查询指令,客户端接收到该查询指令后,将该查询指令发送给服务器。该查询指令可以仅包括一个埋点id,以查询影响特定埋点所在的程序代码的参数信息,也可以是功能模块id,该功能模块包括至少一个埋点id,以查询影响特定功能模块的参数信息。

查询结果获取模块70,用于基于查询指令,获取与埋点id相对应的查询结果。

其中,该查询结果为与埋点id相对应的分析结果。具体地,服务器上的mongodb数据库在接收到查询指令后,可获取采用预设分析算法对与查询指令中的埋点id对应的所有待分析数据进行分析的分析结果,并将该分析结果作为查询结果输出。客户端显示查询结果,以便客户基于查询结果对该埋点id对应的程序代码或功能模块进行改善。

可以理解地,本实施例所提供的软件测试装置中,采用面向文档的mongodb数据库和擅长处理文档行列的awk脚本配合,可直接对上传到mongodb数据库中的所有埋点数据进行筛选、对比、统计、定时输出或循环输出等操作。而且,该软件测试装置中,可基于客户端原有的开发环境,无需对客户端的运行环境进行改变,在不牺牲用户体验、不延迟数据请求的基础上实现将埋点数据实时或批量上传到服务器的mongodb数据库中,轻便简洁且可移植性高。

本发明是通过几个具体实施例进行说明的,本领域技术人员应当明白,在不脱离本发明范围的情况下,还可以对本发明进行各种变换和等同替代。另外,针对特定情形或具体情况,可以对本发明做各种修改,而不脱离本发明的范围。因此,本发明不局限于所公开的具体实施例,而应当包括落入本发明权利要求范围内的全部实施方式。

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