一种残膜回收机防缠绕挑膜装置的制 一种秧草收获机用电力驱动行走机构

单元测试方法、装置、电子设备及存储介质与流程

2022-04-30 13:58:06 来源:中国专利 TAG:
1.本公开涉及自动化测试
技术领域
:,具体地涉及一种单元测试方法、装置、设备、介质和程序产品。
背景技术
::2.单元测试是对软件各模块进行的有针对性、覆盖较全面、较彻底的系统性测试。单元测试对于在开发早期发现程序的漏洞,以及提高程序的稳定性具有重要的意义。相关技术中,利用sal等数据库语句的单元测试方法需要利用公共数据仓库中的测试数据来执行单元测试任务。3.在实现本公开发明构思的过程中,发明人发现相关技术中至少存在以下问题:相关技术的单元测试方法对公共数据库的依赖性较强,当测试用例所依赖的数据库数据被修改或删除时,容易出现单元测试无法通过的情况。技术实现要素:4.鉴于上述问题,本公开提供了一种单元测试方法、装置、设备、介质和程序产品。5.根据本公开的第一个方面,提供了一种单元测试方法,包括:6.接收测试任务,其中,上述测试任务包括待执行的测试用例的标识信息;7.根据来自数据仓库系统中的测试热点数据生成与上述测试用例的标识信息对应的内存数据库;8.在上述测试热点数据中包括与上述测试用例对应的测试基础数据的情况下,根据上述测试用例和上述测试基础数据执行上述测试任务,得到测试结果;以及9.向上述数据仓库系统发送上述测试结果,以便上述数据仓库系统根据上述测试结果更新上述数据仓库系统中的测试热点数据。10.根据本公开的实施例,上述测试任务包括m个测试子任务,每个上述测试子任务对应一个测试用例,其中,m≥2;11.其中,上述根据来自数据仓库系统中的测试热点数据生成与上述测试用例的标识信息对应的内存数据库包括:12.针对上述m个测试子任务中的每个上述测试子任务,根据来自上述数据仓库系统中的测试热点数据生成与上述测试子任务对应的上述内存数据库;13.其中,上述在上述测试热点数据中包括与上述测试用例对应的测试基础数据的情况下,根据上述测试用例和上述测试基础数据执行上述测试任务,得到测试结果包括:14.针对上述m个测试子任务中的每个上述测试子任务,在上述测试热点数据包括与上述测试子任务对应的测试基础数据的情况下,根据与上述测试子任务对应的上述测试用例和上述测试基础数据执行上述测试子任务,得到与上述测试子任务对应的测试结果;15.其中,上述向上述数据仓库系统发送上述测试结果,以便上述数据仓库系统根据上述测试结果更新上述数据仓库系统中的测试热点数据包括:16.向上述数据仓库系统发送由执行上述m个测试子任务得到的m个测试结果,以便上述数据仓库系统根据上述m个测试结果和预设计算规则更新上述数据仓库系统中的测试热点数据。17.根据本公开的实施例,上述单元测试方法还包括:18.查询上述数据仓库系统中与上述测试任务对应的测试结果,得到第一查询结果;19.针对m个上述内存数据库中的每个上述内存数据库,查询上述内存数据库中与上述测试子任务对应的测试结果,得到第二查询结果;20.将上述第一查询结果与上述第二查询结果进行比对,得到比对结果;21.在确定上述比对结果表明上述第一查询结果和上述第二查询结果满足预设条件的情况下,利用上述第一查询结果更新上述内存数据库中的测试热点数据。22.根据本公开的实施例,上述根据来自数据仓库系统中的测试热点数据生成与上述测试用例的标识信息对应的内存数据库包括:23.生成与上述测试用例的标识信息对应的上述内存数据库;24.利用预先设置的配置文件,在上述内存数据库中生成基础数据空表;25.从上述数据仓库系统中获取上述测试热点数据;26.将上述测试热点数据存储至上述内存数据库中的上述基础数据空表中。27.根据本公开的实施例,上述单元测试方法还包括:28.根据预设字段生成初始化表格文件;29.生成与上述预设字段对应的示例数据文件;30.根据上述初始化表格文件和上述示例数据文件生成上述配置文件。31.根据本公开的实施例,上述利用预先设置的配置文件,在上述内存数据库中生成基础数据空表包括:32.根据上述初始化表格文件在上述内存数据库中生成初始化表格;33.将上述示例数据文件中的示例数据存储至上述初始化表格中,得到上述基础数据空表。34.根据本公开的实施例,上述测试热点数据包括上述数据仓库系统中调用频次满足预设值的测试基础数据。35.根据本公开的实施例,上述单元测试方法还包括:36.在上述测试热点数据中不包括与上述测试用例对应的测试基础数据的情况下,从上述数据仓库系统中获取与上述测试用例对应的测试基础数据。37.本公开的第二方面提供了一种单元测试装置,包括:38.接收模块,用于接收测试任务,其中,上述测试任务包括待执行的测试用例的标识信息;39.第一生成模块,用于根据来自数据仓库系统中的测试热点数据生成与上述测试用例的标识信息对应的内存数据库;40.执行模块,用于在上述测试热点数据中包括与上述测试用例对应的测试基础数据的情况下,根据上述测试用例和上述测试基础数据执行上述测试任务,得到测试结果;以及41.发送模块,用于向上述数据仓库系统发送上述测试结果,以便上述数据仓库系统根据上述测试结果更新上述数据仓库系统中的测试热点数据。42.本公开的第三方面提供了一种电子设备,包括:一个或多个处理器;存储器,用于存储一个或多个程序,其中,当上述一个或多个程序被上述一个或多个处理器执行时,使得一个或多个处理器执行上述单元测试方法。43.本公开的第四方面还提供了一种计算机可读存储介质,其上存储有可执行指令,该指令被处理器执行时使处理器执行上述单元测试方法。44.本公开的第五方面还提供了一种计算机程序产品,包括计算机程序,该计算机程序被处理器执行时实现上述单元测试方法。45.根据本公开的实施例,通过接收包括待执行的测试用例的标识信息的测试任务,根据来自数据仓库系统中的测试热点数据生成与测试用例的标识信息对应的内存数据库;然后在测试热点数据中包括与测试用例对应的测试基础数据的情况下,根据测试用例和测试基础数据执行测试任务,得到测试结果;之后向数据仓库系统发送测试结果,以便数据仓库系统根据测试结果更新数据仓库系统中的测试热点数据,保证数据仓库系统中的测试热点数据和内存数据库中的测试热点数据保持一致。本公开提供的技术方案在内存数据库中存储测试热点数据,利用内存数据库中的热点数据执行测试用例,降低了对数据仓库系统的依赖性,当测试用例所依赖的数据仓库系统中的数据被修改或删除时,不会影响影响单元测试的正常进行。因此,本公开的技术方案至少部分解决了相关技术中单元测试方法对数据仓库系统依赖性较强的技术问题。附图说明46.通过以下参照附图对本公开实施例的描述,本公开的上述内容以及其他目的、特征和优点将更为清楚,在附图中:47.图1示意性示出了根据本公开实施例的单元测试方法、装置、设备、介质和程序产品的应用场景图;48.图2示意性示出了根据本公开实施例的单元测试方法的流程图;49.图3示意性示出了根据本公开另一实施例的单元测试方法的流程图;50.图4示意性示出了根据本公开的实施例中内存数据库更新方法的流程图;51.图5示意性示出了根据本公开另一实施例的单元测试方法的流程图;52.图6示意性示出了根据本公开实施例的单元测试装置的结构框图;53.图7示意性示出了根据本公开另一实施例的单元测试装置的结构框图;以及54.图8示意性示出了根据本公开实施例的适于实现单元测试方法的电子设备的方框图。具体实施方式55.以下,将参照附图来描述本公开的实施例。但是应该理解,这些描述只是示例性的,而并非要限制本公开的范围。在下面的详细描述中,为便于解释,阐述了许多具体的细节以提供对本公开实施例的全面理解。然而,明显地,一个或多个实施例在没有这些具体细节的情况下也可以被实施。此外,在以下说明中,省略了对公知结构和技术的描述,以避免不必要地混淆本公开的概念。56.在此使用的术语仅仅是为了描述具体实施例,而并非意在限制本公开。在此使用的术语“包括”、“包含”等表明了所述特征、步骤、操作和/或部件的存在,但是并不排除存在或添加一个或多个其他特征、步骤、操作或部件。57.在此使用的所有术语(包括技术和科学术语)具有本领域技术人员通常所理解的含义,除非另外定义。应注意,这里使用的术语应解释为具有与本说明书的上下文相一致的含义,而不应以理想化或过于刻板的方式来解释。58.在使用类似于“a、b和c等中至少一个”这样的表述的情况下,一般来说应该按照本领域技术人员通常理解该表述的含义来予以解释(例如,“具有a、b和c中至少一个的系统”应包括但不限于单独具有a、单独具有b、单独具有c、具有a和b、具有a和c、具有b和c、和/或具有a、b、c的系统等)。59.在软件开发过程中,测试驱动开发的工作模式也逐渐被软件开发者认同和赞美。而单元测试是测试驱动开发的主体测试构成,是对软件各模块进行的有针对性、覆盖较全面、较彻底的系统性测试。单元测试对于在开发早期发现程序的漏洞,以及提高程序的稳定性具有重要的意义。60.在相关技术中,在写sql等数据库语句的单元测试时,所有的单元测试语句依赖公用的一个数据库,基于公用的数据库进行单元测试的执行操作。但是,相关技术中至少存在以下问题:相关技术的单元测试方法对公用数据库依赖性较强,当测试用例所依赖的数据库数据被修改或删除时,或者在一个新的环境下所依赖的数据库不存在时,容易出现单元测试无法通过的情况。61.有鉴于此,本公开针对以上技术问题,接收到测试任务时,通过根据来自数据仓库系统中的测试热点数据自动生成与测试用例对应的内存数据库;在进行测试时,利用内存数据库中的测试热点数据执行测试用例;测试任务执行结束后将内存数据库中变化的测试热点数据自动同步至数据仓库系统中,以保证测试热点数据的可靠性。本公开提供的技术方案在内存数据库中存储测试热点数据,利用内存数据库中的测试热点数据执行测试用例,通过利用内存数据库模拟数据仓库系统环境,使得每个单元测试用例使用一个单独的内存数据库进行测试执行,降低了对数据仓库系统的依赖性,能够很好地应用于海量数据和数据模型复杂场景。因此,本公开的技术方案至少部分解决了相关技术中单元测试方法对数据仓库系统依赖性较强的技术问题。62.具体地,本公开的实施例提供了一种单元测试方法,包括:接收测试任务,其中,上述测试任务包括待执行的测试用例的标识信息;根据来自数据仓库系统中的测试热点数据生成与上述测试用例的标识信息对应的内存数据库;在上述测试热点数据中包括与上述测试用例对应的测试基础数据的情况下,根据上述测试用例和上述测试基础数据执行上述测试任务,得到测试结果;以及向上述数据仓库系统发送上述测试结果,以便上述数据仓库系统根据上述测试结果更新上述数据仓库系统中的测试热点数据。63.需要说明的是,本公开实施例提供的单元测试方法和装置可用于计算机领域或金融领域。本公开实施例提供的单元测试方法和装置也可用于除计算机领域和金融领域之外的任意领域。本公开实施例提供的单元测试方法和装置的应用领域不做限定。64.在本公开的技术方案中,在获取或采集用户个人信息之前,均获取了用户的授权或同意。65.在本公开的技术方案中,对数据的获取、收集、存储、使用、加工、传输、提供、公开和应用等处理,均符合相关法律法规的规定,采取了必要保密措施,且不违背公序良俗。66.图1示意性示出了根据本公开实施例的单元测试方法、装置、设备、介质和程序产品的应用场景图。67.如图1所示,根据该实施例的应用场景100可以包括网络、终端设备和服务器。网络104用以在终端设备101、102、103和服务器105之间提供通信链路的介质。网络104可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。68.用户可以使用终端设备101、102、103通过网络104与服务器105交互,以接收或发送消息等。终端设备101、102、103上可以安装有各种通讯客户端应用,例如测试类应用、购物类应用、网页浏览器应用、搜索类应用、即时通信工具、邮箱客户端、社交平台软件等(仅为示例)。69.终端设备101、102、103可以是具有显示屏并且支持网页浏览的各种电子设备,包括但不限于智能手机、平板电脑、膝上型便携计算机和台式计算机等等。70.服务器105可以是提供各种服务的服务器,例如对用户利用终端设备101、102、103所浏览的网站提供支持的后台管理服务器(仅为示例)。后台管理服务器可以对接收到的用户请求等数据进行分析等处理,并将处理结果(例如根据用户请求获取或生成的网页、信息、或数据等)反馈给终端设备。71.需要说明的是,本公开实施例所提供的单元测试方法一般可以由服务器105执行。相应地,本公开实施例所提供的单元测试装置一般可以设置于服务器105中。本公开实施例所提供的单元测试方法也可以由不同于服务器105且能够与终端设备101、102、103和/或服务器105通信的服务器或服务器集群执行。相应地,本公开实施例所提供的单元测试装置也可以设置于不同于服务器105且能够与终端设备101、102、103和/或服务器105通信的服务器或服务器集群中。或者,本公开实施例所提供的单元测试方法也可以由终端设备101、102、或103执行,或者也可以由不同于终端设备101、102、或103的其他终端设备执行。相应地,本公开实施例所提供的单元测试装置也可以设置于终端设备101、102、或103中,或设置于不同于终端设备101、102、或103的其他终端设备中。72.应该理解,图1中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。73.以下将基于图1描述的场景,通过图2~图5对公开实施例的单元测试方法进行详细描述。74.图2示意性示出了根据本公开实施例的单元测试方法的流程图。75.如图2所示,该实施例的单元测试方法包括操作s210~操作s240,该单元测试方法可以服务器执行。76.在操作s210,接收测试任务,其中,测试任务包括待执行的测试用例的标识信息。77.根据本公开的实施例,待执行的测试用例的标识信息例如可以包括能够确定待执行的测试用例的信息。例如,待执行的测试用例的标识信息可以包括待执行的测试用例的编号、待执行的测试用例的名称等。78.根据本公开的实施例,测试任务可以包括一个待执行的测试用例,还可以包括多个待执行的测试用例,具体的测试用例数量可根据具体的测试任务确定,本公开实施例对测试任务包括的待执行的测试用例的数量不做限定。79.在操作s220,根据来自数据仓库系统中的测试热点数据生成与测试用例的标识信息对应的内存数据库。80.根据本公开的实施例,数据仓库系统是存储有测试基础数据、测试用例及其他数据的公共数据库。内存数据库是将数据放在内存中直接操作的数据库。81.根据本公开的实施例,测试热点数据可以包括人工提前确定的测试基础数据。例如,对人工确定的测试基础数据进行标记,将带有标记的测试基础数据存入内存数据库中。82.根据本公开的实施例,上述测试热点数据包括上述数据仓库系统中调用频次满足预设值的测试基础数据。83.根据本公开的实施例,测试热点数据例如可以包括数据仓库系统中调用频次超过1000次的测试基础数据。84.根据本公开的实施例,将数据仓库系统中调用频次满足预设值的测试基础数据存入内存数据库中,执行测试任务时,调用内存数据库即可,降低了对数据仓库系统的依赖。85.在操作s230,在测试热点数据中包括与测试用例对应的测试基础数据的情况下,根据测试用例和测试基础数据执行测试任务,得到测试结果。86.根据本公开的实施例,上述单元测试方法还包括:在上述测试热点数据中不包括与上述测试用例对应的测试基础数据的情况下,从上述数据仓库系统中获取与上述测试用例对应的测试基础数据。87.根据本公开的实施例,确定内存数据库包括用于执行测试用例的测试基础数据的情况下,测试用例基于该测试基础数据执行测试任务,得到测试结果。在内存数据库中不包括用于执行测试用例的测试基础数据的情况下,从数据仓库系统中获取与测试用例对应的测试基础数据后,再基于该测试基础数据执行测试任务,得到测试结果。88.根据本公开的实施例,由于本公开中的测试热点数据是调用频次满足预设值的测试基础数据,则测试热点数据中包括了常用的测试基础数据,一般情况下无需从数据仓库系统中获取测试基础数据。从而有助于降低对数据仓库系统的依赖性,并减少了对数据仓库系统的调用次数,提高系统的性能。89.在操作s240,向数据仓库系统发送测试结果,以便数据仓库系统根据测试结果更新数据仓库系统中的测试热点数据。90.根据本公开的实施例,将内存数据库中的测试结果发送至数据仓库系统中,以更新数据仓库系统中的测试热点数据,使得数据仓库系统中的测试热点数据与内存数据库中的测试热点数据同步变化,以保证测试热点数据的一致性,提高数据的可靠性。91.根据本公开的实施例,通过接收包括待执行的测试用例的标识信息的测试任务,根据来自数据仓库系统中的测试热点数据生成与测试用例的标识信息对应的内存数据库;然后在测试热点数据中包括与测试用例对应的测试基础数据的情况下,根据测试用例和测试基础数据执行测试任务,得到测试结果;之后向数据仓库系统发送测试结果,以便数据仓库系统根据测试结果更新数据仓库系统中的测试热点数据,保证数据仓库系统中的测试热点数据和内存数据库中的测试热点数据保持一致。本公开提供的技术方案在内存数据库中存储测试热点数据,利用内存数据库中的热点数据执行测试用例,降低了对数据仓库系统的依赖性,当测试用例所依赖的数据仓库系统中的数据被修改或删除时,不会影响影响单元测试的正常进行。因此,本公开的技术方案至少部分解决了相关技术中单元测试方法对数据仓库系统依赖性较强的技术问题。92.根据本公开的实施例,测试用例数据通常存储在数据仓库系统中,由于数据仓库系统中的数据量庞大,达到上亿级,使得数据仓库系统灵活性差,对数据增删改查的时间较长。本公开的技术方案将实际测试用例常用的数据,即测试热点数据,存入内存数据库中,由于测试热点数据的数据量较小,为几十或者几百个,使得利用内存数据库执行测试用例时能够提高执行效率。同时,由于内存数据库中的数据量较少,还有助于缩短对数据增删改查的时间。93.根据本公开的实施例,上述测试任务包括m个测试子任务,每个上述测试子任务对应一个测试用例,其中,m≥2;其中,上述根据来自数据仓库系统中的测试热点数据生成与上述测试用例的标识信息对应的内存数据库包括:针对上述m个测试子任务中的每个上述测试子任务,根据来自上述数据仓库系统中的测试热点数据生成与上述测试子任务对应的上述内存数据库;其中,上述在上述测试热点数据中包括与上述测试用例对应的测试基础数据的情况下,根据上述测试用例和上述测试基础数据执行上述测试任务,得到测试结果包括:针对上述m个测试子任务中的每个上述测试子任务,在上述测试热点数据包括与上述测试子任务对应的测试基础数据的情况下,根据与上述测试子任务对应的上述测试用例和上述测试基础数据执行上述测试子任务,得到与上述测试子任务对应的测试结果;其中,上述向上述数据仓库系统发送上述测试结果,以便上述数据仓库系统根据上述测试结果更新上述数据仓库系统中的测试热点数据包括:向上述数据仓库系统发送由执行上述m个测试子任务得到的m个测试结果,以便上述数据仓库系统根据上述m个测试结果和预设计算规则更新上述数据仓库系统中的测试热点数据。94.根据本公开的实施例,在测试任务包括多个测试子任务的情况下,每个测试子任务对应一个测试用例,且每个测试子任务对应一个内存数据库,使得每个测试子任务使用独立的内存数据库进行测试执行,能够很好地应用于海量数据和数据模型复杂场景。95.根据本公开的实施例,多个测试子任务生成多个测试结果,将多个测试结果依次发送至数据仓库系统中,数据仓库系统根据发送的多个测试结果和预设计算规则确定与测试任务对应的最终测试结果,并利用该最终测试结果更新数据仓库系统中的测试热点数据。96.在本公开的其中一个实施例中,例如报价的测试任务,由于报价结果受多个因素影响,则每个因素为一个测试子任务,每个测试子任务单独执行后得到的测试结果是在该因素的影响下得出的测试结果;然后将多个测试子任务的测试结果发送给数据仓库系统,数据仓库系统根据多个因素下的测试结果确定最终的测试结果,即报价的最终测试结果。97.更具体地,对于报价的测试任务,包括三个测试子任务,分别为第一测试子任务、第二测试子任务和第三测试子任务,第一测试子任务对应第一测试用例、第二测试子任务对应第二测试用例、第三测试子任务对应第三测试用例。第一测试子任务调用第一内存数据库,利用第一测试用例进行测试执行后得到第一测试结果,第一测试结果存储至第一内存数据库中;第二测试子任务调用第二内存数据库,利用第二测试用例进行测试执行后得到第二测试结果,第二测试结果存储至第二内存数据库中;第三测试子任务调用第三内存数据库,利用第三测试用例进行测试执行后得到第三测试结果,第三测试结果存储至第三内存数据库中。然后将第一测试结果、第二测试结果和第三测试结果依次发送给数据仓库系统,数据仓库系统根据第一测试结果、第二测试结果和第三测试结果和预设的计算规则确定测试任务的最终测试结果,并利用最终测试结果更新测试热点数据。98.根据本公开的实施例,上述单元测试方法还包括将m个测试子任务中的每个测试子任务存储至对应的队列中;依次判断各个队列中的测试子任务是否执行完成,在测试子任务执行完成后,将测试子任务对应的测试结果发送至数据仓库系统中。99.图3示意性示出了根据本公开另一实施例的单元测试方法的流程图。100.如图3所示,以测试任务包括三个测试子任务为例,该单元测试方法包括操作s301~操作s319。101.在操作s301,接收测试任务,其中,测试任务包括第一测试子任务、第二测试子任务和第三测试子任务;第一测试子任务对应第一测试用例、第二测试子任务对应第二测试用例、第三测试子任务对应第三测试用例。102.第一测试子任务、第二测试子任务和第三测试子任务分别执行。103.第一测试子任务执行操作s302~操作s306;第二测试子任务执行操作s307~操作s311;第一测试子任务执行操作s312~操作s316。104.在操作s302,根据来自数据仓库系统中的测试热点数据生成与第一测试用例对应的第一内存数据库。105.在操作s303,判断测试热点数据中是否包括第一测试基础数据。在测试热点数据中不包括第一测试基础数据的情况下,执行操作s304;在测试热点数据中包括第一测试基础数据的情况下,执行操作s305。106.在操作s304,从数据仓库系统获取第一测试基础数据。107.在操作s305,根据第一测试用例和第一测试基础数据执行第一测试子任务,得到第一测试结果。108.在操作s306,向数据仓库系统发送第一测试结果。109.在操作s307,根据来自数据仓库系统中的测试热点数据生成与第二测试用例对应的第二内存数据库。110.在操作s308,判断测试热点数据中是否包括第二测试基础数据。在测试热点中数据不包括第二测试基础数据的情况下,执行操作s309;在测试热点数据中包括第二测试基础数据的情况下,执行操作s310。111.在操作s309,从数据仓库系统获取第二测试基础数据。112.在操作s310,根据第二测试用例和第二测试基础数据执行第二测试子任务,得到第二测试结果。113.在操作s311,向数据仓库系统发送第二测试结果。114.在操作s312,根据来自数据仓库系统中的测试热点数据生成与第三测试用例对应的第三内存数据库。115.在操作s313,判断测试热点数据中是否包括第三测试基础数据。在测试热点数据中不包括第三测试基础数据的情况下,执行操作s314;在测试热点数据中包括第三测试基础数据的情况下,执行操作s315。116.在操作s314,从数据仓库系统获取第三测试基础数据。117.在操作s315,根据第三测试用例和第三测试基础数据执行第三测试子任务,得到第三测试结果。118.在操作s316,向数据仓库系统发送第三测试结果。119.在操作s317,数据仓库系统获取第一测试结果、第二测试结果和第三测试结果。120.在操作s318,数据仓库系统根据第一测试结果、第二测试结果和第三测试结果以及预设的计算规则确定与测试任务对应的最终测试结果。121.在操作s319,利用最终测试结果更新数据仓库系统中的测试热点数据。122.根据本公开的实施例,上述单元测试方法还包括:查询上述数据仓库系统中与上述测试任务对应的测试结果,得到第一查询结果;针对m个上述内存数据库中的每个上述内存数据库,查询上述内存数据库中与上述测试子任务对应的测试结果,得到第二查询结果;将上述第一查询结果与上述第二查询结果进行比对,得到比对结果;在确定上述比对结果表明上述第一查询结果和上述第二查询结果满足预设条件的情况下,利用上述第一查询结果更新上述内存数据库中的测试热点数据。123.根据本公开的实施例,第一查询结果可以包括与测试任务对应的最终测试结果以及所有测试子任务的测试结果。第二查询结果包括内存数据库中与测试子任务对应的测试结果。预设条件例如可以包括第一查询结果中包含第二查询结果,且第二查询结果中测试子任务对应的测试结果与第一查询结果中测试任务对应的最终测试结果是否一致。124.根据本公开的实施例,在第一查询结果中包含第二查询结果,且第二查询结果中测试子任务对应的测试结果与第一查询结果中测试任务对应的最终测试结果不一致的情况下,利用第一查询结果中测试任务对应的最终测试结果更新内存数据库中的测试热点数据,保证内存数据库中的测试热点数据与数据仓库系统中的测试热点数据保持一致。125.根据本公开的实施例,在第一查询结果中不包含第二查询结果的情况下,向数据仓库系统发送测试子任务对应的测试结果。126.在本公开的其中一个实施例中,例如报价的测试任务,包括第一测试子任务和第二测试子任务。第一查询结果可以包括与测试任务对应的最终测试结果、与第一测试子任务对应的第一测试结果和与第二测试子任对应的第二测试结果。对于第一测试子任务,第二查询结果可以包括第一内存数据库中的第一测试结果;然后将第一查询结果和第二查询结果比对,得到第一比对结果;在第一比对结果表明第一查询结果中包含第二查询结果,且第一查询结果中的最终测试结果与第二查询结果中的第一测试结果不一致的情况下,利用最终测试结果更新第一内存数据库中的测试热点数据。对于第二测试子任务,第二查询结果可以包括第二内存数据库中的第二测试结果;然后将第一查询结果和第二查询结果比对,得到第二比对结果;在第二比对结果表明第一查询结果中包含第二查询结果,且第一查询结果中的最终测试结果与第二查询结果中的第二测试结果不一致的情况下,利用最终测试结果更新第二内存数据库中的测试热点数据。127.图4示意性示出了根据本公开的实施例中内存数据库更新方法的流程图。128.根据本公开的实施例,测试任务包括多个测试子任务,且每个测试子任务对应一个内存数据库,每个内存数据库均需要执行相同的操作以更新内存数据库中的测试热点数据,图4以更新第一内存数据库中的测试热点数据为例进行说明。129.如图4所示,该方法包括操作s401~操作s407。130.在操作s401,第一测试子任务对应的第一内存数据库向数据仓库系统发送查询请求,其中,查询请求用于查询数据仓库系统中与测试任务对应的最终测试结果。131.在操作s402,数据仓库系统响应于查询请求,查询测试任务对应的最终测试结果,得到第一查询结果。132.在操作s403,查询第一内存数据库中与第一测试子任务对应的第一测试结果,得到第二查询结果。133.在操作s404,将第一查询结果与第二查询结果进行比对,得到比对结果。134.在操作s405,判断比对结果中第一查询结果和第二查询结果是否一致。在确定第一查询结果和第二查询结果不一致的情况下,执行操作s406;在确定第一查询结果和第二查询结果保持一致的情况下,执行操作s407。135.在操作s406,利用第一查询结果中的最终测试结果更新第一内存数据库中的测试热点数据。136.在操作s407,无需更新第一内存数据库中的测试热点数据。137.根据本公开的实施例,上述根据来自数据仓库系统中的测试热点数据生成与上述测试用例的标识信息对应的内存数据库包括:生成与上述测试用例的标识信息对应的上述内存数据库;利用预先设置的配置文件,在上述内存数据库中生成基础数据空表;从上述数据仓库系统中获取上述测试热点数据;将上述测试热点数据存储至上述内存数据库中的上述基础数据空表中。138.根据本公开的实施例,基础数据空表例如可以包括用于存储测试热点数据的表格。139.根据本公开的实施例,上述单元测试方法还包括:根据预设字段生成初始化表格文件;生成与上述预设字段对应的示例数据文件;根据上述初始化表格文件和上述示例数据文件生成上述配置文件。140.根据本公开的实施例,预设字段例如可以包括初始化表格中需要填写的信息字段。例如,预设字段可以包括数据名称、数据类型、数据大小等信息。141.根据本公开的实施例,预设字段文件例如可以包括init-table.sql文件;示例数据文件例如可以包括data.sql文件。将预设字段文件init-table.sql添至resources的sql目录中,将示例数据文件data.sql添加至application-test.yml文件中生成配置文件。142.根据本公开的实施例,上述利用预先设置的配置文件,在上述内存数据库中生成基础数据空表包括:根据上述初始化表格文件在上述内存数据库中生成初始化表格;将上述示例数据文件中的示例数据存储至上述初始化表格中,得到上述基础数据空表。143.根据本公开的实施例,在服务器上配置内存数据库包括在pom.xml的dependency模块加入内存数据库的依赖,然后新增测试环境配置文件,在resources目录添加application-test.yml,添加内存数据库连接配置,同时在mybatis的xml配置里增加内存数据库的依赖。144.图5示意性示出了根据本公开另一实施例的单元测试方法的流程图。145.如图5所示,该单元测试方法包括操作s501~操作s511。146.在操作s501,根据预设字段生成初始化表格文件。147.在操作s502,生成与预设字段对应的示例数据文件。148.在操作s503,根据初始化表格文件和示例数据文件生成配置文件。149.在操作s504,接收测试任务,其中,测试任务包括待执行的测试用例的标识信息。150.在操作s505,生成与测试用例的标识信息对应的内存数据库。151.在操作s506,根据初始化表格文件在内存数据库中生成初始化表格。152.在操作s507,将示例数据文件中的示例数据存储至初始化表格中,得到基础数据空表。153.在操作s508,从数据仓库系统中获取测试热点数据。154.在操作s509,将测试热点数据存储至内存数据库中的基础数据空表中。155.在操作s510,在测试热点数据中包括与测试用例对应的测试基础数据的情况下,根据测试用例和测试基础数据执行测试任务,得到测试结果。156.在操作s511,向数据仓库系统发送测试结果,以便数据仓库系统根据测试结果更新数据仓库系统中的测试热点数据。157.根据本公开的实施例,本公开提供一种利用内存数据库来优化sql等数据库语句的单元测试方法,通过在服务器上安装部署内存数据库,将数据仓库系统中的测试热点数据,缓存到内存数据库中,并配置相应的数据同步方式,将内存数据库中变化的测试热点数据自动同步到数据仓库系统中,以保证数据的可靠性,利用了内存数据库技术,解决了sql语句的单元测试对于公用数据库过于依赖的技术问题,提高了系统的性能。158.根据本公开的实施例,本公开采用内存数据库的技术,将sql语句等数据库语言的单元测试,缓存到内存中,实现了内存数据库与服务器数据库的松耦合。159.根据本公开的实施例,本公开提供了一种内存数据库的数据同步方式,将sql语句的单元测试执行后变化的测试热点数据自动同步到数据仓库系统库中,能灵活创建和管理内存数据库。160.根据本公开的实施例,本公开聚焦于sql语句等数据库语言的单元测试执行情况,提升了执行的性能。161.需要说明的是,本公开实施例中的流程图所示的操作除非明确说明不同操作之间存在执行的先后顺序,或者不同操作在技术实现上存在执行的先后顺序,否则,多个操作之间的执行顺序可以不分先后,多个操作也可以同时执行。162.基于上述单元测试方法,本公开还提供了一种单元测试装置。以下将结合图6对该装置进行详细描述。163.图6示意性示出了根据本公开实施例的单元测试装置的结构框图。164.如图6所示,该实施例的单元测试装置600包括接收模块610、第一生成模块620、执行模块630和发送模块640。165.接收模块610用于接收测试任务,其中,上述测试任务包括待执行的测试用例的标识信息。在一实施例中,接收模块610可以用于执行前文描述的操作s210,在此不再赘述。166.第一生成模块620用于根据来自数据仓库系统中的测试热点数据生成与上述测试用例的标识信息对应的内存数据库。在一实施例中,第一生成模块620可以用于执行前文描述的操作s220,在此不再赘述。167.执行模块630用于在上述测试热点数据中包括与上述测试用例对应的测试基础数据的情况下,根据上述测试用例和上述测试基础数据执行上述测试任务,得到测试结果。在一实施例中,执行模块630可以用于执行前文描述的操作s230,在此不再赘述。168.发送模块640用于向上述数据仓库系统发送上述测试结果,以便上述数据仓库系统根据上述测试结果更新上述数据仓库系统中的测试热点数据。在一实施例中,发送模块640可以用于执行前文描述的操作s240,在此不再赘述。169.根据本公开的实施例,上述测试任务包括m个测试子任务,每个上述测试子任务对应一个测试用例,其中,m≥2。170.根据本公开的实施例,第一生成模块还用于针对上述m个测试子任务中的每个上述测试子任务,根据来自上述数据仓库系统中的测试热点数据生成与上述测试子任务对应的上述内存数据库。171.根据本公开的实施例,执行模块还用于针对上述m个测试子任务中的每个上述测试子任务,在上述测试热点数据包括与上述测试子任务对应的测试基础数据的情况下,根据与上述测试子任务对应的上述测试用例和上述测试基础数据执行上述测试子任务,得到与上述测试子任务对应的测试结果。172.根据本公开的实施例,发送模块还用于向上述数据仓库系统发送由执行上述m个测试子任务得到的m个测试结果,以便上述数据仓库系统根据上述m个测试结果和预设计算规则更新上述数据仓库系统中的测试热点数据。173.根据本公开的实施例,上述单元测试装置还包括第一查询模块、第二查询模块、比对模块和更新模块。174.第一查询模块,用于查询上述数据仓库系统中与上述测试任务对应的测试结果,得到第一查询结果。175.第二查询模块,用于针对m个上述内存数据库中的每个上述内存数据库,查询上述内存数据库中与上述测试子任务对应的测试结果,得到第二查询结果。176.比对模块,用于将上述第一查询结果与上述第二查询结果进行比对,得到比对结果。177.更新模块,用于在确定上述比对结果表明上述第一查询结果和上述第二查询结果满足预设条件的情况下,利用上述第一查询结果更新上述内存数据库中的测试热点数据。178.根据本公开的实施例,上述第一生成模块包括第一生成单元、第二生成单元、获取单元和存储单元。179.第一生成单元用于生成与上述测试用例的标识信息对应的上述内存数据库。180.第二生成单元用于利用预先设置的配置文件,在上述内存数据库中生成基础数据空表。181.获取单元用于从上述数据仓库系统中获取上述测试热点数据。182.存储单元用于将上述测试热点数据存储至上述内存数据库中的上述基础数据空表中。183.根据本公开的实施例,上述单元测试装置还包括第二生成模块、第三生成模块和第四生成模块。184.第二生成模块,用于根据预设字段生成初始化表格文件。185.第三生成模块,用于生成与上述预没字段对应的示例数据文件;186.第四生成模块,用于根据上述初始化表格文件和上述示例数据文件生成上述配置文件。187.根据本公开的实施例,上述第二生成单元包括生成子单元和存储子单元。188.生成子单元用于根据上述初始化表格文件在上述内存数据库中生成初始化表格。189.存储子单元用于将上述示例数据文件中的示例数据存储至上述初始化表格中,得到上述基础数据空表。190.根据本公开的实施例,上述测试热点数据包括上述数据仓库系统中调用频次满足预设值的测试基础数据。191.根据本公开的实施例,上述单元测试装置还包括获取模块。192.获取模块,用于在上述测试热点数据中不包括与上述测试用例对应的测试基础数据的情况下,从上述数据仓库系统中获取与上述测试用例对应的测试基础数据。193.图7示意性示出了根据本公开另一实施例的单元测试装置的结构框图。194.如图7所示,该实施例的单元测试装置700包括环境配置模块710、数据准备模块720、代码编写和执行模块730和结果输出模块740。195.环境配置模块710用于在测试环境上集成内存数据库并配置相关文件。环境配置模块710例如可以用于实现上述第二生成模块、第三生成模块和第四生成模块的功能。196.数据准备模块720用于准备测试基类初始化数据。数据准备模块720例如可以用于实现上述生成子单元、获取单元、存储单元和存储子单元的功能。197.代码编写和执行模块730用于调用内存数据库进行sql单元测试的编写和执行。代码编写和执行模块730例如可以用于实现上述执行模块的功能。198.结果输出模块740用于收集sql单元测试执行情况,包括执行状态、执行时间与资源消耗情况,以及后续负责收集测试人员对sql单元测试发现问题的评级反馈。199.根据本公开的实施例的模块、子模块、单元、子单元中的任意多个、或其中任意多个的至少部分功能可以在一个模块中实现。根据本公开实施例的模块、子模块、单元、子单元中的任意一个或多个可以被拆分成多个模块来实现。根据本公开实施例的模块、子模块、单元、子单元中的任意一个或多个可以至少被部分地实现为硬件电路,例如现场可编程门阵列(fpga)、可编程逻辑阵列(pla)、片上系统、基板上的系统、封装上的系统、专用集成电路(asic),或可以通过对电路进行集成或封装的任何其他的合理方式的硬件或固件来实现,或以软件、硬件以及固件三种实现方式中任意一种或以其中任意几种的适当组合来实现。或者,根据本公开实施例的模块、子模块、单元、子单元中的一个或多个可以至少被部分地实现为计算机程序模块,当该计算机程序模块被运行时,可以执行相应的功能。200.根据本公开的实施例,接收模块610、第一生成模块620、执行模块630和发送模块640中的任意多个模块可以合并在一个模块中实现,或者其中的任意一个模块可以被拆分成多个模块。或者,这些模块中的一个或多个模块的至少部分功能可以与其他模块的至少部分功能相结合,并在一个模块中实现。根据本公开的实施例,接收模块610、第一生成模块620、执行模块630和发送模块640中的至少一个可以至少被部分地实现为硬件电路,例如现场可编程门阵列(fpga)、可编程逻辑阵列(pla)、片上系统、基板上的系统、封装上的系统、专用集成电路(asic),或可以通过对电路进行集成或封装的任何其他的合理方式等硬件或固件来实现,或以软件、硬件以及固件三种实现方式中任意一种或以其中任意几种的适当组合来实现。或者,接收模块610、第一生成模块620、执行模块630和发送模块640中的至少一个可以至少被部分地实现为计算机程序模块,当该计算机程序模块被运行时,可以执行相应的功能。201.需要说明的是,本公开的实施例中单元测试装置部分与本公开的实施例中单元测试方法部分是相对应的,单元测试装置部分的描述具体参考单元测试方法部分,在此不再赘述。202.图8示意性示出了根据本公开实施例的适于实现单元测试方法的电子设备的方框图。203.如图8所示,根据本公开实施例的电子设备800包括处理器801,其可以根据存储在只读存储器(rom)802中的程序或者从存储部分808加载到随机访问存储器(ram)803中的程序而执行各种适当的动作和处理。处理器801例如可以包括通用微处理器(例如cpu)、指令集处理器和/或相关芯片组和/或专用微处理器(例如,专用集成电路(asic))等等。处理器801还可以包括用于缓存用途的板载存储器。处理器801可以包括用于执行根据本公开实施例的方法流程的不同动作的单一处理单元或者是多个处理单元。204.在ram803中,存储有电子设备800操作所需的各种程序和数据。处理器801、rom802以及ram803通过总线804彼此相连。处理器801通过执行rom802和/或ram803中的程序来执行根据本公开实施例的方法流程的各种操作。需要注意,所述程序也可以存储在除rom802和ram803以外的一个或多个存储器中。处理器801也可以通过执行存储在所述一个或多个存储器中的程序来执行根据本公开实施例的方法流程的各种操作。205.根据本公开的实施例,电子设备800还可以包括输入/输出(i/o)接口805,输入/输出(i/o)接口805也连接至总线804。电子设备800还可以包括连接至i/o接口805的以下部件中的一项或多项:包括键盘、鼠标等的输入部分806;包括诸如阴极射线管(crt)、液晶显示器(lcd)等以及扬声器等的输出部分807;包括硬盘等的存储部分808;以及包括诸如lan卡、调制解调器等的网络接口卡的通信部分809。通信部分809经由诸如因特网的网络执行通信处理。驱动器810也根据需要连接至i/o接口805。可拆卸介质811,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器810上,以便于从其上读出的计算机程序根据需要被安装入存储部分808。206.本公开还提供了一种计算机可读存储介质,该计算机可读存储介质可以是上述实施例中描述的设备/装置/系统中所包含的;也可以是单独存在,而未装配入该设备/装置/系统中。上述计算机可读存储介质承载有一个或者多个程序,当上述一个或者多个程序被执行时,实现根据本公开实施例的方法。207.根据本公开的实施例,计算机可读存储介质可以是非易失性的计算机可读存储介质,例如可以包括但不限于:便携式计算机磁盘、硬盘、随机访问存储器(ram)、只读存储器(rom)、可擦式可编程只读存储器(eprom或闪存)、便携式紧凑磁盘只读存储器(cd-rom)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本公开中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。例如,根据本公开的实施例,计算机可读存储介质可以包括上文描述的rom802和/或ram803和/或rom802和ram803以外的一个或多个存储器。208.本公开的实施例还包括一种计算机程序产品,其包括计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。当计算机程序产品在计算机系统中运行时,该程序代码用于使计算机系统实现本公开实施例所提供的单元测试方法。209.在该计算机程序被处理器801执行时执行本公开实施例的系统/装置中限定的上述功能。根据本公开的实施例,上文描述的系统、装置、模块、单元等可以通过计算机程序模块来实现。210.在一种实施例中,该计算机程序可以依托于光存储器件、磁存储器件等有形存储介质。在另一种实施例中,该计算机程序也可以在网络介质上以信号的形式进行传输、分发,并通过通信部分809被下载和安装,和/或从可拆卸介质811被安装。该计算机程序包含的程序代码可以用任何适当的网络介质传输,包括但不限于:无线、有线等等,或者上述的任意合适的组合。211.在这样的实施例中,该计算机程序可以通过通信部分809从网络上被下载和安装,和/或从可拆卸介质811被安装。在该计算机程序被处理器801执行时,执行本公开实施例的系统中限定的上述功能。根据本公开的实施例,上文描述的系统、设备、装置、模块、单元等可以通过计算机程序模块来实现。212.根据本公开的实施例,可以以一种或多种程序设计语言的任意组合来编写用于执行本公开实施例提供的计算机程序的程序代码,具体地,可以利用高级过程和/或面向对象的编程语言、和/或汇编/机器语言来实施这些计算程序。程序设计语言包括但不限于诸如java,c ,python,“c”语言或类似的程序设计语言。程序代码可以完全地在用户计算设备上执行、部分地在用户设备上执行、部分在远程计算设备上执行、或者完全在远程计算设备或服务器上执行。在涉及远程计算设备的情形中,远程计算设备可以通过任意种类的网络,包括局域网(lan)或广域网(wan),连接到用户计算设备,或者,可以连接到外部计算设备(例如利用因特网服务提供商来通过因特网连接)。213.附图中的流程图和框图,图示了按照本公开各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,上述模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图或流程图中的每个方框、以及框图或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。214.本领域技术人员可以理解,本公开的各个实施例和/或权利要求中记载的特征可以进行多种组合或/或结合,即使这样的组合或结合没有明确记载于本公开中。特别地,在不脱离本公开精神和教导的情况下,本公开的各个实施例和/或权利要求中记载的特征可以进行多种组合和/或结合。所有这些组合和/或结合均落入本公开的范围。215.以上对本公开的实施例进行了描述。但是,这些实施例仅仅是为了说明的目的,而并非为了限制本公开的范围。尽管在以上分别描述了各实施例,但是这并不意味着各个实施例中的措施不能有利地结合使用。本公开的范围由所附权利要求及其等同物限定。不脱离本公开的范围,本领域技术人员可以做出多种替代和修改,这些替代和修改都应落在本公开的范围之内。当前第1页12当前第1页12
再多了解一些

本文用于企业家、创业者技术爱好者查询,结果仅供参考。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

相关文献