CN103617118A - 测试结果的统一处理方法、装置及系统 - Google Patents

测试结果的统一处理方法、装置及系统 Download PDF

Info

Publication number
CN103617118A
CN103617118A CN201310627148.3A CN201310627148A CN103617118A CN 103617118 A CN103617118 A CN 103617118A CN 201310627148 A CN201310627148 A CN 201310627148A CN 103617118 A CN103617118 A CN 103617118A
Authority
CN
China
Prior art keywords
test
report
case
result
database
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.)
Granted
Application number
CN201310627148.3A
Other languages
English (en)
Other versions
CN103617118B (zh
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.)
Beijing Qihoo Technology Co Ltd
Qizhi Software Beijing Co Ltd
Original Assignee
Beijing Qihoo Technology Co Ltd
Qizhi Software Beijing Co Ltd
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 Beijing Qihoo Technology Co Ltd, Qizhi Software Beijing Co Ltd filed Critical Beijing Qihoo Technology Co Ltd
Priority to CN201310627148.3A priority Critical patent/CN103617118B/zh
Publication of CN103617118A publication Critical patent/CN103617118A/zh
Application granted granted Critical
Publication of CN103617118B publication Critical patent/CN103617118B/zh
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Debugging And Monitoring (AREA)
  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)

Abstract

本发明涉及一种测试结果的统一处理方法、装置及系统,该方法包括:接收并解析由至少一个测试脚本发来的XML格式的测试结果;获取测试结果中包含的所有测试用例,将测试用例存储到预设的用例数据库中;并且,根据测试结果创建错误报表,将错误报表存储到预设的报表数据库中;根据测试用例和错误报表生成测试报告,将测试报告存储到预设的报告数据库中;获取测试结果中包含的用于指示是否发送测试报告的第一参数,当第一参数指示为发送测试报告时,将测试报告发送给预设终端。从而避免了现有技术中手动处理测试结果的繁琐过程,提高了处理效率,降低了对处理人员的要求。

Description

