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

页面测试方法、装置、设备、存储介质和程序产品与流程

2022-06-16 03:32:26 来源:中国专利 TAG:


1.本公开涉及软件测试技术领域,具体的涉及界面测试技术领域,更具体地涉及一种页面测试方法、装置、设备、存储介质和程序产品。


背景技术:

2.在页面ui(user interface,ui)端对端测试过程中,通常使用基于页面控件对象属性识别原理进行自动化测试,相较于其他原理,例如基于图像识别原理或基于windows句柄识别原理进行测试,基于页面控件对象属性识别的方式具有识别准确度高、运行效率快、自动化脚本保鲜维护简单的优点。
3.然而使用基于浏览器页面控件属性识别的自动化测试方式,虽然能够高效快速的对所测试的业务流程完成功能性验证,实现对检查点的验证等功能,但相较于人工测试来说,还是存在一个很大的局限性,对于系统页面中的各个控件元素在浏览器中所显示的视觉效果无法进行正确性判断,即无法及时发现页面控件显示配对错误的问题,在自动化测试过程中无法实现对该类测试目标的自动化验证,进而降低测试效率。
4.需要说明的是,在上述背景技术部分公开的信息仅用于加强对本公开的背景的理解,因此可以包括不构成对本领域普通技术人员已知的现有技术的信息。


技术实现要素:

