CN110737594B - 自动生成测试用例的数据库标准符合性测试方法及装置 - Google Patents
自动生成测试用例的数据库标准符合性测试方法及装置 Download PDFInfo
- Publication number
- CN110737594B CN110737594B CN201910887833.7A CN201910887833A CN110737594B CN 110737594 B CN110737594 B CN 110737594B CN 201910887833 A CN201910887833 A CN 201910887833A CN 110737594 B CN110737594 B CN 110737594B
- Authority
- CN
- China
- Prior art keywords
- database
- test
- standard
- tested
- data
- 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.)
- Active
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/3684—Test management for test design, e.g. generating new test cases
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
技术领域
本申请涉及数据库领域,尤其涉及自动生成测试用例的数据库标准符合性测试方法及装置。
背景技术
对于数据库公司推出的数据库产品,通常通过测试工具对其进行数据库标准符合性测试,测试数据库产品是否符合标准。
在对一款数据库产品进行数据库标准符合性测试时,若数据库版本不同,则意味着存在不同的数据库测试标准,而若数据库的类型不同,数据库测试标准之间则存在着更大的差异。
在具体的测试过程中,还须工作人员在工作现场根据当前的数据库测试标准,手动编写不同的数据库测试标准相对应的测试用例,这就导致了需要等待较长的编写时长,降低了数据库标准符合性测试的测试效率。
发明内容
本申请提供了自动生成测试用例的数据库标准符合性测试方法及装置,不仅可自动生成测试用例,且优化了测试用例的生成方式,从而可大大缩短测试用例的编写时长,明显提高数据库标准符合性测试的测试效率。
第一方面,本申请提供了自动生成测试用例的数据库标准符合性测试方法,方法包括:
测试设备获取待测试数据库的数据库测试标准;
测试设备根据数据库测试标准,生成语法模板数据,语法模板数据包括符合数据库测试标准的测试用例伪代码集以及实例数据形参定义数据;
测试设备根据实例数据形参定义数据以及待测试数据库的基本信息,生成实例数据枚举数值;
测试设备将实例数据枚举数值替换至语法模板数据中的形参,得到待测试数据库的测试用例;
测试设备基于测试用例,对待测试数据库进行数据库标准符合性测试,得到待测试数据库的数据库标准符合性测试结果。
结合本申请第一方面,在本申请一方面第一种可能的实现方式中,测试设备获取待测试数据库的数据库测试标准包括:
测试设备触发待测试数据库的数据库标准符合性测试任务;
测试设备读取数据库标准符合性测试任务的任务信息;
测试设备根据任务信息中用户所选定的数据库测试标准的标准标识,从数据库测试标准集合中提取数据库测试标准。
结合本申请第一方面,在本申请一方面第二种可能的实现方式中,测试设备基于测试用例,对待测试数据库进行数据库标准符合性测试之前,方法还包括:
测试设备根据预设的调整策略或者用户的调整操作,定位测试用例中的异常用例;
测试设备将异常用例进行调整,以生成新用例。
结合本申请第一方面,在本申请一方面第三种可能的实现方式中,测试设备基于测试用例,对待测试数据库进行数据库标准符合性测试包括:
测试设备按照测试用例中多个用例的用例顺序执行多个用例,并在执行过程中记录测试用例执行状态、执行错误信息以及执行结果记录。
结合本申请第一方面,在本申请一方面第四种可能的实现方式中,待测试数据库的数据库编程语言包括SQL。
结合本申请第一方面,在本申请一方面第五种可能的实现方式中,基本信息包括待测试数据库的数据库类型、数据库连接信息、数据表、数据类型以及约束要求。
结合本申请第一方面,在本申请一方面第六种可能的实现方式中,测试用例包括查询语句、修改语句、删除语句以及建表语句。
第二方面,本申请提供了自动生成测试用例的数据库标准符合性测试装置,装置包括:
获取单元,用于获取待测试数据库的数据库测试标准;
生成单元,用于根据数据库测试标准,生成语法模板数据,语法模板数据包括符合数据库测试标准的测试用例伪代码集以及实例数据形参定义数据;
生成单元,还用于根据实例数据形参定义数据以及待测试数据库的基本信息,生成实例数据枚举数值;
替换单元,用于将实例数据枚举数值替换至语法模板数据中的形参,得到待测试数据库的测试用例;
测试单元,用于基于测试用例,对待测试数据库进行数据库标准符合性测试,得到待测试数据库的数据库标准符合性测试结果。
结合本申请第二方面,在本申请二方面第一种可能的实现方式中,获取单元,具体用于:
触发待测试数据库的数据库标准符合性测试任务;
读取数据库标准符合性测试任务的任务信息;
根据任务信息中用户所选定的数据库测试标准的标准标识,从数据库测试标准集合中提取数据库测试标准。
结合本申请第二方面,在本申请二方面第二种可能的实现方式中,装置还包括调整单元,用于:
根据预设的调整策略或者用户的调整操作,定位测试用例中的异常用例;
将异常用例进行调整,以生成新用例。
结合本申请第二方面,在本申请二方面第三种可能的实现方式中,测试单元,具体用于:
按照测试用例中多个用例的用例顺序执行多个用例,并在执行过程中记录测试用例执行状态、执行错误信息以及执行结果记录。
结合本申请第二方面,在本申请二方面第四种可能的实现方式中,待测试数据库的数据库编程语言包括SQL。
结合本申请第二方面,在本申请二方面第五种可能的实现方式中,基本信息包括待测试数据库的数据库类型、数据库连接信息、数据表、数据类型以及约束要求。
结合本申请第二方面,在本申请二方面第六种可能的实现方式中,测试用例包括查询语句、修改语句、删除语句以及建表语句。
第三方面,本申请提供了自动生成测试用例的数据库标准符合性测试设备,包括处理器,处理器用于执行存储器中存储的计算机程序时实现如上述第一方面的任一步骤。
第四方面,本申请提供了可读存储介质,其上存储有计算机程序,计算机程序被处理器执行时实现如上述第一方面的任一步骤。
从以上技术方案可以看出,本申请具有以下优点:
一方面,在本申请的数据库标准符合性测试中,通过自动生成待测试数据库对应的测试用例,从而可避免现有技术中由工作人员手动编写测试用例所带来的较长的编写时长,实现数据库标准符合性测试的自动化测试。
另一方面,在测试用例的生成处理中,基于待测试数据库的测试标准生成语法模板数据,并将测试用例从语法结构以及实例数据两个层面相分离开,即,根据该语法模板数据以及待测试数据库的基本信息,生成实例数据枚举数值,以用变量方式定义实例数据,再将该实例数据枚举数值替换至用模型模板定义的语法模板数据中的形参,如此优化测试用例的生成方式,使用时能够在代码不做任何修改的情况下,对于每个形参都可生成大量的测试用例,从而可大大缩短测试用例的编写时长,提高测试用例的生成效率,降低生成测试用例的工作量,进而提高本申请数据库标准符合性测试的自动化性能。
附图说明
图1为本申请提供的自动生成测试用例的数据库标准符合性测试方法的一种流程示意图;
图2为本申请提供的自动生成测试用例的数据库标准符合性测试方法的又一种流程示意图;
图3为本申请提供的自动生成测试用例的数据库标准符合性测试方法的一种流程示意图;
图4为本申请自动生成测试用例的数据库标准符合性测试装置的一种结构示意图;
图5为本申请自动生成测试用例的数据库标准符合性测试设备的一种结构示意图。
具体实施方式
本申请提供了自动生成测试用例的数据库标准符合性测试方法及装置,不仅可自动生成测试用例,且优化了测试用例的生成方式,从而可大大缩短测试用例的编写时长,明显提高数据库标准符合性测试的测试效率。
下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。
本申请的说明书和权利要求书及上述附图中的术语“第一”、“第二”等是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的实施例能够以除了在这里图示或描述的内容以外的顺序实施。此外,术语“包括”和“具有”以及他们的任何变形,意图在于覆盖不排他的包含,例如,包含了一系列步骤或模块的过程、方法、系统、产品或设备不必限于清楚地列出的那些步骤或模块,而是可包括没有清楚地列出的或对于这些过程、方法、产品或设备固有的其它步骤或模块。在本申请中出现的对步骤进行的命名或者编号,并不意味着必须按照命名或者编号所指示的时间/逻辑先后顺序执行方法流程中的步骤,已经命名或者编号的流程步骤可以根据要实现的技术目的变更执行次序,只要能达到相同或者相类似的技术效果即可。
本申请中所出现的模块的划分,是一种逻辑上的划分,实际应用中实现时可以有另外的划分方式,例如多个模块可以结合成或集成在另一个系统中,或一些特征可以忽略,或不执行,另外,所显示的或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,模块之间的间接耦合或通信连接可以是电性或其他类似的形式,本申请中均不作限定。并且,作为分离部件说明的模块或子模块可以是也可以不是物理上的分离,可以是也可以不是物理模块,或者可以分布到多个电路模块中,可以根据实际的需要选择其中的部分或全部模块来实现本申请方案的目的。
首先,在介绍本申请之前,首先介绍本申请涉及的测试设备。
在本申请中,测试设备为服务器设备或者主机设备等具有数据处理能力的硬件设备,用于根据数据库测试任务的触发,对待测试数据库进行数据库标准符合性测试,在测试过程中,通过应用本申请提供的自动生成测试用例的数据库标准符合性测试方法,自动生成测试用例,并优化测试用例的生成方式,提高测试效率。
下面,则基于上述背景的介绍,开始介绍本申请的具体内容。
参阅图1,图1示出了本申请自动生成测试用例的数据库标准符合性测试方法的一种流程示意图,具体的,本申请自动生成测试用例的数据库标准符合性测试方法,具体可包括如下步骤:
步骤S101,测试设备获取待测试数据库的数据库测试标准;
可以理解,在触发待测试数据库的数据库标准符合性测试任务后,测试设备即可确定本次测试任务的待测试数据库,并获取该数据库对应的数据库测试标准。
在一种实施例中,参阅图2示出的本申请自动生成测试用例的数据库标准符合性测试方法的又一种流程示意图,步骤S101在实际应用中,具体可包括如下步骤:
步骤S201,测试设备触发待测试数据库的数据库标准符合性测试任务;
在具有数据库的测试需求时,用户可通过用户设备(User Equipment,UE)向测试设备发起测试请求,触发待测试数据库的数据库标准符合性测试任务;
或者,用户也可在测试设备本地手动触发待测试数据库的数据库标准符合性测试任务。
其中,UE,具体可以为智能手表、智能手环、智能手机、平板电脑、笔记本电脑、台式电脑、电脑一体机、个人数字助理(Personal Digital Assistant,PDA)等终端设备,具有人机交互能力。
步骤S202,测试设备读取数据库标准符合性测试任务的任务信息;
可以理解,测试任务的任务信息中可通过用户所选定的数据库标识以及标准标识分别标识待测试数据库以及数据库测试标准,数据库标识具体可以包括数据库的所在地址、数据库版本号等信息。
步骤S203,测试设备根据任务信息中用户所选定的数据库测试标准的标准标识,从数据库测试标准集合中提取数据库测试标准。
在得到数据库测试标准的标准标识后,测试设备即可从本次或者其他设备中的数据库测试标准集合中,提取出对应的数据库测试标准。
步骤S102,测试设备根据数据库测试标准,生成语法模板数据;
其中,语法模板数据包括符合数据库测试标准的测试用例伪代码集以及实例数据形参定义数据。
在本申请中,测试用例的生成处理,与现有技术不同的是,分为了语法结构以及实例数据两个层面。
首先,测试设备在待测试数据库当前的数据库测试标准的基础上,按照数据库测试标准的测试方式以及测试内容,生成对应的语法模板数据,该语法模板数据覆盖了符合数据库测试标准的测试用例伪代码集以及实例据形参定义数据。
步骤S103,测试设备根据实例数据形参定义数据以及待测试数据库的基本信息,生成实例数据枚举数值;
接着,测试设备根据上述语法模板数据中的实例数据形参定义,以及本次测试任务其任务信息中待测试数据库的基本信息,生成实例数据枚举数值,即生成大量的实例数据的实际变量值。
在一种实施例中,待测试数据库的基本信息具体可包括待测试数据库的数据库类型、数据库连接信息、数据表、数据类型以及约束要求。
步骤S104,测试设备将实例数据枚举数值替换至语法模板数据中的形参,得到待测试数据库的测试用例;
最后,测试设备再将生成的实例数据枚举数值替换至语法模板数据中的形参,以此实现语法结构以及实例数据两个层面的融合,得到本次测试任务中待测试数据库对应的测试用例。
在一种实施例中,该测试用例包括查询语句、修改语句、删除语句以及建表语句等形式的语句,具体可参考下述实例:
查询语句:SELECT${1}FROM${2}WHERE${3}ORDER BY${4}
修改语句:UPDATE${1}SET${2}WHERE${3}
删除语句:DELETE FROM${1}WHERE${3}
建表语句:CREATE TABLE${1}{${2},${3}}
在一种实施例中,待测试数据库的数据库编程语言具体包括SQL。对于基于SQL的数据库,例如Oracle、MySQL、SQLServer、达梦、金仓、南大通用等数据库,其数据库测试标准中要求验证数据库必须能够定义不同的数据类型,而在应用本申请提供的自动生成测试用例的数据库测试方法后,只需要定义一个语法模板,在模板中定义一个枚举型参数变量代表数据类型,程序实现时依次用枚举数据实参每个值替换形参,就可以生成多个测试用例,实现自动生成多个测试用例的目标。
步骤S105,测试设备基于测试用例,对待测试数据库进行数据库标准符合性测试,得到待测试数据库的数据库标准符合性测试结果。
在生成得到待测试数据库的测试用例后,测试设备即可基于执行该测试用例,对待测试数据库进行数据库标准符合性测试,监测得到待测试数据库的响应结果,并基于监测得到的响应结果,进行数据的汇总、分析、格式转换等处理,形成待测试数据库的数据库标准符合性测试结果。
该测试结果中,可包括上述测试的测试详细信息以及统计信息,具体还可包括计算得到的数据库标准符合性覆盖率,以表征待测试数据库在数据库测试标准的具体标准下的测试结果。该测试结果,具体可以以TXT、报告或者图表等数据形式存在,并加以输出。
测试用例的执行,可以以实际应用中的一种用户信息表为例:
表1-用户信息表定义
表2-用户信息表数据
从上述表1以及表2的内同可看出,待测试数据库会根据用户信息表(ID、NAME、SEX、AGE)中每个字段的数据类型以及约束,随机生成N行符合要求的记录。
在一种实施例中,步骤S105中,具体可包括如下步骤:
测试设备按照测试用例中多个用例的用例顺序执行多个用例,并在执行过程中记录测试用例执行状态、执行错误信息以及执行结果记录。
可以理解,测试设备在步骤S104中生成的测试用例中,包括了多个用例,在进行数据库标准符合性测试时,测试设备可根据这些用例的默认排列顺序,依次执行,并在执行过程中记录待测试数据库的响应结果。
其中,在记录的过程中,测试设备还可测试用例执行的返回状态进行有效性判断,以过滤用例异常执行的响应结果。
在一种实施例中,步骤S105之前,还可包括测试用例的校正处理,具体的,参照图3示出的本申请自动生成测试用例的数据库测试方法的又一种流程示意图,具体可通过下述步骤实现:
步骤S301,测试设备根据预设的调整策略或者用户的调整操作,定位测试用例中的异常用例;
可以理解,在异常用例的校正处理中,一方面可通过预设的调整策略,由测试设备自动进行异常用例的定位,另一方面,也可结合用户的调整操作,由用户手动定位异常用例。
步骤S302,测试设备将异常用例进行调整,以生成新用例。
在定位出测试用例中的异常用例后,测试设备即可对其进行调整,并生成新用例,实现测试用例的优化,提高测试用例以及测试任务的精确性。
从上述的说明中看出,本申请提供的自动生成测试用例的数据库标准符合性测试方法,一方面,通过自动生成待测试数据库对应的测试用例,从而可避免现有技术中由工作人员手动编写测试用例所带来的较长的编写时长,实现数据库标准符合性测试的自动化测试。
另一方面,在测试用例的生成处理中,基于待测试数据库的测试标准生成语法模板数据,并将测试用例从语法结构以及实例数据两个层面相分离开,即,根据该语法模板数据以及待测试数据库的基本信息,生成实例数据枚举数值,以用变量方式定义实例数据,再将该实例数据枚举数值替换至用模型模板定义的语法模板数据中的形参,如此优化测试用例的生成方式,使用时能够在代码不做任何修改的情况下,对于每个形参都可生成大量的测试用例,从而可大大缩短测试用例的编写时长,提高测试用例的生成效率,降低生成测试用例的工作量,进而提高本申请数据库标准符合性测试的自动化性能。
以上是对本申请自动生成测试用例的数据库标准符合性测试方法的介绍,下面开始介绍本申请自动生成测试用例的数据库标准符合性测试装置。
参阅图4,图4示出了本申请自动生成测试用例的数据库标准符合性测试装置的一种结构示意图,具体的,自动生成测试用例的数据库标准符合性测试装置可包括如下结构:
获取单元401,用于获取待测试数据库的数据库测试标准;
生成单元402,用于根据数据库测试标准,生成语法模板数据,语法模板数据包括符合数据库测试标准的测试用例伪代码集以及实例数据形参定义数据;
生成单元402,还用于根据实例数据形参定义数据以及待测试数据库的基本信息,生成实例数据枚举数值;
替换单元403,用于将实例数据枚举数值替换至语法模板数据中的形参,得到待测试数据库的测试用例;
测试单元404,用于基于测试用例,对待测试数据库进行数据库标准符合性测试,得到待测试数据库的数据库标准符合性测试结果。
在一种实施例中,获取单元401,具体用于:
触发待测试数据库的数据库标准符合性测试任务;
读取数据库标准符合性测试任务的任务信息;
根据任务信息中用户所选定的数据库测试标准的标准标识,从数据库测试标准集合中提取数据库测试标准。
在一种实施例中,装置还包括调整单元405,用于:
根据预设的调整策略或者用户的调整操作,定位测试用例中的异常用例;
将异常用例进行调整,以生成新用例。
在一种实施例中,测试单元404,具体用于:
按照测试用例中多个用例的用例顺序执行多个用例,并在执行过程中记录测试用例执行状态、执行错误信息以及执行结果记录。
在一种实施例中,待测试数据库的数据库编程语言包括SQL。
在一种实施例中,基本信息包括待测试数据库的数据库类型、数据库连接信息、数据表、数据类型以及约束要求。
在一种实施例中,测试用例包括查询语句、修改语句、删除语句以及建表语句。
继续参阅图5,图5示出了本申请提供的自动生成测试用例的数据库标准符合性测试设备的一种结构示意图,具体的,本申请提供的自动生成测试用例的数据库标准符合性测试设备包括处理器501,处理器501用于执行存储器502中存储的计算机程序时实现如图1至图3对应任意实施例中自动生成测试用例的数据库标准符合性测试方法的各步骤;或者,处理器501用于执行存储器502中存储的计算机程序时实现如图4对应实施例中各单元的功能。
示例性的,计算机程序可以被分割成一个或多个模块/单元,一个或者多个模块/单元被存储在存储器502中,并由处理器501执行,以完成本申请。一个或多个模块/单元可以是能够完成特定功能的一系列计算机程序指令段,该指令段用于描述计算机程序在计算机装置中的执行过程。
自动生成测试用例的数据库标准符合性测试设备可包括,但不仅限于处理器501、存储器502。本领域技术人员可以理解,示意仅仅是自动生成测试用例的数据库标准符合性测试设备的示例,并不构成对自动生成测试用例的数据库标准符合性测试设备的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件,例如自动生成测试用例的数据库标准符合性测试设备还可以包括输入输出设备、网络接入设备、总线等,处理器501、存储器502、输入输出设备以及网络接入设备等通过总线相连。
处理器501可以是中央处理单元(Central Processing Unit,CPU),还可以是其他通用处理器、数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等,处理器是自动生成测试用例的数据库标准符合性测试设备的控制中心,利用各种接口和线路连接整个自动生成测试用例的数据库标准符合性测试设备的各个部分。
存储器502可用于存储计算机程序和/或模块,处理器501通过运行或执行存储在存储器502内的计算机程序和/或模块,以及调用存储在存储器502内的数据,实现计算机装置的各种功能。存储器502可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序(比如声音播放功能、图像播放功能等)等;存储数据区可存储根据自动生成测试用例的数据库标准符合性测试设备的使用所创建的数据(比如音频数据、视频数据等)等。此外,存储器可以包括高速随机存取存储器,还可以包括非易失性存储器,例如硬盘、内存、插接式硬盘,智能存储卡(Smart Media Card,SMC),安全数字(Secure Digital,SD)卡,闪存卡(Flash Card)、至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。
本申请还提供了可读存储介质,其上存储有计算机程序,计算机程序被处理器执行时实现如图1至图3对应任意实施例中的自动生成测试用例的数据库标准符合性测试方法。
可以理解,集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本申请各方法实施例的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(Read-only Memory,ROM)、随机存取存储器(Random Access Memory,RAM)、磁碟或者光盘等各种可以存储程序代码的介质。
所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的自动生成测试用例的数据库标准符合性测试装置、设备及其相应单元的具体工作过程,可以参考图1至图3对应实施例中自动生成测试用例的数据库标准符合性测试方法的说明,具体在此不再赘述。
综上,本申请提供的自动生成测试用例的数据库标准符合性测试方法、装置、设备以及计算机存储介质,一方面,通过自动生成待测试数据库对应的测试用例,从而可避免现有技术中由工作人员手动编写测试用例所带来的较长的编写时长,实现数据库标准符合性测试的自动化测试。
另一方面,在测试用例的生成处理中,基于待测试数据库的测试标准生成语法模板数据,并将测试用例从语法结构以及实例数据两个层面相分离开,即,根据该语法模板数据以及待测试数据库的基本信息,生成实例数据枚举数值,以用变量方式定义实例数据,再将该实例数据枚举数值替换至用模型模板定义的语法模板数据中的形参,如此优化测试用例的生成方式,使用时能够在代码不做任何修改的情况下,对于每个形参都可生成大量的测试用例,从而可大大缩短测试用例的编写时长,提高测试用例的生成效率,降低生成测试用例的工作量,进而提高本申请数据库标准符合性测试的自动化性能。
在本申请所提供的几个实施例中,应该理解到,所揭露的自动生成测试用例的数据库标准符合性测试装置、设备及其相应单元,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本申请各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
以上,以上实施例仅用以说明本申请的技术方案,而非对其限制;尽管参照前述实施例对本申请进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本申请各实施例技术方案的精神和范围。
Claims (7)
1.一种自动生成测试用例的数据库标准符合性测试方法,其特征在于,所述方法包括:
测试设备获取待测试数据库的数据库测试标准;
所述测试设备根据所述数据库测试标准,生成语法模板数据,所述语法模板数据包括符合所述数据库测试标准的测试用例伪代码集以及实例数据形参定义数据;
所述测试设备根据所述实例数据形参定义数据以及所述待测试数据库的基本信息,生成实例数据枚举数值;
所述测试设备将所述实例数据枚举数值替换至所述语法模板数据中的形参,得到所述待测试数据库的测试用例;
所述测试设备基于所述测试用例,对所述待测试数据库进行数据库标准符合性测试,得到所述待测试数据库的数据库标准符合性测试结果;
所述测试设备获取待测试数据库的数据库测试标准包括:
所述测试设备触发所述待测试数据库的数据库标准符合性测试任务;
所述测试设备读取所述数据库标准符合性测试任务的任务信息;
所述测试设备根据所述任务信息中用户所选定的数据库测试标准的标准标识,从数据库测试标准集合中提取所述数据库测试标准;
所述测试设备基于所述测试用例,对所述待测试数据库进行数据库标准符合性测试之前,所述方法还包括:
所述测试设备根据预设的调整策略或者用户的调整操作,定位所述测试用例中的异常用例;
所述测试设备将所述异常用例进行调整,以生成新用例。
2.根据权利要求1所述的方法,其特征在于,所述测试设备基于所述测试用例,对所述待测试数据库进行数据库标准符合性测试包括:
所述测试设备按照所述测试用例中多个用例的用例顺序执行所述多个用例,并在执行过程中记录测试用例执行状态、执行错误信息以及执行结果记录。
3.根据权利要求1所述的方法,其特征在于,所述待测试数据库的数据库编程语言包括SQL。
4.根据权利要求1所述的方法,其特征在于,所述基本信息包括所述待测试数据库的数据库类型、数据库连接信息、数据表、数据类型以及约束要求。
5.根据权利要求1所述的方法,其特征在于,所述测试用例包括查询语句、修改语句、删除语句以及建表语句。
6.一种自动生成测试用例的数据库标准符合性测试设备,包括处理器,处理器用于执行存储器中存储的计算机程序时实现如权利要求1至5中任一项所述的方法。
7.一种可读存储介质,其上存储有计算机程序,计算机程序被处理器执行时实现如权利要求1至5中任一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910887833.7A CN110737594B (zh) | 2019-09-19 | 2019-09-19 | 自动生成测试用例的数据库标准符合性测试方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910887833.7A CN110737594B (zh) | 2019-09-19 | 2019-09-19 | 自动生成测试用例的数据库标准符合性测试方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN110737594A CN110737594A (zh) | 2020-01-31 |
CN110737594B true CN110737594B (zh) | 2021-02-05 |
Family
ID=69268128
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910887833.7A Active CN110737594B (zh) | 2019-09-19 | 2019-09-19 | 自动生成测试用例的数据库标准符合性测试方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110737594B (zh) |
Families Citing this family (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111324544A (zh) * | 2020-03-12 | 2020-06-23 | 惠州市德赛电池有限公司 | 基于LabView的测试方法和测试系统 |
CN113448829B (zh) * | 2020-03-27 | 2024-06-04 | 来也科技(北京)有限公司 | 对话机器人测试方法、装置、设备及存储介质 |
CN113297060A (zh) * | 2020-05-11 | 2021-08-24 | 阿里巴巴集团控股有限公司 | 一种数据测试方法及其装置 |
CN113742200B (zh) * | 2020-05-28 | 2024-07-26 | 阿里巴巴集团控股有限公司 | 数据库版本升级的测试方法、设备及计算机可读介质 |
CN114070764B (zh) * | 2020-08-07 | 2024-06-18 | 中国电信股份有限公司 | 网络功能虚拟化nfv测试方法、装置和系统 |
US11907108B2 (en) | 2022-01-05 | 2024-02-20 | International Business Machines Corporation | Generating workloads for system verification |
CN116185883A (zh) * | 2023-04-28 | 2023-05-30 | 阿里云计算有限公司 | 测试用例生成方法、测试系统、装置、设备及介质 |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2005309917A (ja) * | 2004-04-23 | 2005-11-04 | Mitsubishi Electric Corp | レビュー支援装置 |
CN101425064A (zh) * | 2007-10-29 | 2009-05-06 | 英业达股份有限公司 | 测试日志处理方法及系统 |
CN103425683A (zh) * | 2012-05-18 | 2013-12-04 | 上海宝信软件股份有限公司 | 数据库性能测试系统 |
CN105512036A (zh) * | 2015-12-12 | 2016-04-20 | 天津南大通用数据技术股份有限公司 | 根据预置规则自动生成测试用例的测试模板及测试方法 |
CN107832226A (zh) * | 2017-11-23 | 2018-03-23 | 中国平安人寿保险股份有限公司 | 基于性能测试的报告生成方法、装置、设备和计算机介质 |
CN109408358A (zh) * | 2018-08-03 | 2019-03-01 | 中国人民解放军63928部队 | 一种操作系统间互操作性测试方法和系统 |
CN110069406A (zh) * | 2019-03-29 | 2019-07-30 | 梁俊杰 | 自动触发的tpc-ds测试方法以及系统 |
Family Cites Families (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20070143151A1 (en) * | 2005-12-16 | 2007-06-21 | U.S. Preventive Medicine, Inc. | Preventive health care device, system and method |
TW200919248A (en) * | 2007-10-23 | 2009-05-01 | Inventec Corp | Method and system for processing test diaries |
CN102955738B (zh) * | 2012-11-13 | 2014-10-29 | 中原工学院 | 一种针对仿真系统的主动被动混合测试方法 |
CN104407971B (zh) * | 2014-11-18 | 2017-04-12 | 中国电子科技集团公司第十研究所 | 自动化测试嵌入式软件的方法 |
CN109271326B (zh) * | 2018-11-28 | 2021-03-12 | 优刻得科技股份有限公司 | 云数据库的测试方法及其装置、设备和存储介质 |
-
2019
- 2019-09-19 CN CN201910887833.7A patent/CN110737594B/zh active Active
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2005309917A (ja) * | 2004-04-23 | 2005-11-04 | Mitsubishi Electric Corp | レビュー支援装置 |
CN101425064A (zh) * | 2007-10-29 | 2009-05-06 | 英业达股份有限公司 | 测试日志处理方法及系统 |
CN103425683A (zh) * | 2012-05-18 | 2013-12-04 | 上海宝信软件股份有限公司 | 数据库性能测试系统 |
CN105512036A (zh) * | 2015-12-12 | 2016-04-20 | 天津南大通用数据技术股份有限公司 | 根据预置规则自动生成测试用例的测试模板及测试方法 |
CN107832226A (zh) * | 2017-11-23 | 2018-03-23 | 中国平安人寿保险股份有限公司 | 基于性能测试的报告生成方法、装置、设备和计算机介质 |
CN109408358A (zh) * | 2018-08-03 | 2019-03-01 | 中国人民解放军63928部队 | 一种操作系统间互操作性测试方法和系统 |
CN110069406A (zh) * | 2019-03-29 | 2019-07-30 | 梁俊杰 | 自动触发的tpc-ds测试方法以及系统 |
Also Published As
Publication number | Publication date |
---|---|
CN110737594A (zh) | 2020-01-31 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110737594B (zh) | 自动生成测试用例的数据库标准符合性测试方法及装置 | |
CN110795455B (zh) | 依赖关系解析方法、电子装置、计算机设备及可读存储介质 | |
CN108459962B (zh) | 代码规范性检测方法、装置、终端设备及存储介质 | |
CN105589874B (zh) | Etl任务依赖关系的检测方法、装置及etl工具 | |
CN109241174B (zh) | 数据同步方法、装置、可读存储介质和电子设备 | |
US20160283357A1 (en) | Call stack relationship acquiring method and apparatus | |
CN109445837B (zh) | 一种应用程序的发布方法及设备 | |
CN108491326B (zh) | 测试行为重组方法、装置及存储介质 | |
CN105205053A (zh) | 一种数据库增量日志解析方法及系统 | |
CN111124480B (zh) | 应用程序包的生成方法、装置、电子设备及存储介质 | |
CN110990274B (zh) | 一种生成测试案例的数据处理方法、装置及系统 | |
CN110647562B (zh) | 一种数据查询方法和装置、电子设备、存储介质 | |
CN112328631A (zh) | 一种生产故障分析方法、装置、电子设备及存储介质 | |
US10339035B2 (en) | Test DB data generation apparatus | |
CN106294128B (zh) | 一种导出报表数据的自动化测试方法及装置 | |
CN111177119A (zh) | 基于数据库的全量数据比对方法、装置、设备及存储介质 | |
CN105512276B (zh) | 一种构建垃圾文件的方法、装置及电子设备 | |
CN107729541A (zh) | 一种数据处理方法、装置及计算机可读存储介质 | |
WO2016165461A1 (zh) | 一种电信网网管系统软件自动化测试方法和装置 | |
CN107193736B (zh) | 测试方法、装置、电子设备以及存储介质 | |
CN110058995B (zh) | 一种可避免数据库类型的干扰的数据库测试方法以及系统 | |
CN112631920A (zh) | 一种测试方法、装置、电子设备及可读存储介质 | |
CN116661758A (zh) | 一种优化日志框架配置的方法、装置、电子设备及介质 | |
CN109474822B (zh) | 一种安卓电视多国语言自动化测试的方法及装置 | |
CN115757174A (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 | ||
GR01 | Patent grant | ||
GR01 | Patent grant |