测试结果的统一处理方法、装置及系统
技术领域
本发明涉及网络通信技术领域,具体涉及一种测试结果的统一处理方法、装置及系统。
背景技术
随着计算机编程技术的快速发展,出现了多种程序语言,相应地,在软件测试过程中,经常需要测试由不同的程序语言编写的各类产品,并根据测试结果生成相应的测试报告。在生成测试报告的过程中,由于不同的程序语言对应的测试结果的格式不同,因此,针对每种类型的程序语言所对应的测试结果,需要由了解该程序语言特点的测试人员手动提取测试用例、分析错误报表,进而完成测试报告。
由此可见,在根据测试结果生成测试报告的上述过程中,对测试人员的要求较高,需要了解多种程序语言才能完成对各类程序语言对应的测试结果的处理。而且,在这一过程中,首先需要测试人员人工分析测试结果,然后从测试结果中手动提取各个测试用例,并分析每一测试用例是否出错,从而根据实际情况生成错误报表,最后还要根据得到的上述测试用例以及错误报表来手动创建测试报告,由此导致测试报告的生成过程繁琐且效率低下。
发明内容
鉴于上述问题,提出了本发明以便提供一种克服上述问题或者至少部分地解决上述问题的测试结果的统一处理方法、装置及系统。
依据本发明的一个方面,提供了一种测试结果的统一处理方法,包括:接收并解析由至少一个测试脚本发来的XML格式的测试结果;获取测试结果中包含的所有测试用例,将测试用例存储到预设的用例数据库中;并且,根据测试结果创建错误报表,将错误报表存储到预设的报表数据库中;根据测试用例和错误报表生成测试报告,将测试报告存储到预设的报告数据库中;获取测试结果中包含的用于指示是否发送测试报告的第一参数,当第一参数指示为发送测试报告时,将测试报告发送给预设终端。
可选地,XML格式的测试结果中包含的测试用例通过三层节点构成的标识符表示,其中,三层节点进一步包括:作为第一层的产品节点、作为第二层的模块节点以及作为第三层的用例节点;则获取测试结果中包含的所有测试用例的步骤进一步包括:获取测试结果中包含的三层节点构成的标识符,根据标识符所标识的字符串确定测试结果中包含的测试用例。
可选地,产品节点中进一步包括用于指示是否创建错误报表的第二参数,则根据测试结果创建错误报表的步骤进一步包括:获取第二参数,当第二参数指示为创建错误报表时,为测试失败的测试用例创建错误报表。
可选地,进一步包括步骤:通过预设的第一web查询接口接收到测试用例查询请求后,根据用例数据库中的存储内容返回测试用例查询结果;通过预设的第二web查询接口接收到错误报表查询请求后,根据报表数据库中的存储内容返回错误报表查询结果;以及,通过预设的第三web查询接口接收到测试报告查询请求后,根据报告数据库中的存储内容返回测试报告查询结果。
可选地,通过HTTP POST消息接收XML格式的测试结果。
可选地,将测试报告发送给预设终端时,通过邮件方式和/或短消息方式发送。
依据本发明的另一方面,提供了一种测试结果的统一处理装置,包括:接收模块,适于接收并解析由至少一个测试脚本发来的XML格式的测试结果;测试用例获取模块,适于获取测试结果中包含的所有测试用例,将测试用例存储到预设的用例数据库中;错误报表创建模块,适于根据测试结果创建错误报表,将错误报表存储到预设的报表数据库中;测试报告生成模块,适于根据测试用例和错误报表生成测试报告,将测试报告存储到预设的报告数据库中;发送模块,适于获取测试结果中包含的用于指示是否发送测试报告的第一参数,当第一参数指示为发送测试报告时,将测试报告发送给预设终端。
可选地,XML格式的测试结果中包含的测试用例通过三层节点构成的标识符表示,其中,三层节点进一步包括:作为第一层的产品节点、作为第二层的模块节点以及作为第三层的用例节点;则测试用例获取模块适于:获取测试结果中包含的三层节点构成的标识符,根据标识符所标识的字符串确定测试结果中包含的测试用例。
可选地,产品节点中进一步包括用于指示是否创建错误报表的第二参数,则错误报表创建模块适于:获取第二参数,当第二参数指示为创建错误报表时,为测试失败的测试用例创建错误报表。
可选地,进一步包括:第一web查询接口,适于在接收到测试用例查询请求后,根据用例数据库中的存储内容返回测试用例查询结果;第二web查询接口,适于在接收到错误报表查询请求后,根据报表数据库中的存储内容返回错误报表查询结果;以及,第三web查询接口,适于在接收到测试报告查询请求后,根据报告数据库中的存储内容返回测试报告查询结果。
依据本发明的另一方面,提供了一种测试结果的统一处理系统,包括:上述的统一处理装置,以及与上述统一处理装置分别相连的用例数据库、报表数据库、报告数据库以及查询客户端,其中,用例数据库适于存储测试用例,报表数据库适于存储错误报表,报告数据库适于存储测试报告,查询客户端适于向统一处理装置发送测试用例查询请求、错误报表查询请求和/或测试报告查询请求,并接收统一处理装置返回的测试用例查询结果、错误报表查询结果和/或测试报告查询结果。
在本发明提供的测试结果的统一处理方法、装置及系统中,所有测试脚本发来的测试结果统一采用XML格式的文档编写,因此,能够自动地根据测试结果获取其中包含的所有测试用例、自动创建错误报表,还能自动根据测试用例和错误报表生成测试报告,从而避免了现有技术中手动处理测试结果的繁琐过程,提高了处理效率,降低了对处理人员的要求。另外,在本发明中,还将得到的测试用例、错误报表以及测试报告分别存储到对应的数据库中,因而实现了测试结果的统一管理,进而能够提供各项信息的查询,为后续的测试过程提供了很大便利。
上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。
附图说明
通过阅读下文优选实施方式的详细描述,各种其他的优点和益处对于本领域普通技术人员将变得清楚明了。附图仅用于示出优选实施方式的目的,而并不认为是对本发明的限制。而且在整个附图中,用相同的参考符号表示相同的部件。在附图中:
图1示出了本发明中的测试结果的统一处理系统的结构图;
图2示出了本发明实施例提供的测试结果的统一处理方法的流程图;
图3示出了本发明另一实施例提供的测试结果的统一处理方法的流程图;
图4示出了本发明实施例提供的测试结果的统一处理装置的结构图;以及
图5示出了本发明实施例提供的测试结果的统一处理系统的结构图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
本发明实施例提供了一种测试结果的统一处理方法、装置及系统,用以解决现有技术中的测试报告的生成过程非常繁琐且效率低下的问题。
图1示出了本发明中的测试结果的统一处理系统的结构图。如图1所示,该系统包括:统一处理装置20,以及与统一处理装置20分别相连的用例数据库31、报表数据库32、报告数据库33以及查询客户端10。其中,统一处理装置20适于根据测试结果自动生成测试用例、错误报表以及测试报告,并对应存储到相应的数据库中;用例数据库31适于存储测试用例,报表数据库32适于存储错误报表,报告数据库33适于存储测试报告;查询客户端10适于向统一处理装置20发送测试用例查询请求、错误报表查询请求和/或测试报告查询请求,并接收统一处理装置20返回的测试用例查询结果、错误报表查询结果和/或测试报告查询结果。其中,查询客户端10的数量可以为一个或多个。本发明基于图1所示的系统结构来进行测试结果的统一处理。
图2示出了本发明实施例提供的测试结果的统一处理方法的流程图,本方法的执行主体为图1所示的统一处理装置。如图2所示,该方法起始于步骤S110,在步骤S110中,接收并解析由至少一个测试脚本发来的XML格式的测试结果。其中,可以通过HTTP POST消息来接收上述XML格式的测试结果。
在步骤S120中,获取上述测试结果中包含的所有测试用例,将这些测试用例存储到预设的用例数据库中;并且,根据测试结果创建错误报表,将错误报表存储到预设的报表数据库中。
在步骤S130中,根据测试用例和错误报表生成测试报告,将测试报告存储到预设的报告数据库中。
在步骤S140中,获取测试结果中包含的用于指示是否发送测试报告的第一参数,当该第一参数指示为发送测试报告时,将测试报告发送给预设终端。其中,在将测试报告发送给预设终端时,可以通过邮件方式和/或短消息方式发送。
可选地,在步骤S110中解析到的XML格式的测试结果中包含的测试用例通过三层节点构成的标识符表示,其中,三层节点进一步包括:作为第一层的产品节点、作为第二层的模块节点以及作为第三层的用例节点;则在步骤S120中,获取测试结果中包含的三层节点构成的标识符,根据该标识符所标识的字符串来确定测试结果中包含的测试用例。并且,上述的产品节点中还可以进一步包括用于指示是否创建错误报表的第二参数,则在步骤S120中,获取该第二参数,当该第二参数指示为创建错误报表时,为测试失败的测试用例创建错误报表。
可选地,在本实施例中,还可以进一步包括步骤:通过预设的第一web查询接口接收到测试用例查询请求后,根据用例数据库中的存储内容返回测试用例查询结果;通过预设的第二web查询接口接收到错误报表查询请求后,根据报表数据库中的存储内容返回错误报表查询结果;以及,通过预设的第三web查询接口接收到测试报告查询请求后,根据报告数据库中的存储内容返回测试报告查询结果。
在本发明提供的测试结果的统一处理方法中,所有测试脚本发来的测试结果统一采用XML格式的文档编写,因此,能够自动地根据测试结果获取其中包含的所有测试用例、自动创建错误报表,还能自动根据测试用例和错误报表生成测试报告,从而避免了现有技术中手动处理测试结果的繁琐过程,提高了处理效率,降低了对处理人员的要求。另外,在本发明中,还将得到的测试用例、错误报表以及测试报告分别存储到对应的数据库中,因而实现了测试结果的统一管理,进而能够提供各项信息的查询,为后续的测试过程提供了很大便利。
下面结合一个具体的实施例详细描述一下本发明提供的测试结果的统一处理方法。图3示出了该方法的各个步骤中的消息交互流程。
如图3所示,在步骤S210中,接收并解析由至少一个测试脚本发来的XML格式的测试结果。
在步骤S210中,可以通过HTTP POST消息来接收上述XML格式的测试结果。其中,上述的测试脚本也可以称作测试工具,具体指用于测试某一产品,并根据该产品的测试流程生成测试结果的脚本。这里,测试脚本的数量可以为一个或多个,每个测试脚本可以分别用来测试不同的产品;或者,也可以由多个测试脚本统一测试相同的产品,以便得出更为准确的测试结果。在本发明中,无论各个测试脚本在产品的测试过程中采用何种程序语言进行测试,最终生成的测试结果都统一采用XML格式的文档编写。而且,XML格式的测试结果的具体格式规范是预先设置好的,下面就给出一个XML格式的测试结果的实例:
Figure BDA0000424714260000061
Figure BDA0000424714260000071
Figure BDA0000424714260000081
在上述实例中,最外层的节点名称为<testresult>,由此表明该文档是一个测试结果类型的文档。
在步骤S220中,获取上述测试结果中包含的所有测试用例,将测试用例存储到预设的用例数据库中。
下面以上述实例中的测试结果为例介绍一下步骤S220的具体实现过程。在本实施例中,根据XML格式的测试结果的具体格式规范,将测试结果中包含的测试用例通过三层节点构成的标识符表示,其中,三层节点进一步包括:作为第一层的产品节点、作为第二层的模块节点以及作为第三层的用例节点。
其中,作为第一层的产品节点,即上述实例中的<product>节点,该节点用于唯一标识一个待测产品。例如,在上述实例中,产品节点的数量为两个,节点名称分别为product1和product2,由此表示该测试结果中包含了两个待测产品的测试内容。
作为第二层的模块节点,即上述实例中的<module>节点,该节点用于唯一标识某一待测产品内的一个测试模块。例如,在具体测试时,由于产品功能较多,需要针对每一功能分别构造一个测试模块来完成对该功能的测试,具体到上述实例中,第一个待测产品(product1)具有两个测试模块,第一个测试模块的名称为“URL自动扫描/其他”,第二个测试模块的名称为“URL自动扫描/市场”。第二个待测产品(product2)具有一个测试模块,该测试模块的名称为“URL自动扫描/导航”。
作为第三层的用例节点,即上述实例中的<case>节点,该节点用于唯一地标识某一测试模块内的一个测试用例。例如,在具体测试时,针对某产品的一个具体功能,可能需要根据实际情况构造多个场景下的测试用例,以便全方位地测试该功能是否正常。具体到上述实例中,在“URL自动扫描/其他”这一测试模块中构造了一个名称为“官网”的测试用例,在“URL自动扫描/市场”这一测试模块中构造了两个名称分别为“蚕豆”和“烤瓜”的测试用例,在“URL自动扫描/导航”这一测试模块中则构造了两个名称分别为“hao360”和“彩票”的测试用例。其中,在每个<case>节点所标明的测试用例中,通过<steps>节点来表示该用例的各个执行步骤,通过<result>节点来表示该用例的执行结果,通过<reason>节点来表示失败的原因。
由此可见,通过三层节点构成的标识符,能够清楚地表示出各个产品内包含的各个测试模块,以及各个测试模块内进一步包含的各个测试用例。在本发明其他的实施例中,本领域技术人员也可以根据实际情况规定两层节点,甚至四层或五层节点构成的标识符,并且可以根据实际情况规定每层节点的名称和含义,本发明对标识符的具体实现形式不做限定,只要能够清楚地表示出待测产品的测试过程和测试结果即可。
基于XML格式的测试结果的上述格式规范,在步骤S220中,首先,获取测试结果中包含的上述三层节点构成的标识符,即分别查找上述的<product>节点、<module>节点和<case>节点;然后,根据标识符中的每一节点所标识的字符串来确定测试结果中包含的测试用例。具体地,首先查找<product>节点,以便确定测试结果中共包含几个待测产品;然后查找<module>节点,以便确定每一待测产品中包含几个测试模块;最后查找<case>节点,以便确定每一测试模块中包含几个测试用例,从而获取到测试结果中所包含的所有测试用例,即上述实例中的“官网”、“蚕豆”、“烤瓜”、“hao360”和“彩票”五个测试用例,并将这五个测试用例分别存储到预设的用例数据库中。其中,在向用例数据库中存储测试用例时,还可以先判断用例数据库中是否已经存储有相应的测试用例,如果判断结果为是,则无需重复存储,只有在判断结果为否时才存储该测试用例,由此保证用例数据库中存储的各个测试用例之间彼此互不重复,从而既节约存储空间,又便于后续的查询操作。
在步骤S230中,根据上述测试结果创建错误报表,将错误报表存储到预设的报表数据库中。其中,错误报表也叫“bug”,用于表示程序运行过程中的故障。
下面以上述实例中的测试结果为例介绍一下步骤S230的具体实现过程。根据XML格式的测试结果的格式规范,在上述实例的测试结果中,产品节点(<product>节点)中进一步包括“createbug”参数,该参数用于指示是否创建错误报表。例如,在product1这一产品中,“createbug”参数的参数值为true,由此表示该产品中所有测试失败的测试用例都需要创建错误报表;而在product2这一产品中,“createbug”参数的参数值为false,由此表示该产品中所有测试失败的测试用例都无需创建错误报表。因此,在步骤S230中,首先根据createbug”参数的参数值确定出需要为product1这一产品中测试失败的测试用例创建错误报表;然后,针对product1这一产品中的每一测试用例,获取其中用于指示测试结果的参数“result”,如果“result”的参数值为fail则表示该测试用例测试失败,如果“result”的参数值为pass则表示该测试用例测试成功。具体到上述实例中,“官网”这一测试用例,以及“烤瓜”这一测试用例的测试结果为失败,因此,在步骤S230中需要为“官网”和“烤瓜”这两个测试用例分别创建相应的错误报表,具体创建错误报表时,可以通过调用Bugzilla软件中的mysql接口来自动地创建错误报表。并且,将创建的两个错误报表分别存储到预设的报表数据库中,使报表数据库内存储了所有测试结果中所需的错误报表,以便于后续的查询操作。
在步骤S240中,根据步骤S220中得到的测试用例以及步骤S230中得到的错误报表生成测试报告,并将该测试报告存储到预设的报告数据库中。具体地,在该测试报告中,包含了测试结果中的每个待测产品中的各个测试模块,以及各个测试模块中的测试用例,并且还包括了测试失败的测试用例所对应的错误报表等信息,因此,通过测试报告,就可以直观地了解测试结果的具体内容。
另外,在步骤S240中生成的测试报告可以为多个,例如,结合上述实例来说,可以先生成一份测试报告,在该测试报告中包含测试结果中的所有待测产品的测试信息;然后,再根据待测产品的数量,将该测试报告拆分为多个子报告,每个子报告用于存储一个待测产品的测试信息;甚至,还可以再针对每个子报告中包含的测试模块的数量,进一步将该子报告拆分为多个部分,每个部分用于存储一个测试模块的测试信息。
并且,在报告数据库内存储了所有测试结果对应的测试报告及其子报告等信息,以便于后续的查询操作。
最后,在步骤S250中,获取测试结果中包含的用于指示是否发送测试报告的第一参数,当第一参数指示为发送测试报告时,将测试报告发送给预设终端。具体到上述实例中,该第一参数即为<mail>节点对应的参数,例如,在product1这一产品中,具有<mail>节点,因此需要将该产品对应的测试报告发送给预设终端;而在product2这一产品中,不具有<mail>节点,因此无需将该产品对应的测试报告发送给预设终端。具体地,在product1这一产品中,<mail>节点内包含如下信息:
<mail-to>guanjianjun360.cn;tanglei360.cn;</mail-to>
<mail-from>guanjianjun360.cn</mail-from>
<mail-title>[2012-08-2310:00:43]服务器URL扫描测试</mail-title>
其中,<mail-to>节点表示接收测试报告的预设终端的信息,在本实例中,需要将product1这一产品对应的测试报告发送给guanjianjun360.cn和tanglei360.cn所对应的邮箱地址。<mail-from>节点表示发送测试报告的邮箱地址,在本实例中,将通过guanjianjun360.cn这一邮箱地址来发送product1这一产品对应的测试报告。<mail-title>节点规定了发送的测试报告的名称,该名称反映了测试时间、测试内容等信息。在采用邮箱地址来收发测试报告时,上述接收测试报告的预设终端可以是邮件服务器(例如域名为mail.corp.qihoo.net的服务器),且该邮件服务器通过SMTP协议来接收测试报告。
除了采用邮箱地址来发送或接收测试报告之外,在本发明其他的实施例中,也可以通过其他方式,例如短消息、语音通话等多种方式来发送测试报告。另外,在本实例中,一个<mail-to>节点仅用于表示一份测试结果中的某一个待测产品所对应的测试报告是否需要发送,在其他的实例中,也可以由一个<mail-to>节点来表示一份测试结果中包含的所有待测产品所对应的测试报告是否需要发送。
另外,在本实施例中,除了能够根据测试结果的设置自动发送测试报告之外,还能够根据测试结果的设置自动发送错误报表。具体到上述实例中,如果存在“bug-reporter”和“bug-assignto”这一组参数,则表示需要发送错误报表,否则,则无需发送错误报表。例如,对于product1这一产品来说,需要发送错误报表,且根据“bug-reporter”的值可知,错误报表的发送者为“guanjianjun”,进一步地,对于其中的“URL自动扫描/其他”这一测试模块中的测试用例来说,根据“bug-assignto”的值可知,需将错误报表发送给“yanwei”;对于其中的“URL自动扫描/市场”这一测试模块中的测试用例来说,根据“bug-assignto”的值可知,需将错误报表发送给“shengzhe”。由此可见,在本发明中,还可以自动地将测试模块中的错误报表发送给负责该测试模块的负责人,以使该负责人及时了解测试情况,并且,还可以针对不同的情况,为不同的测试模块或一个测试模块中的不同测试用例分别指定不同的邮件接收地址(可通过收件人或抄送人来表示),由此大大简化了测试结果的分析过程,为测试提供了便利。
由此可见,通过上述步骤的执行,能够自动地根据测试结果创建测试报告,在此过程中,能够详细地分析出待测产品的数量和名称,每个待测产品所包含的测试模块的数量和名称,以及每一测试模块所具有的测试用例的数量和名称,并且还能够获取到每个测试模块或其中的测试用例的测试结果,而且还能够自动地向相关人员发送测试报告。在发送测试报告的过程中,还可以根据实际情况的设定,具体将测试报告的指定部分(例如某一测试模块或某一测试用例)发送给负责该部分的人员,从而能够大大简化测试人员内部的协调过程,提高测试效率,简化测试操作。
另外,由于在上述步骤中,还进一步将测试用例、错误报表以及测试报告分别存储到了相应的数据库中,因此,本实施例还可以进一步包括如下步骤:通过预设的第一web查询接口接收到测试用例查询请求后,根据用例数据库中的存储内容返回测试用例查询结果;通过预设的第二web查询接口接收到错误报表查询请求后,根据报表数据库中的存储内容返回错误报表查询结果;以及,通过预设的第三web查询接口接收到测试报告查询请求后,根据报告数据库中的存储内容返回测试报告查询结果。由此,能够为测试人员提供各种相关查询。其中,上述的三个web查询接口可以通过三个对应的查询按钮来实现,这三个查询按钮既可以直接显示在图1所示的统一处理装置20的显示界面上,也可以通过网络显示在查询客户端10的显示界面上,其中,查询客户端10可以是需要共享某一测试报告的测试人员所使用的电脑。
综上所述,本发明中的测试结果的统一处理方法具有如下优点:
首先,在该方法中所涉及到的各个传输接口(包括统一处理装置与测试脚本之间的传输接口、统一处理装置与各个数据库之间的存储接口、以及统一处理装置与各个查询客户端之间的查询接口)都是基于web的接口,与待测产品所使用的程序语言以及测试过程中所使用的程序语言无关。因而,操作者只需了解XML格式规范即可,不需要了解各类语言的编程特点,由此降低了对操作者的技术要求。
其次,在该方法中,能够自动地创建测试用例、错误报表,并据此生成测试报告,从而避免了手动处理测试结果的繁琐过程,大幅提高了测试结果的处理效率。而且,还能够根据预设情况自动地向相关人员发送错误报表或测试报告等信息,以使相关人员能够及时了解测试情况,从而为测试过程中所涉及的多个相关人员之间的协调带来了便利。
不仅如此,在该方法中,由于设置有多个数据库,还能够提供测试用例、错误报表以及测试报告等各项信息的查询,从而为测试过程中所涉及的多个相关人员之间的数据共享提供了方便。
图4示出了本发明实施例提供的测试结果的统一处理装置20的结构图。如图4所示,该装置20包括:接收模块21、测试用例获取模块22、错误报表创建模块23、测试报告生成模块24、以及发送模块25。
其中,接收模块21接收并解析由至少一个测试脚本发来的XML格式的测试结果。
测试用例获取模块22获取测试结果中包含的所有测试用例,将测试用例存储到预设的用例数据库中。
错误报表创建模块23根据测试结果创建错误报表,将错误报表存储到预设的报表数据库中。
其中,可选地,XML格式的测试结果中包含的测试用例通过三层节点构成的标识符表示,其中,三层节点进一步包括:作为第一层的产品节点、作为第二层的模块节点以及作为第三层的用例节点;则测试用例获取模块22获取测试结果中包含的三层节点构成的标识符,根据标识符所标识的字符串确定测试结果中包含的测试用例。其中,产品节点中进一步包括用于指示是否创建错误报表的第二参数,则错误报表创建模块23获取第二参数,当第二参数指示为创建错误报表时,为测试失败的测试用例创建错误报表。
测试报告生成模块24根据测试用例和错误报表生成测试报告,将测试报告存储到预设的报告数据库中。
发送模块25获取测试结果中包含的用于指示是否发送测试报告的第一参数,当第一参数指示为发送测试报告时,将测试报告发送给预设终端。
可选地,该装置进一步包括:第一web查询接口,适于在接收到测试用例查询请求后,根据用例数据库中的存储内容返回测试用例查询结果;第二web查询接口,适于在接收到错误报表查询请求后,根据报表数据库中的存储内容返回错误报表查询结果;以及,第三web查询接口,适于在接收到测试报告查询请求后,根据报告数据库中的存储内容返回测试报告查询结果。
关于该装置中的各个模块的具体工作过程可参照方法实施例中相应步骤的描述,此处不再赘述。
图5示出了本发明实施例提供的测试结果的统一处理系统的结构图。如图5所示,该系统包括如图4所示的统一处理装置20,以及与该统一处理装置20分别相连的用例数据库31、报表数据库32、报告数据库33以及查询客户端10。另外,在该系统中,还包括用于产生测试结果的测试脚本50以及用于接收测试报告的预设终端40。其中,关于统一处理装置20的具体细节及其内部包含的各个模块(如接收模块21、测试用例获取模块22、错误报表创建模块23、测试报告生成模块24以及发送模块25)可参照上一实施例的描述,此处不再赘述。
在本发明提供的测试结果的统一处理方法、装置及系统中,所有测试脚本发来的测试结果统一采用XML格式的文档编写,因此,能够自动地根据测试结果获取其中包含的所有测试用例、自动创建错误报表,还能自动根据测试用例和错误报表生成测试报告,从而避免了现有技术中手动处理测试结果的繁琐过程,提高了处理效率,降低了对处理人员的要求。另外,在本发明中,还将得到的测试用例、错误报表以及测试报告分别存储到对应的数据库中,因而实现了测试结果的统一管理,进而能够提供各项信息的查询,为后续的测试过程提供了很大便利。
在此提供的算法和显示不与任何特定计算机、虚拟系统或者其它设备固有相关。各种通用系统也可以与基于在此的示教一起使用。根据上面的描述,构造这类系统所要求的结构是显而易见的。此外,本发明也不针对任何特定编程语言。应当明白,可以利用各种编程语言实现在此描述的本发明的内容,并且上面对特定语言所做的描述是为了披露本发明的最佳实施方式。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
类似地,应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多的特征。更确切地说,如下面的权利要求书所反映的那样,发明方面在于少于前面公开的单个实施例的所有特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组件组合成一个模块或单元或组件,以及此外可以把它们分成多个子模块或子单元或子组件。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在下面的权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。
本发明的各个部件实施例可以以硬件实现,或者以在一个或者多个处理器上运行的软件模块实现,或者以它们的组合实现。本领域的技术人员应当理解,可以在实践中使用微处理器或者数字信号处理器(DSP)来实现根据本发明实施例的装置中的一些或者全部部件的一些或者全部功能。本发明还可以实现为用于执行这里所描述的方法的一部分或者全部的设备或者装置程序(例如,计算机程序和计算机程序产品)。这样的实现本发明的程序可以存储在计算机可读介质上,或者可以具有一个或者多个信号的形式。这样的信号可以从因特网网站上下载得到,或者在载体信号上提供,或者以任何其他形式提供。
应该注意的是上述实施例对本发明进行说明而不是对本发明进行限制,并且本领域技术人员在不脱离所附权利要求的范围的情况下可设计出替换实施例。在权利要求中,不应将位于括号之间的任何参考符号构造成对权利要求的限制。单词“包含”不排除存在未列在权利要求中的元件或步骤。位于元件之前的单词“一”或“一个”不排除存在多个这样的元件。本发明可以借助于包括有若干不同元件的硬件以及借助于适当编程的计算机来实现。在列举了若干装置的单元权利要求中,这些装置中的若干个可以是通过同一个硬件项来具体体现。单词第一、第二、以及第三等的使用不表示任何顺序。可将这些单词解释为名称。