5.鉴于上述问题,本公开提供了页面测试方法、装置、设备、存储介质和程序产品。
6.根据本公开的第一个方面,提供了一种页面测试方法,包括:
7.响应于页面的跳转操作,对所述页面进行截图操作,以获取初始页面图像信息;
8.对所述初始页面图像信息进行处理,以确定目标页面图像信息,所述目标页面图像信息仅包括控件对象信息;
9.根据所述控件对象信息确定目标文本向量;
10.将所述目标文本向量与基准文本向量进行比对,以获取比对结果,所述基准文本向量是根据所述页面的测试脚本的历史运行信息确定的;以及
11.根据所述比对结果确定页面测试结果。
12.根据本公开的实施例,所述控件对象信息包括控件名称信息和控件位置信息,所述根据所述控件对象信息确定目标文本向量包括:
13.根据控件位置信息确定控件对应输入框的位置信息;
14.根据所述输入框的位置信息确定控件名称位置信息;以及
15.根据所述控件名称位置信息生成目标文本向量。
16.根据本公开的实施例,所述根据所述控件名称位置信息生成目标文本向量包括:
17.根据所述控件名称位置信息确定控件名称;以及
18.根据所述控件名称位置信息按照预设顺序遍历所述控件名称,以获取目标文本向量。
19.根据本公开的实施例,所述对所述初始页面图像信息进行处理,以确定目标页面图像信息包括:
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.图4a示意性示出了根据本公开实施例的对初始页面图像进行处理的流程图之一;
51.图4b示意性示出了根据本公开实施例的对初始页面图像进行处理的流程图之二;
52.图5示意性示出了根据本公开实施例的目标文本向量生成方法的流程图;
53.图6示意性示出了根据本公开实施例的目标文本向量与基准文本向量比对的流程图;
54.图7a示意性示出了根据本公开实施例的页面测试装置的结构框图;
55.图7b示意性示出了根据本公开实施例的图像处理模块的结构框图;
56.图7c示意性示出了根据本公开实施例的第一确定模块的结构框图;以及
57.图8示意性示出了根据本公开实施例的适于实现页面测试方法的电子设备的方框图。
具体实施方式
58.以下,将参照附图来描述本公开的实施例。但是应该理解,这些描述只是示例性的,而并非要限制本公开的范围。在下面的详细描述中,为便于解释,阐述了许多具体的细节以提供对本公开实施例的全面理解。然而,明显地,一个或多个实施例在没有这些具体细节的情况下也可以被实施。此外,在以下说明中,省略了对公知结构和技术的描述,以避免不必要地混淆本公开的概念。
59.在此使用的术语仅仅是为了描述具体实施例,而并非意在限制本公开。在此使用的术语“包括”、“包含”等表明了所述特征、步骤、操作和/或部件的存在,但是并不排除存在或添加一个或多个其他特征、步骤、操作或部件。
60.在此使用的所有术语(包括技术和科学术语)具有本领域技术人员通常所理解的含义,除非另外定义。应注意,这里使用的术语应解释为具有与本说明书的上下文相一致的
含义,而不应以理想化或过于刻板的方式来解释。
61.在使用类似于“a、b和c等中至少一个”这样的表述的情况下,一般来说应该按照本领域技术人员通常理解该表述的含义来予以解释(例如,“具有a、b和c中至少一个的系统”应包括但不限于单独具有a、单独具有b、单独具有c、具有a和b、具有a和c、具有 b和c、和/或具有a、b、c的系统等)。
62.自动化测试技术目前越来越广泛的应用到了各类软件研发的过程中,分层测试的理念也越来越广泛的应用,如单元测试验证代码覆盖率,接口测试验证功能正确性,验收测试验证功能串接后的交易链路的正确性等,在验收测试阶段,作为最后一道关口,为了整体功能的正确性,会主要使用界面ui端到端的模式进行自动化测试。
63.在界面ui端到端模式进行自动化测试的过程中,有多种实现原理的自动化测试工具,有基于浏览器页面控件属性识别原理的,有基于页面图像ocr原理识别的,也有windows句柄识别原理的。但测试执行的验证是一个非常严谨的工作,因为在图像识别的过程中会存在识别不准确的情况,基于windows句柄原理识别的自动化工具可以适用范围又窄,所以,相对于其他使用图像识别等原理进行自动化测试的方式,基于页面控件对象属性识别的方式具有识别准确度高、运行效率快、自动化脚本保鲜维护简单等优点,被越来越广企业选用,如selenium等自动化测试框架等。
64.但使用基于浏览器页面控件属性识别的自动化测试方式,虽然能够高效快速的对所测试的业务流程完成功能性验证,而且很方便的获取到页面控件的属性值进行断言的比对,实现对检查点的验证等功能,但相较于人工测试来说,还是存在一个很大的局限性,对于系统页面中的各个控件元素在浏览器中所显示的视觉效果无法进行正确性判断,在自动化测试过程中无法实现对该类测试目标的自动化验证。
65.一个示例中,一个页面中有五个输入项,用户名称、用户性格、用户单位地址、用户住址、用户属性,使用浏览器页面控件属性识别原理的自动化测试,页面中每个输入项前面会有输入项名称,后面对应的是输入项控件,使用基于对象识别属性编写自动化脚本的过程中,自动化测试脚本所操作的对象是具体的输入项控件,但当系统的开发人员在后续版本的修改过程中,将输入项显示名称顺序调整错误,如出现将用户名称对应的输入项控件写成用户性格,用户性格对应的输入项控件写成用户名称时,原有的自动化脚本依然能够执行成功,无法发现该类问题。
66.基于上述技术问题,本公开的实施例提供了一种页面测试方法,包括:响应于页面的跳转操作,对所述页面进行截图操作,以获取初始页面图像信息;对所述初始页面图像信息进行处理,以确定目标页面图像信息,所述目标页面图像信息仅包括控件对象信息;根据所述控件对象信息确定目标文本向量;将所述目标文本向量与基准文本向量进行比对,以获取比对结果,所述基准文本向量是根据所述页面的测试脚本的历史运行信息确定的;以及根据所述比对结果确定页面测试结果。
67.图1示意性示出了根据本公开实施例的页面测试方法、装置、设备、存储介质和程序产品的应用场景图。
68.如图1所示,根据该实施例的应用场景100可以包括页面测试场景。网络104用以在终端设备101、102、103和服务器105之间提供通信链路的介质。网络104可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
69.用户可以使用终端设备101、102、103通过网络104与服务器 105交互,以接收或发送消息等。终端设备101、102、103上可以安装有各种通讯客户端应用,例如购物类应用、网页浏览器应用、搜索类应用、即时通信工具、邮箱客户端、社交平台软件等(仅为示例)。
70.终端设备101、102、103可以是具有显示屏并且支持网页浏览的各种电子设备,包括但不限于智能手机、平板电脑、膝上型便携计算机和台式计算机等等。终端设备101、102、103预先安装有自动化测试脚本,自动化测试脚本也可以部署在服务器105上。
71.服务器105可以是提供各种服务的服务器,例如对用户利用终端设备101、102、103部署的脚本运行所产生的数据进行处理的测试服务器(仅为示例)。测试服务器可以根据当前接收到的测试数据进行分析等处理,例如可以是根据页面图像进行处理比对确定测试结果。
72.需要说明的是,本公开实施例所提供的页面测试方法一般可以由服务器105执行。相应地,本公开实施例所提供的页面测试装置一般可以设置于服务器105中。本公开实施例所提供的页面测试方法也可以由不同于服务器105且能够与终端设备101、102、103和/或服务器105通信的服务器或服务器集群执行。相应地,本公开实施例所提供的页面测试装置也可以设置于不同于服务器105且能够与终端设备101、102、103和/或服务器105通信的服务器或服务器集群中。
73.应该理解,图1中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
74.需要说明的是,本公开实施例提供的页面测试方法和装置可用于金融领域在软件测试的应用,也可用于除金融领域之外的任意领域,本公开实施例提供的页面测试方法和装置的应用领域不做限定。
75.图2示意性示出了根据本公开实施例的页面测试方法的流程图。如图2所示,自动化测试脚本在测试过程中会对页面进行截图采集,对获取到的截图进行降噪处理后,通过ocr技术(optical characterrecogniton,光学字符识别)对处理后的图像信息进行文字识别,获取图像中的控件遍历路径,并对该控件遍历路径进行比对,具体的,首先判断该测试脚本是否存在有效的历史遍历路径,若不存在,则将上述获取到的控件遍历路径保存至数据库,等待下一次测试使用。若存在,则将新获取的控件遍历路径与数据库保存的控件遍历路径进行比对,将比对结果展示给测试人员。
76.以下将基于图1描述的场景,通过图3~图6对公开实施例的页面测试方法进行详细描述。
77.图3示意性示出了根据本公开实施例的一种页面测试方法的流程图。
78.如图3所示,该实施例的页面测试方法包括操作s210~操作s250。本公开实施例的页面测试方法可以由服务器或计算设备执行。在本实施例中,页面测试的过程由对应的自动化脚本实现,在测试脚本运行的过程中,执行本公开提供的页面测试方法。由于本公开涉及页面 ui端的测试,基于不同的业务流程及业务场景预先编写有不同的测试脚本,例如,在用户进行转账汇款的业务场景,业务流程一可以是用户登陆、账户查询、转账,业务流程二可以是用户登陆、转账。开发人员结合具体的业务流程,从用户的视角,根据业务流程的使用频率开发自动化测试脚本进行界面ui测试。
79.在操作s210,响应于页面的跳转操作,对所述页面进行截图操作,以获取初始页面
图像信息。
80.一个示例中,在自动化测试脚本执行测试的过程中,对系统所显示页面发生页面跳转时进行截图操作,具体的,以web端系统操作为例,对自动化脚本中每一个包含点击提交“.click”关键字的语句执行操作前,自动对当前系统界面进行截图,然后判断当前浏览器的 browser.page对象属性值是否发生改变,如果page对象属性值未发生改变,则说明当前页面没有发生页面跳转行为,废弃截图信息;如果page对象属性值发生改变,则判断为当前发生页面跳转行为,保留最新的截图,并将所有保留的系统截图有序化命名,例如第三个系统界面则命名为3-xxx。经过截图操作保留的系统截图即为初始页面图像信息,此时初始页面图像信息为用户视角下的页面,包括控件名称、各种输入项、输入项中的值、按钮的图片信息和其他标题菜单信息。
81.在操作s220,对所述初始页面图像信息进行处理,以确定目标页面图像信息。
82.根据本公开实施例,所述目标页面图像信息仅包括控件对象信息。
83.一个示例中,为了提高页面识别的处理效率以及对控件名称识别的准确率,需对初始页面图像信息进行降噪处理,去除初始页面图像信息中的无效信息,得到目标页面图像信息,此时目标页面图像信息仅包含控件对象信息。就本公开实施例而言,由于是对页面中的控件名称显示是否匹配进行测试,因此初始页面图像信息中除了控件对象信息,其他的图像信息均为无效信息。通过算法确定初始页面图像中有多少个输入项,依据不同的输入项特征,识别控件显示特征,保留当前页面的控件对象信息,删除其他无用的界面信息。具体降噪处理过程可参见图4所述的操作s221~s222,在此不再赘述。
84.在操作s230,根据所述控件对象信息确定目标文本向量。
85.一个示例中,将操作s220得到的目标页面图像信息按照预设顺序进行控件名称遍历,作为优选的,例如可以按照用户的正常阅读习惯遍历,即从左向右,自上而下的顺序获取每个控件名称的位置,通过ocr识别的方式,获取每个控件名称,生成一个1xm的文本矩阵向量,其中m为当前页面控件的个数,该文本矩阵向量即为目标文本向量。目标文本向量的生成过程参见图5所示的操作s231~操作 s233,在此不再赘述。
86.在操作s240,将所述目标文本向量与基准文本向量进行比对,以获取比对结果。
87.根据本公开实施例,所述基准文本向量是根据所述页面的测试脚本的历史运行信息确定的。
88.根据本公开的实施例,当确定所述页面的测试脚本为初次运行时,将所述目标文本向量保存为基准文本向量。
89.一个示例中,在生成目标文本向量后,需要将目标文本向量与基准文本向量进行比对,基准文本向量与页面的测试脚本是一一对应的,即每个测试脚本都唯一对应一个基准文本向量作为对比基线,基准文本向量是根据测试脚本的历史运行信息确定的,作为优选的,例如可以是在测试脚本初次成功执行之后,将获取到的目标文本向量保存为基准文本向量;可拓展的,测试人员可以根据历史数据库对基准文本向量进行更新调整,将两文本向量进行比对获取比对结果。
90.在操作s250,根据所述比对结果确定页面测试结果。
91.一个示例中,当自动化测试脚本全部语句执行成功,且文本向量比对成功时,证明该自动化测试脚本所测试的系统功能功能正常,且没有出现控件名称与对应控件内容误修
改的情况。由于在实际测试过程中,存在部分流程较长的情况,为了提高测试效率,也可以是当自动化测试脚本部分语句执行成功时,对执行成功部分的语句对应的文本向量进行核对,验证是否正常,并且将执行失败的错误信息记录到自动化脚本执行结果信息中,供后续系统对结果进行展示。
92.通过本公开提供的页面测试方法,通过将运行页面的测试脚本对待测试页面进行截图操作,获取初始页面图像信息,为了提高图像处理效率和图像识别的准确率,对初始页面图像信息进行处理确定目标页面图像信息;基于目标页面图像获取页面控件名称的遍历路径信息,保存为目标文本向量,将目标文本向量与基准文本向量进行比对,及时发现控件显示错位的问题,相较于现有技术中的页面测试方法,本公开提供的测试方法准确率高,能够提高页面测试效率。
93.接下来将结合图4a~图4b对初始页面图像处理过程进行详细介绍。
94.图4a示意性示出了根据本公开实施例的对初始页面图像进行处理的流程图之一,图4b示意性示出了根据本公开实施例的对初始页面图像进行处理的流程图之二。如图4a所示,操作s220包括操作 s221~操作s222。
95.在操作s221,根据所述初始页面图像信息确定页面的控件对象信息。在操作s222,根据所述控件对象信息对所述初始页面图像信息进行删除处理,以确定目标页面图像信息。
96.一个示例中,为了确定控件位置,排除页面中的无效信息,首先根据初始页面图像信息识别出页面的控件对象信息,控件对象信息包括控件名称和控件位置信息,其中控件位置信息即为控件中对应输入项的位置信息,在获取初始页面的控件对象信息后,去除处控件对象信息之外的页面信息,得到目标页面图像信息,具体过程可参见图 4b所述的操作s310~操作s350。
97.如图4b,图像降噪处理操作包括操作s310~操作s350。
98.在操作s310,根据输入项特征识别控件显示特征。
99.在操作s320,根据所述控件显示特征确定控件名称信息和控件位置信息。
100.在操作s330,确定控件位置信息。
101.在操作s340,删除除所述控件名称信息和所述控件位置信息之外的界面信息。
102.在操作s350,生成目标页面图像信息。
103.根据本公开实施例,输入项包括文本输入框、单选框、选择框、日期输入框和文本域。
104.一个示例中,通过智能化算法判断初始页面图像信息中包含有多少个输入项,具体的依据不同的输入项特征识别对应的控件显示特征,再根据控件显示特征进一步确定控件名称信息和控件位置信息。
105.可选的,例如对于标题格式和内容为左右格式的,以文本输入框和单选框为例,选取特征为输入框特征的图像区域,即左右两边分别为的图像像域,然后对展示域前面的文本内容进行取值,作为该控件的名称,去除掉页面上原本的标题,按钮等其他信息,处理后的结果只保留页面控件,去除掉按钮,页面标题等无效信息。
106.例如对于有特定特征的选择框、日期输入框和文本域,选择框开头处有输入框,结尾处有下拉箭头;日期输入框开头处为输入框,结尾处有特殊的日历图片;文本域开头处为
较宽的输入框,结尾处具有相反方向的两个箭头,根据这些特征,确定控件的位置信息,再根据控件位置前后的像素变化确定控件名称信息。去除页面中其他无效信息,得到目标页面图像信息,此时的目标页面图像信息仅包括控件对象信息。
107.在对初始页面进行降噪得到目标页面图像后,对目标页面图像进行ocr文本提取,获取目标文本向量,下面将结合图5详细介绍目标文本向量的生成过程。
108.图5示意性示出了根据本公开实施例的目标文本向量生成方法的流程图,如图5所示,操作s230包括操作s231~操作s233。
109.在操作s231,根据所述控件位置信息确定控件对应输入框的位置信息。
110.在操作s232,根据所述输入框的位置信息确定控件名称位置信息。
111.在操作s233,根据所述控件名称位置信息生成目标文本向量。
112.根据本公开实施例,根据所述控件名称位置信息确定控件名称;根据所述控件名称位置信息按照预设顺序遍历所述控件名称,以获取目标文本向量。
113.一个示例中,按照从左向右、从上到下的顺序根据控件位置获取每个输入项的位置,并根据该位置查找到其对应的输入框和控件名称位置。通过ocr识别的方式,将控件对象名称提取出来,同时将输入框中的值屏蔽掉,通过从左向右、从上到下的顺序,形成当前页面的控件名称遍历路径。如用户信息页面形成的控件遍历路径为“3-1,项目名称;3-2,项目类型;3-3,项目负责人;3-4,项目测试负责部室;3-5,归属产品线;3-6,产品经理;3-7,测试开始时间;3-8,测试结束时间;3-9,立项时间;3-10,需求提出部门;3-11,备注”的遍历路径,将该遍历路径以文本向量的形式保存下来,即为目标文本向量。
114.图6示意性示出了根据本公开实施例的目标文本向量与基准文本向量比对的流程图。如图6所示,操作s240包括操作s241~操作 s242。
115.在操作s241,根据所述页面的脚本获取基准文本向量。
116.在操作s242,将基准文本向量中的控件名称与目标文本向量中的控件名称按顺序进行逐一比对,以生成比对结果。
117.一个示例中,假设某版本开发人员在进行版本修改时,不小心将立项时间和测试开始时间的标签改错位了,即“立项时间”和“测试开始时间”两个控件名称显示顺序不匹配,则按照上述获取该页面的目标文本向量的方法,计算本次测试路径为“3-1,项目名称;3-2,项目类型;3-3,项目负责人;3-4,项目测试负责部室;3-5,归属产品线;3-6,产品经理;3-7,立项时间;3-8,测试结束时间;3-9,测试开始时间;3-10,需求提出部门;3-11,备注”。
118.根据测试脚本标识在数据库中获取基准文本向量,将该文本向量与基准文本向量中的控件名称进行逐一比对,发现两文本相比不一致,则比对不通过。说明前台系统界面显示有问题,脚本比对执行结果为:“控件遍历路径核对不通过,核对通过部分为:“3-1,项目名称;3-2,项目类型;3-3,项目负责人;3-4,项目测试负责部室;3-5,归属产品线;3-6,产品经理;核对不通过部分为“3-7,立项时间;3-9,测试开始时间;”。
119.基于上述页面测试方法,本公开还提供了一种页面测试装置。以下将结合图7a~图7c对该装置进行详细描述。
120.图7a示意性示出了根据本公开实施例的页面测试装置的结构框图。图7b示意性示出了根据本公开实施例的图像处理模块的结构框图。图7c示意性示出了根据本公开实施例的第一确定模块的结构框图。
121.如图7a所示,该实施例的页面测试装置800包括截图模块810、图像处理模块820、第一确定模块830、比对模块840、第二确定模块850和第三确定模块860。
122.截图模块810用于响应于页面的跳转操作,对所述页面进行截图操作,以获取初始页面图像信息。在一实施例中,截图模块810可以用于执行前文描述的操作s210,在此不再赘述。
123.图像处理模块820用于对所述初始页面图像信息进行处理,以确定目标页面图像信息,所述目标页面图像信息仅包括控件对象信息。在一实施例中,图像处理模块820可以用于执行前文描述的操作s220,在此不再赘述。
124.第一确定模块830用于根据所述控件对象信息确定目标文本向量。在一实施例中,第一确定模块830可以用于执行前文描述的操作 s230,在此不再赘述。
125.比对模块840用于将所述目标文本向量与基准文本向量进行比对,以获取比对结果,所述基准文本向量是根据所述页面的测试脚本的历史运行信息确定的。在一实施例中,比对模块840可以用于执行前文描述的操作s240,在此不再赘述。
126.第二确定模块850用于根据所述比对结果确定页面测试结果。在一实施例中,第二确定模块850可以用于执行前文描述的操作s250,在此不再赘述。
127.第三确定模块860用于当确定所述页面的测试脚本为初次运行时,将所述目标文本向量保存为基准文本向量。在一实施例中,第三确定模块860可以用于执行前文描述的操作s240,在此不再赘述。
128.如图7b所示,图像处理模块820包括第一确定子模块821和第二确定子模块822。
129.第一确定子模块821用于根据所述初始页面图像信息确定页面的控件对象信息。在一实施例中,第一确定子模块821可以用于执行前文描述的操作s221,在此不再赘述。
130.第二确定子模块822用于根据所述控件对象信息对所述初始页面图像信息进行删除处理,以确定目标页面图像信息。在一实施例中,第二确定子模块822可以用于执行前文描述的操作s222,在此不再赘述。
131.根据本公开实施例,第一确定子模块821包括识别单元8211和第一确定单元8212。
132.识别单元8211用于根据输入项特征识别控件显示特征。在一实施例中,识别单元8211可以用于执行前文描述的操作s310,在此不再赘述。
133.第一确定单元8212用于根据所述控件显示特征确定控件名称信息和控件位置信息。在一实施例中,第一确定单元8212可以用于执行前文描述的操作s320,在此不再赘述。
134.根据本公开实施例,第二确定子模块822包括第二确定单元8221、删除单元8222和生成单元8223。
135.第二确定单元8221用于确定控件位置信息。在一实施例中,第二确定单元8221可以用于执行前文描述的操作s330,在此不再赘述。
136.删除单元8222用于删除除所述控件名称信息和所述控件位置信息之外的界面信息。在一实施例中,删除单元8222可以用于执行前文描述的操作s340,在此不再赘述。
137.生成单元8223用于生成目标页面图像信息。在一实施例中,生成单元8223可以用于执行前文描述的操作s350,在此不再赘述。
138.如图7c所示,第一确定模块830包括第三确定子模块831、第四确定子模块832和生成子模块833。
139.第三确定子模块831用于根据所述控件位置信息确定控件对应输入框的位置信息。在一实施例中,第三确定子模块831可以用于执行前文描述的操作s231,在此不再赘述。
140.第四确定子模块832用于根据所述输入框的位置信息确定控件名称位置信息。在一实施例中,第四确定子模块832可以用于执行前文描述的操作s232,在此不再赘述。
141.生成子模块833用于根据所述控件名称位置信息生成目标文本向量。在一实施例中,生成子模块833可以用于执行前文描述的操作 s233,在此不再赘述。
142.根据本公开的实施例,比对模块840包括获取子模块841和比对子模块842。
143.获取子模块841用于根据所述页面的脚本获取基准文本向量。在一实施例中,获取子模块841可以用于执行前文描述的操作s241,在此不再赘述。
144.比对子模块842用于将基准文本向量中的控件名称与目标文本向量中的控件名称按顺序进行逐一比对,以生成比对结果。在一实施例中,比对子模块842可以用于执行前文描述的操作s242,在此不再赘述。
145.根据本公开的实施例,截图模块810、图像处理模块820、第一确定模块830、比对模块840、第二确定模块850和第三确定模块860 中的任意多个模块可以合并在一个模块中实现,或者其中的任意一个模块可以被拆分成多个模块。或者,这些模块中的一个或多个模块的至少部分功能可以与其他模块的至少部分功能相结合,并在一个模块中实现。根据本公开的实施例,截图模块810、图像处理模块820、第一确定模块830、比对模块840、第二确定模块850和第三确定模块860中的至少一个可以至少被部分地实现为硬件电路,例如现场可编程门阵列(fpga)、可编程逻辑阵列(pla)、片上系统、基板上的系统、封装上的系统、专用集成电路(asic),或可以通过对电路进行集成或封装的任何其他的合理方式等硬件或固件来实现,或以软件、硬件以及固件三种实现方式中任意一种或以其中任意几种的适当组合来实现。或者,截图模块810、图像处理模块820、第一确定模块830、比对模块840、第二确定模块850和第三确定模块860中的至少一个可以至少被部分地实现为计算机程序模块,当该计算机程序模块被运行时,可以执行相应的功能。
146.图8示意性示出了根据本公开实施例的适于实现页面测试方法的电子设备的方框图。
147.如图8所示,根据本公开实施例的电子设备900包括处理器901,其可以根据存储在只读存储器(rom)902中的程序或者从存储部分 908加载到随机访问存储器(ram)903中的程序而执行各种适当的动作和处理。处理器901例如可以包括通用微处理器(例如cpu)、指令集处理器和/或相关芯片组和/或专用微处理器(例如,专用集成电路(asic))等等。处理器901还可以包括用于缓存用途的板载存储器。处理器901可以包括用于执行根据本公开实施例的方法流程的不同动作的单一处理单元或者是多个处理单元。
148.在ram 903中,存储有电子设备900操作所需的各种程序和数据。处理器901、rom 902以及ram 903通过总线904彼此相连。处理器901通过执行rom 902和/或ram 903中的程序来执行根据本公开实施例的方法流程的各种操作。需要注意,所述程序也可以存储在除rom 902和ram 903以外的一个或多个存储器中。处理器 901也可以通过执行存储在所述一个或多个存储器中的程序来执行根据本公开实施例的方法流程的各种操作。
149.根据本公开的实施例,电子设备900还可以包括输入/输出(i/o) 接口905,输入/输出(i/o)接口905也连接至总线904。电子设备 900还可以包括连接至i/o接口905的以下
部件中的一项或多项:包括键盘、鼠标等的输入部分906;包括诸如阴极射线管(crt)、液晶显示器(lcd)等以及扬声器等的输出部分907;包括硬盘等的存储部分908;以及包括诸如lan卡、调制解调器等的网络接口卡的通信部分909。通信部分909经由诸如因特网的网络执行通信处理。驱动器910也根据需要连接至i/o接口905。可拆卸介质911,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器910 上,以便于从其上读出的计算机程序根据需要被安装入存储部分908。
150.本公开还提供了一种计算机可读存储介质,该计算机可读存储介质可以是上述实施例中描述的设备/装置/系统中所包含的;也可以是单独存在,而未装配入该设备/装置/系统中。上述计算机可读存储介质承载有一个或者多个程序,当上述一个或者多个程序被执行时,实现根据本公开实施例的页面测试方法。
151.根据本公开的实施例,计算机可读存储介质可以是非易失性的计算机可读存储介质,例如可以包括但不限于:便携式计算机磁盘、硬盘、随机访问存储器(ram)、只读存储器(rom)、可擦式可编程只读存储器(eprom或闪存)、便携式紧凑磁盘只读存储器 (cd-rom)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本公开中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。例如,根据本公开的实施例,计算机可读存储介质可以包括上文描述的rom 902和/或ram 903和/或rom 902和ram 903 以外的一个或多个存储器。
152.本公开的实施例还包括一种计算机程序产品,其包括计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。当计算机程序产品在计算机系统中运行时,该程序代码用于使计算机系统实现本公开实施例所提供的页面测试方法。
153.在该计算机程序被处理器901执行时执行本公开实施例的系统/ 装置中限定的上述功能。根据本公开的实施例,上文描述的系统、装置、模块、单元等可以通过计算机程序模块来实现。
154.在一种实施例中,该计算机程序可以依托于光存储器件、磁存储器件等有形存储介质。在另一种实施例中,该计算机程序也可以在网络介质上以信号的形式进行传输、分发,并通过通信部分909被下载和安装,和/或从可拆卸介质911被安装。该计算机程序包含的程序代码可以用任何适当的网络介质传输,包括但不限于:无线、有线等等,或者上述的任意合适的组合。
155.在这样的实施例中,该计算机程序可以通过通信部分909从网络上被下载和安装,和/或从可拆卸介质911被安装。在该计算机程序被处理器901执行时,执行本公开实施例的系统中限定的上述功能。根据本公开的实施例,上文描述的系统、设备、装置、模块、单元等可以通过计算机程序模块来实现。
156.根据本公开的实施例,可以以一种或多种程序设计语言的任意组合来编写用于执行本公开实施例提供的计算机程序的程序代码,具体地,可以利用高级过程和/或面向对象的编程语言、和/或汇编/机器语言来实施这些计算程序。程序设计语言包括但不限于诸如java,c , python,“c”语言或类似的程序设计语言。程序代码可以完全地在用户计算设备上执行、部分地在用户设备上执行、部分在远程计算设备上执行、或者完全在远程计算设备或服务器上执行。在涉及远程计算设备的情形中,远程计算设备可以通过任意种类的网络,包括局域网(lan)或广域网(wan),连接到用户计算设备,或者,可以连接到外部计算设备
(例如利用因特网服务提供商来通过因特网连接)。
157.附图中的流程图和框图,图示了按照本公开各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,上述模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图或流程图中的每个方框、以及框图或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
158.本领域技术人员可以理解,本公开的各个实施例和/或权利要求中记载的特征可以进行多种组合或/或结合,即使这样的组合或结合没有明确记载于本公开中。特别地,在不脱离本公开精神和教导的情况下,本公开的各个实施例和/或权利要求中记载的特征可以进行多种组合和/或结合。所有这些组合和/或结合均落入本公开的范围。
159.以上对本公开的实施例进行了描述。但是,这些实施例仅仅是为了说明的目的,而并非为了限制本公开的范围。尽管在以上分别描述了各实施例,但是这并不意味着各个实施例中的措施不能有利地结合使用。本公开的范围由所附权利要求及其等同物限定。不脱离本公开的范围,本领域技术人员可以做出多种替代和修改,这些替代和修改都应落在本公开的范围之内。
再多了解一些

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

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

相关文献