Claims (10)

1.一种测试结果的统一处理方法,包括:
接收并解析由至少一个测试脚本发来的XML格式的测试结果;
获取所述测试结果中包含的所有测试用例,将所述测试用例存储到预设的用例数据库中;并且,根据所述测试结果创建错误报表,将所述错误报表存储到预设的报表数据库中;
根据所述测试用例和所述错误报表生成测试报告,将所述测试报告存储到预设的报告数据库中;
获取所述测试结果中包含的用于指示是否发送测试报告的第一参数,当所述第一参数指示为发送测试报告时,将所述测试报告发送给预设终端。
2.如权利要求1所述的方法,其中,所述XML格式的测试结果中包含的测试用例通过三层节点构成的标识符表示,其中,所述三层节点进一步包括:作为第一层的产品节点、作为第二层的模块节点以及作为第三层的用例节点;
则所述获取所述测试结果中包含的所有测试用例的步骤进一步包括:获取所述测试结果中包含的所述三层节点构成的标识符,根据所述标识符所标识的字符串确定所述测试结果中包含的测试用例。
3.如权利要求2所述的方法,其中,所述产品节点中进一步包括用于指示是否创建错误报表的第二参数,则所述根据所述测试结果创建错误报表的步骤进一步包括:获取所述第二参数,当所述第二参数指示为创建错误报表时,为测试失败的测试用例创建错误报表。
4.如权利要求1所述的方法,其中,进一步包括步骤:
通过预设的第一web查询接口接收到测试用例查询请求后,根据所述用例数据库中的存储内容返回测试用例查询结果;
通过预设的第二web查询接口接收到错误报表查询请求后,根据所述报表数据库中的存储内容返回错误报表查询结果;以及,
通过预设的第三web查询接口接收到测试报告查询请求后,根据所述报告数据库中的存储内容返回测试报告查询结果。
5.如权利要求1所述的方法,其中,通过HTTP POST消息接收所述XML格式的测试结果。
6.如权利要求1所述的方法,其中,所述将所述测试报告发送给预设终端时,通过邮件方式和/或短消息方式发送。
7.一种测试结果的统一处理装置,包括:
接收模块,适于接收并解析由至少一个测试脚本发来的XML格式的测试结果;
测试用例获取模块,适于获取所述测试结果中包含的所有测试用例,将所述测试用例存储到预设的用例数据库中;
错误报表创建模块,适于根据所述测试结果创建错误报表,将所述错误报表存储到预设的报表数据库中;
测试报告生成模块,适于根据所述测试用例和所述错误报表生成测试报告,将所述测试报告存储到预设的报告数据库中;
发送模块,适于获取所述测试结果中包含的用于指示是否发送测试报告的第一参数,当所述第一参数指示为发送测试报告时,将所述测试报告发送给预设终端。
8.如权利要求7所述的装置,其中,所述XML格式的测试结果中包含的测试用例通过三层节点构成的标识符表示,其中,所述三层节点进一步包括:作为第一层的产品节点、作为第二层的模块节点以及作为第三层的用例节点;
则所述测试用例获取模块适于:获取所述测试结果中包含的所述三层节点构成的标识符,根据所述标识符所标识的字符串确定所述测试结果中包含的测试用例。
9.如权利要求7所述的装置,其中,进一步包括:
第一web查询接口,适于在接收到测试用例查询请求后,根据所述用例数据库中的存储内容返回测试用例查询结果;
第二web查询接口,适于在接收到错误报表查询请求后,根据所述报表数据库中的存储内容返回错误报表查询结果;以及,
第三web查询接口,适于在接收到测试报告查询请求后,根据所述报告数据库中的存储内容返回测试报告查询结果。
10.一种测试结果的统一处理系统,包括:如权利要求7-10任一所述的统一处理装置,以及与所述统一处理装置分别相连的用例数据库、报表数据库、报告数据库以及查询客户端,其中,
所述用例数据库适于存储测试用例,所述报表数据库适于存储错误报表,所述报告数据库适于存储测试报告,所述查询客户端适于向所述统一处理装置发送测试用例查询请求、错误报表查询请求和/或测试报告查询请求,并接收所述统一处理装置返回的测试用例查询结果、错误报表查询结果和/或测试报告查询结果。
CN201310627148.3A 2013-11-28 2013-11-28 测试结果的统一处理方法、装置及系统 Expired - Fee Related CN103617118B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201310627148.3A CN103617118B (zh) 2013-11-28 2013-11-28 测试结果的统一处理方法、装置及系统

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201310627148.3A CN103617118B (zh) 2013-11-28 2013-11-28 测试结果的统一处理方法、装置及系统

Publications (2)

Publication Number Publication Date
CN103617118A true CN103617118A (zh) 2014-03-05
CN103617118B CN103617118B (zh) 2016-06-29

Family

ID=50167821

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201310627148.3A Expired - Fee Related CN103617118B (zh) 2013-11-28 2013-11-28 测试结果的统一处理方法、装置及系统

Country Status (1)

Country Link
CN (1) CN103617118B (zh)

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104243282A (zh) * 2014-09-12 2014-12-24 深圳创维数字技术有限公司 一种信息通知方法及服务器
CN106445805A (zh) * 2016-08-26 2017-02-22 上海合福信息科技有限公司 一种可视化测试报告生成方法
CN107741900A (zh) * 2016-08-26 2018-02-27 上海合福信息科技有限公司 一种自动测试方法
CN107885660A (zh) * 2017-10-31 2018-04-06 平安科技(深圳)有限公司 基金系统自动化测试管理方法、装置、设备及存储介质
CN109828913A (zh) * 2018-12-27 2019-05-31 北京新鼎峰软件科技有限公司 一种测试报告生成方法及装置
CN110287115A (zh) * 2019-06-26 2019-09-27 北京金山云网络技术有限公司 测试报告的生成方法、装置和服务器
CN112380140A (zh) * 2020-12-08 2021-02-19 安徽江淮汽车集团股份有限公司 智能座舱数据测试方法及系统
CN113973068A (zh) * 2021-10-20 2022-01-25 重庆紫光华山智安科技有限公司 混沌测试方法、装置、混沌测试平台及存储介质
CN117931679A (zh) * 2024-03-21 2024-04-26 成都佰维存储科技有限公司 版本测试结果发送方法、装置、可读存储介质及电子设备

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7836346B1 (en) * 2007-06-11 2010-11-16 Oracle America, Inc. Method and system for analyzing software test results
US8151248B1 (en) * 2007-10-31 2012-04-03 Sprint Communications Company L.P. Method and system for software defect management
CN102662833A (zh) * 2012-03-21 2012-09-12 天津书生软件技术有限公司 一种管理测试用例的方法
CN102880546A (zh) * 2012-09-03 2013-01-16 上海方正数字出版技术有限公司 一种基于xml数据库的软件集成测试方法及系统
CN103092864A (zh) * 2011-11-03 2013-05-08 无锡华润上华科技有限公司 一种生成测试数据报表的方法和系统

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7836346B1 (en) * 2007-06-11 2010-11-16 Oracle America, Inc. Method and system for analyzing software test results
US8151248B1 (en) * 2007-10-31 2012-04-03 Sprint Communications Company L.P. Method and system for software defect management
CN103092864A (zh) * 2011-11-03 2013-05-08 无锡华润上华科技有限公司 一种生成测试数据报表的方法和系统
CN102662833A (zh) * 2012-03-21 2012-09-12 天津书生软件技术有限公司 一种管理测试用例的方法
CN102880546A (zh) * 2012-09-03 2013-01-16 上海方正数字出版技术有限公司 一种基于xml数据库的软件集成测试方法及系统

Cited By (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104243282B (zh) * 2014-09-12 2018-09-21 深圳创维数字技术有限公司 一种信息通知方法及服务器
CN104243282A (zh) * 2014-09-12 2014-12-24 深圳创维数字技术有限公司 一种信息通知方法及服务器
CN106445805B (zh) * 2016-08-26 2020-06-12 上海合福信息科技有限公司 一种可视化测试报告生成方法
CN107741900A (zh) * 2016-08-26 2018-02-27 上海合福信息科技有限公司 一种自动测试方法
CN107741900B (zh) * 2016-08-26 2019-09-17 上海合福信息科技有限公司 一种自动测试方法
CN106445805A (zh) * 2016-08-26 2017-02-22 上海合福信息科技有限公司 一种可视化测试报告生成方法
CN107885660A (zh) * 2017-10-31 2018-04-06 平安科技(深圳)有限公司 基金系统自动化测试管理方法、装置、设备及存储介质
CN107885660B (zh) * 2017-10-31 2020-04-03 平安科技(深圳)有限公司 基金系统自动化测试管理方法、装置、设备及存储介质
CN109828913A (zh) * 2018-12-27 2019-05-31 北京新鼎峰软件科技有限公司 一种测试报告生成方法及装置
CN110287115A (zh) * 2019-06-26 2019-09-27 北京金山云网络技术有限公司 测试报告的生成方法、装置和服务器
CN112380140A (zh) * 2020-12-08 2021-02-19 安徽江淮汽车集团股份有限公司 智能座舱数据测试方法及系统
CN112380140B (zh) * 2020-12-08 2022-02-01 安徽江淮汽车集团股份有限公司 智能座舱数据测试方法及系统
CN113973068A (zh) * 2021-10-20 2022-01-25 重庆紫光华山智安科技有限公司 混沌测试方法、装置、混沌测试平台及存储介质
CN117931679A (zh) * 2024-03-21 2024-04-26 成都佰维存储科技有限公司 版本测试结果发送方法、装置、可读存储介质及电子设备

Also Published As

Publication number Publication date
CN103617118B (zh) 2016-06-29

Similar Documents

Publication Publication Date Title
CN103617118A (zh) 测试结果的统一处理方法、装置及系统
CN108574604B (zh) 测试方法和装置
CN111240653B (zh) 接口文档生成方法、装置及可读存储介质
CN111038906B (zh) 一种订单分拣方法和装置
CN109995612B (zh) 一种服务巡检方法、装置及电子设备
CN103714002B (zh) 基于配置系统的项目测试方法及装置
CN111026670B (zh) 测试用例的生成方法、测试用例的生成装置及存储介质
CN112463588A (zh) 一种自动化测试系统及方法、存储介质、计算设备
CN103686809A (zh) 提供移动终端故障问题解决方案的方法、移动终端和系统
CN105653318A (zh) 软件升级方法、装置及系统
CN111190807A (zh) 一种埋点测试方法及设备
CN110971447A (zh) 一种测试信息管理方法、装置、电子设备及可读存储介质
CN112817853A (zh) 一种自动测试方法、系统和电子设备
CN110648126A (zh) 支付类型配置方法、装置、服务器及存储介质
CN113138934B (zh) 自动测试的方法、介质、装置和计算设备
CN110489326B (zh) 基于ids的httpapi调试方法装置、介质和设备
CN110618943B (zh) 安防服务测试方法、装置、电子设备及可读存储介质
CN111382051A (zh) 一种api自动测试方法及测试装置
CN111026629A (zh) 一种测试脚本自动生成的方法和装置
CN112965745A (zh) 一种系统接入方法、装置、设备及计算机可读介质
CN113342678A (zh) 一种接口自动化测试方法、装置、电子设备和存储介质
CN111881112A (zh) 一种数据库配置方法、装置及相关设备
CN113626409B (zh) 一种测试资料处理方法、装置、设备及存储介质
CN114356344A (zh) 应用部署方法、装置、电子设备及存储介质
CN117271302A (zh) 一种微服务接口自动化测试方法、装置及相关设备

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C14 Grant of patent or utility model
GR01 Patent grant
CF01 Termination of patent right due to non-payment of annual fee
CF01 Termination of patent right due to non-payment of annual fee

Granted publication date: 20160629

Termination date: 20211128