CN116643996A - 基于Monkey的参数可定制的自动测试系统及方法 - Google Patents
基于Monkey的参数可定制的自动测试系统及方法 Download PDFInfo
- Publication number
- CN116643996A CN116643996A CN202310730806.5A CN202310730806A CN116643996A CN 116643996 A CN116643996 A CN 116643996A CN 202310730806 A CN202310730806 A CN 202310730806A CN 116643996 A CN116643996 A CN 116643996A
- Authority
- CN
- China
- Prior art keywords
- test
- monkey
- parameters
- module
- automatic
- 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.)
- Pending
Links
- 238000012360 testing method Methods 0.000 title claims abstract description 430
- 241000282693 Cercopithecidae Species 0.000 title claims abstract description 74
- 238000000034 method Methods 0.000 title claims abstract description 32
- 238000013515 script Methods 0.000 claims abstract description 46
- 238000004458 analytical method Methods 0.000 claims abstract description 27
- 230000008569 process Effects 0.000 claims abstract description 21
- 230000002159 abnormal effect Effects 0.000 claims description 16
- 230000000007 visual effect Effects 0.000 claims description 13
- 230000010354 integration Effects 0.000 claims description 8
- 238000012545 processing Methods 0.000 claims description 4
- 238000007726 management method Methods 0.000 description 14
- 238000004891 communication Methods 0.000 description 6
- 230000005856 abnormality Effects 0.000 description 5
- 238000010276 construction Methods 0.000 description 5
- 230000002354 daily effect Effects 0.000 description 4
- 230000000694 effects Effects 0.000 description 4
- 238000010586 diagram Methods 0.000 description 3
- 230000009471 action Effects 0.000 description 2
- 230000005540 biological transmission Effects 0.000 description 2
- 238000011161 development Methods 0.000 description 2
- 230000006870 function Effects 0.000 description 2
- 238000013522 software testing Methods 0.000 description 2
- 230000001960 triggered effect Effects 0.000 description 2
- 208000025174 PANDAS Diseases 0.000 description 1
- 208000021155 Paediatric autoimmune neuropsychiatric disorders associated with streptococcal infection Diseases 0.000 description 1
- 240000000220 Panda oleosa Species 0.000 description 1
- 235000016496 Panda oleosa Nutrition 0.000 description 1
- 238000012356 Product development Methods 0.000 description 1
- 206010000210 abortion Diseases 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 230000003203 everyday effect Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000005457 optimization Methods 0.000 description 1
- 238000009877 rendering Methods 0.000 description 1
- 230000004044 response Effects 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 238000010998 test method Methods 0.000 description 1
- 238000012795 verification Methods 0.000 description 1
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
-
- 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/3688—Test management for test execution, e.g. scheduling of test suites
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02P—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN THE PRODUCTION OR PROCESSING OF GOODS
- Y02P90/00—Enabling technologies with a potential contribution to greenhouse gas [GHG] emissions mitigation
- Y02P90/30—Computing systems specially adapted for manufacturing
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
本发明公开了一种基于Monkey的参数可定制的自动测试系统及方法,该系统包括:设备管理模块,用于连接至少一个目标设备,获取目标设备所有待测试的测试包,并自定义选择需要测试的测试包;参数配置模块,用于对Monkey测试参数进行设置,以定制测试事件;测试计划模块,用于自定义设置测试事件的测试时间、运行次数与延时时间,以制定测试计划;测试执行模块,用于根据测试参数自动生成测试脚本并对测试包进行测试,获取测试结果;测试分析模块,用于根据测试过程数据自动分析并输出测试报告。本发明能够连接多个目标设备同时测试,可自定义设置测试参数及自动化分析测试结果,从而提高测试效率,增加测试灵活性,保证测试产品质量。
Description
技术领域
本发明涉及软件测试技术领域,特别是涉及一种基于Monkey的参数可定制的自动测试系统及方法。
背景技术
Monkey测试是一种自动化的软件测试方法,它通过随机生成的输入数据和事件来测试应用程序或系统的稳定性和可靠性。
Monkey是一个命令行工具,通常在目标设备上进行Monkey测试需要在cmd命令行输入完整的运行指令,或是把多个Monkey指令汇集在一起,编写成脚本来进行,比较耗时繁琐。而且,现有的基于Monkey的自动化测试方法,多数是在Monkey测试过程中记录过程数据,测试结束后通过记录的数据分析测试结果。因此,现有的Monkey测试存在测试效率低、测试灵活性低等问题,无法有效保证测试产品质量。
需要说明的是,在上述背景技术部分公开的信息仅用于对本申请的背景的理解,因此可以包括不构成对本领域普通技术人员已知的现有技术的信息。
发明内容
本发明的目的在于解决Monkey测试的测试效率和测试灵活性较低的技术问题,提供一种基于Monkey的参数可定制的自动测试系统及方法。
为实现上述目的,本发明采用以下技术方案:
一种基于Monkey的参数可定制的自动测试系统,包括:
设备管理模块,用于连接至少一个目标设备,获取目标设备所有待测试的测试包,并自定义选择需要测试的测试包;
参数配置模块,用于对Monkey测试参数进行设置,以定制测试事件;
测试计划模块,用于自定义设置测试事件的测试时间、运行次数与延时时间,以制定测试计划;
测试执行模块,用于根据设置好的Monkey测试参数自动生成测试脚本并对测试包进行测试,获取测试结果;
测试分析模块,用于根据测试过程数据自动分析并输出测试报告。
在一些实施例中,所述设备管理模块、参数配置模块和测试计划模块分别通过可视化界面选择需要测试的测试包、设置测试参数、制定测试计划,以实现可视化操作。
在一些实施例中,所述可视化界面为Web页面,所述Web页面基于electron搭建Windows桌面应用,使用antDesign组件库搭建页面。
在一些实施例中,所述设备管理模块通过数据接口将目标设备和所述测试系统所在服务器连接;所述设备管理模块还用于识别目标设备类型,根据目标设备类型自动关联同类型的常用历史测试脚本。
在一些实施例中,所述测试参数包括:用户操作间的时延、触摸事件百分比、反馈信息级别和伪随机数生成器的seed值。
在一些实施例中,所述反馈信息级别分为level0、level1和level2。
在一些实施例中,所述测试执行模块还用于对每次生成的测试脚本进行记录,所记录的历史测试脚本能够直接重复运行,当重复的测试场景再次测试时能够通过所述历史测试脚本实现一键化执行测试。
在一些实施例中,所述测试执行模块还用于集成DevOps工具链,在持续集成流程中调度所述测试系统执行每日自动化测试;所述每日自动化测试具体为:通过Jenkins触发定时测试任务,获取测试系统内计划的测试脚本,在测试环境执行测试任务,获取测试结果并进行反馈。
在一些实施例中,所述测试分析模块根据测试过程数据自动分析并输出测试报告具体为:获取Monkey测试过程中的日志数据,重定向日志文件并保存;通过分析保存的日志文件,进行自动化分析处理,统计ANR和Crash异常点,截取异常日志;自动统计测试过程中的异常点总数,记录异常日志并进行反馈。
本发明还提供一种基于Monkey的参数可定制的自动测试方法,基于如上任一项所述的基于Monkey的参数可定制的自动测试系统,包括如下步骤:
A1、连接所述测试系统和目标设备,获取目标设备所有待测试的测试包,并自定义选择需要测试的测试包;
A2、对Monkey测试参数进行设置,定制测试事件;
A3、自定义设置测试事件的测试时间、运行次数与延时时间,制定测试计划;
A4、根据设置好的Monkey测试参数自动生成测试脚本并对测试包进行测试,并获取测试结果;
A5、对测试结果进行自动化分析并输出测试报告。
本发明具有如下有益效果:
本发明提供的基于Monkey的参数可定制的自动测试系统,通过设备管理模块连接多个目标设备同时进行Monkey测试,通过参数配置模块自定义设置Monkey测试参数,通过测试计划模块自定义设置测试时间、运行次数与延时时间,通过测试执行模块自动生成测试脚本进行测试,通过测试分析模块自动分析测试过程数据并生成测试报告,从而提高测试效率,增加测试灵活性,保证测试产品质量。
此外,在本发明的一些实施例中,还具有如下有益效果:
通过可视化界面选择需要测试的测试包、设置测试参数、制定测试计划,从而实现可视化操作,进一步增加测试灵活性。
通过测试执行模块记录历史测试场景和测试脚本,相同的测试场景二次测试时可以一键执行,从而实现测试脚本可记录以及测试场景可复用,进一步提高测试效率。
本发明实施例中的其他有益效果将在下文中进一步述及。
附图说明
图1是本发明实施例中基于Monkey参数可定制的自动测试系统的测试流程示意图。
图2是本发明实施例中基于Monkey参数可定制的自动测试系统的结构示意图。
图3是本发明实施例中基于Monkey参数可定制的自动测试系统的用户界面示意图。
具体实施方式
以下对本发明的实施方式做详细说明。应该强调的是,下述说明仅仅是示例性的,而不是为了限制本发明的范围及其应用。
参阅图1至图3,本发明实施例提供一种测试参数可定制、测试脚本可记录、测试结果可自动化分析的基于Monkey的参数可定制的自动测试系统。该测试系统包括:设备管理模块,用于连接至少一个目标设备,获取目标设备所有待测试的测试包,并自定义选择需要测试的测试包;参数配置模块,用于对Monkey测试参数进行设置,以定制测试事件;测试计划模块,用于自定义设置测试事件的测试时间、运行次数与延时时间,以制定测试计划;测试执行模块,用于根据设置好的Monkey测试参数自动生成测试脚本并对测试包进行测试,获取测试结果,测试执行过程不需要手动输入测试脚本;测试分析模块,用于根据测试过程数据自动分析并输出测试报告。
该测试系统所有的测试操作均提供可视化界面。优选的,可视化界面基于electron(前端开发框架)开源技术,通过JSBridge(一种JS和Native之间的通信方式)实现跨平台通信,通过内嵌webview(可视化组件)实现搭建Window桌面应用。基于Node(结点)中的child_process模块集成Web页面与shell命令脚本,并通过electron的JSBridge实现跨平台通信,进行数据传输通信。基于umijs的框架的antDesign组件库快速搭建业务页面。
设备管理模块通过数据接口将目标设备和测试系统所在服务器连接,测试系统会获取所有连接的测试设备。具体地,通过adb device指令获取当前测试系统连接的设备信息,截取设备号供测试执行的时候指定设备,以实现多设备同时执行Monkey测试。
设备管理模块还用于识别目标设备类型,测试系统会根据接入目标设备的类型,自动关联同类型的常用历史测试脚本,从而节约测试成本。
优选地,设备管理模块获取设备号后,通过adb-s设备shell pm list package获取当前设备所有的APK包(测试包)。
当测试系统与目标设备连接后,通过Web页面在参数配置模块中设置Monkey测试相关的所有参数。所有的测试参数都可以根据测试场景定制选择。测试参数全都可以通过web页面来按需选择,测试系统根据选择后的测试参数结合目标设备和测试包生成测试脚本。测试参数内容包括:
--throttle,用于指定用户操作(即事件)间的时延;
--pct-touch,用于调整触摸事件的百分比;
--pct-motion,用于调整动作事件的百分比;
--pct-trackball,用于调整轨迹事件的百分比;
--pct-nav,用于调整“基本”导航事件的百分比;
--pct-majornav,用于调整“主要”导航事件的百分比;
--pct-syskeys,用于调整“系统”按键事件的百分比;
--pct-appswitch,用于调整启动Activity的百分比;
--pct-anyevent,用于调整其它类型事件的百分比;
--ignore-crashes,用于指定当应用程序崩溃时(Force&Close错误),Monkey是否中止运行。若是使用此参数,即便应用程序崩溃,Monkey依然会发送事件,直到事件计数完成;
--ignore-timeouts,用于指定当应用程序发生ANR(Application NoResponding)错误时,Monkey是否中止运行。若是使用此参数,即便应用程序发生ANR错误,Monkey依然会发送事件,直到事件计数完成;
--ignore-security-exception,用于指定当应用程序发生许可错误时(如证书许可,网络许可等),Monkey是否中止运行。若是使用此参数,即便应用程序发生许可错误,Monkey依然会发送事件,直到事件计数完成;
--kill-process-after-error,用于指定当应用程序发生错误时,是否中止其运行。若是指定此参数,当应用程序发生错误时,应用程序中止运行并保持在当前状态;
--v,用于指定反馈信息级别;
--s,用于伪随机数生成器的seed值;
--monitor-native-crashes,用于指定是否监视并报告应用程序发生崩溃的本地代码;
--ignore-native-crashes,用于忽略native层代码的崩溃;
上述反馈信息级别分为level0、level1和level2。这三个不同等级可以在参数配置模块中按需选择,在一些实施例中,Level0表示:提供很少的信息,除了启动通知,测试完成和最终结果;Level1表示:提供更详细的信息,如个别事件被发生至测试Activity;Level2表示:提供更详细的设置等信息,如Activity选中和未选中的测试信息。
参数配置模块设置完成后,在测试计划模块中设置本次的执行时间、执行次数以及执行延迟时间。参数非必填,可通过测试场景自定义。测试计划模块设置完成后,测试系统会根据设置的时间点执行多次测试。
测试执行模块可以记录历史测试脚本数据(每次生成的测试脚本)并保存至测试分析模块中的数据库(数据库用于测试系统的数据记录),所记录的历史测试脚本可以直接点击再重复运行,当典型重复的测试场景二次执行(再次测试)时可以通过所记录的历史测试脚本实现一键化执行测试。在一些实施例中,测试执行模块在开始运行测试脚本前会进行判断,测试条件满足要求时会在后台模拟CMD命令执行测试脚本。
测试执行模块还用于集成DevOps工具链,在持续集成(CI)流程中调度测试系统执行每日自动化测试。每日自动化测试具体为:通过Jenkins触发定时测试任务,获取测试系统内计划的测试脚本,在每日构建的测试环境中自动执行测试任务,获取测试结果并进行反馈。优选地,将测试结果以邮件的方式反馈发送给用户。当目标设备或者测试包升级后,测试系统可以通过Jenkins自动触发测试任务,以保障本次升级对历史的测试功能无影响。
在测试脚本执行完成后,测试分析模块获取Monkey测试过程中的日志数据,重定向日志文件并保存。测试分析模块通过分析保存的日志文件,进行自动化分析处理,统计ANR和Crash异常点,截取异常日志,异常日志的截取可以避免冗余的测试数据,更加直观地判断各测试包的测试结果,对测试记录进行过滤、汇总与分析,大大提高了测试的效率与质量。测试结果自动化分析处理后,测试分析模块自动统计测试过程中的异常点总数,记录异常日志并进行反馈。优选地,测试分析模块在测试结束后自动生成测试异常统计表与测试异常日志表,通过Excel的方式保存并反馈给用户。
本发明实施例还公开了一种基于Monkey的参数可定制的自动测试方法,基于上述的基于Monkey的参数可定制的自动测试系统,包括如下步骤:
A1、连接测试系统和目标设备,获取目标设备所有待测试的测试包,并自定义选择需要测试的测试包。
A2、对Monkey测试参数进行设置,定制测试事件。
A3、自定义设置测试事件的测试时间、运行次数与延时时间,制定测试计划。
A4、根据设置好的Monkey测试参数自动生成测试脚本并对测试包进行测试,并获取测试结果。
A5、对测试结果进行自动化分析并输出测试报告。
本发明实施例提供的基于Monkey的参数可定制的自动测试系统,通过设备管理模块实现对多目标设备的连接与管理,获取目标设备的测试包信息,并可根据所获取的信息对测试参数进行灵活匹配;通过参数配置模块对测试相关的Monkey参数进行设置;通过测试计划模块,根据测试需求,模拟测试场景,定制测试的次数与时间,实现测试执行自动化;通过测试执行模块,基于参数配置模块,根据参数自动生成测试脚本进行测试;通过测试分析模块,当测试执行完成后根据测试过程数据自动化分析测试结果并生成测试报告。本发明实施例通过可视化页面替代传统的CMD窗口发送Adb指令进行Monkey测试,测试执行模块会记录历史的测试执行场景,相同的测试场景二次测试时可以一键执行,测试分析模块自动分析测试过程数据并生成测试报告。实现了测试参数可配置、测试脚本可记录以及测试场景可复用,极大地提高了测试效率,增加了测试灵活性,保证了测试产品质量。
实施例一
如图2所示,本实施例提供的基于Monkey可定制的自动测试与分析系统包括:设备管理模块、参数配置模块、测试计划模块、测试执行模块以及测试分析模块。该系统所有的测试操作均提供可视化界面。前端页面通过内嵌webview实现搭建Window桌面应用。业务页面基于umijs的框架的antDesign组件库进行开发,并通过electron的JSBridge实现跨平台通信,进行数据传输通信。
设备管理模块主要是基于node框架实现,通过child_process执行shell命令脚本,获取连接的目前设备信息。
测试执行模块也是通过child_process将拼接的测试脚本下发给测试设备,执行monkey测试。
测试分析模块基于python通过使用sed工具分析monkey日志文件,并且通过pandas模块对分析结果进行汇总记录。
如图1和图3所示,本实施例的基于Monkey参数可定制的自动测试系统的具体测试操作流程包括以下步骤:
S1:目标设备正常接入测试系统后,可以在测试系统内选择目标设备进行测试。测试系统会根据接入的目标设备类型,自动匹配同类型设备的历史测试脚本。
根据测试场景,测试系统支持选择一个设备或者多个设备进行测试。
S2:目标设备接入后,测试系统会获取当前目标设备所有待测试的APK包,用户可以在界面中选择需要的APK包进行测试。
S3:用户可以在界面(WER页面)中设置Monkey测试的相关参数,具体包括用户操作(即事件)间的时延、触摸事件百分比、反馈信息级别、伪随机数生成器的seed值以及程序运行中的相关配置。
S4:用户可以在界面(WER页面)中制定测试计划,根据测试场景配置测试时间、运行次数以及延时时间。
S5:测试系统会根据用户选择的Monkey测试参数,自动生成测试脚本。
测试场景案例:
测试包名com.android.settings,触摸事件的百分比10%,动作事件的百分比20%,轨迹事件的百分比30%,日志等级为level3,伪随机数生成器的seed值为3500,事件执行次数为100000。
DevOps作为敏捷开发重要的实现途径,测试系统支持Jenkins持续集成,通过Jenkins任务触发测试任务。持续集成作为DevOps中重要的一环,通过自动化构建与测试来加快产品开发速度、提高产品质量和可靠性。
本实施例中,持续集成的具体实现如下:
首先是插件安装:在Jenkins的管理界面中,点击"Manage Jenkins",然后选择"Manage Plugins"。在"Available"选项卡中搜索并安装以下插件:Android EmulatorPlugin、Gradle Plugin、Android Lint Plugin、APK Builder Plugin、TestResultsAnalyzerPlugin。
创建项目:在Jenkins主页上,点击"New Item"创建一个新的项目。输入项目名称,并选择"Freestyle project"或者"Pipeline"作为项目类型。
配置构建步骤:根据项目需求,配置构建步骤。以下是一些常见的配置示例:在"Build"部分中,配置Gradle构建步骤,例如执行Gradle命令进行代码编译、运行测试和生成APK文件等。使用Android Lint插件配置代码静态分析步骤。使用APKBuilder插件配置构建APK文件的步骤。使用Test ResultsAnalyzer插件配置测试结果分析步骤。
系统集成测试:在构建完成后,自动从测试系统获取需要的Monkey测试脚本,执行测试并将结果通知到用户。从自动化构建到自动化测试的过程以实现持续集成的目标。
S6:在步骤S5执行完成后,手动执行测试或通过Jenkins触发测试任务,测试系统会在后台模拟CMD命令自动执行测试脚本。手动执行测试可以是在测试系统内的页面上进行相关操作使其开始测试,Jenkins触发测试任务是指通过Jenkins来直接调度测试系统内的测试任务进行测试,不需要在测试系统内操作。
在自动执行测试脚本完成后,记录历史测试脚本,并存放在数据库中,增加测试脚本复用性,提高测试效率。
S7:在步骤S6执行完成后,根据测试数据,自动化分析测试结果。
测试结果分析包括崩溃日志分析统计:Monkey测试期间,如果应用程序崩溃或发生异常,会生成崩溃日志。这些日志记录了崩溃的堆栈跟踪信息,可以帮助开发人员定位并解决问题。
ANR(应用程序无响应)日志分析统计:如果应用程序在Monkey测试期间出现无响应的情况,测试系统会生成ANR日志。ANR日志包含了导致应用程序无响应的线程信息,有助于定位并解决应用程序的性能问题。
覆盖率报告分系统计:Monkey测试可以生成应用程序的覆盖率报告,显示在测试期间访问的代码和功能的覆盖情况。通过分析覆盖率报告,可以了解哪些部分的代码被测试覆盖,哪些部分需要进一步测试和验证。
性能指标分析统计:Monkey测试期间可以收集应用程序的性能指标,如CPU使用率、内存占用、网络流量等。分析这些指标可以评估应用程序的性能表现,并发现性能瓶颈和优化机会。
异常情况分析统计:分析Monkey测试期间发生的异常情况,如闪退、卡顿、UI(用户界面)异常等。可以统计异常的频率和类型,帮助开发人员识别和解决问题。
测试覆盖范围和结果总结:根据Monkey测试的目标和测试策略,可以对测试覆盖的范围和结果进行总结。包括测试持续时间、事件数量、覆盖的应用程序功能等信息。
测试结果自动写入Excel文件中,用户可以通过测试报告了解测试执行结果。
以上内容是结合具体的优选实施方式对本发明所作的进一步详细说明,不能认定本发明的具体实施只局限于这些说明。对于本发明所属技术领域的技术人员来说,在不脱离本发明构思的前提下,还可以做出若干等同替代或明显变型,而且性能或用途相同,都应当视为属于本发明的保护范围。
Claims (10)
1.一种基于Monkey的参数可定制的自动测试系统,其特征在于,包括:
设备管理模块,用于连接至少一个目标设备,获取目标设备所有待测试的测试包,并自定义选择需要测试的测试包;
参数配置模块,用于对Monkey测试参数进行设置,以定制测试事件;
测试计划模块,用于自定义设置测试事件的测试时间、运行次数与延时时间,以制定测试计划;
测试执行模块,用于根据设置好的Monkey测试参数自动生成测试脚本并对测试包进行测试,获取测试结果;
测试分析模块,用于根据测试过程数据自动分析并输出测试报告。
2.如权利要求1所述的基于Monkey的参数可定制的自动测试系统,其特征在于,所述设备管理模块、参数配置模块和测试计划模块分别通过可视化界面选择需要测试的测试包、设置测试参数、制定测试计划,以实现可视化操作。
3.如权利要求2所述的基于Monkey的参数可定制的自动测试系统,其特征在于,所述可视化界面为Web页面,所述Web页面基于electron搭建Windows桌面应用,使用antDesign组件库搭建页面。
4.如权利要求1所述的基于Monkey的参数可定制的自动测试系统,其特征在于,所述设备管理模块通过数据接口将目标设备和所述测试系统所在服务器连接;所述设备管理模块还用于识别目标设备类型,根据目标设备类型自动关联同类型的常用历史测试脚本。
5.如权利要求1所述的基于Monkey的参数可定制的自动测试系统,其特征在于,所述测试参数包括:用户操作间的时延、触摸事件百分比、反馈信息级别和伪随机数生成器的seed值。
6.如权利要求5所述的基于Monkey的参数可定制的自动测试系统,其特征在于,所述反馈信息级别分为level0、level1和level2。
7.如权利要求1所述的基于Monkey的参数可定制的自动测试系统,其特征在于,所述测试执行模块还用于对每次生成的测试脚本进行记录,所记录的历史测试脚本能够直接重复运行,当重复的测试场景再次测试时能够通过所述历史测试脚本实现一键化执行测试。
8.如权利要求1所述的基于Monkey的参数可定制的自动测试系统,其特征在于,所述测试执行模块还用于集成DevOps工具链,在持续集成流程中调度所述测试系统执行每日自动化测试;所述每日自动化测试具体为:通过Jenkins触发定时测试任务,获取测试系统内计划的测试脚本,在测试环境执行测试任务,获取测试结果并进行反馈。
9.如权利要求1所述的基于Monkey的参数可定制的自动测试系统,其特征在于,所述测试分析模块根据测试过程数据自动分析并输出测试报告具体为:获取Monkey测试过程中的日志数据,重定向日志文件并保存;通过分析保存的日志文件,进行自动化分析处理,统计ANR和Crash异常点,截取异常日志;自动统计测试过程中的异常点总数,记录异常日志并进行反馈。
10.一种基于Monkey的参数可定制的自动测试方法,其特征在于,基于如权利要求1至9中任一项所述的基于Monkey的参数可定制的自动测试系统,包括如下步骤:
A1、连接所述测试系统和目标设备,获取目标设备所有待测试的测试包,并自定义选择需要测试的测试包;
A2、对Monkey测试参数进行设置,定制测试事件;
A3、自定义设置测试事件的测试时间、运行次数与延时时间,制定测试计划;
A4、根据设置好的Monkey测试参数自动生成测试脚本并对测试包进行测试,并获取测试结果;
A5、对测试结果进行自动化分析并输出测试报告。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202310730806.5A CN116643996A (zh) | 2023-06-20 | 2023-06-20 | 基于Monkey的参数可定制的自动测试系统及方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202310730806.5A CN116643996A (zh) | 2023-06-20 | 2023-06-20 | 基于Monkey的参数可定制的自动测试系统及方法 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN116643996A true CN116643996A (zh) | 2023-08-25 |
Family
ID=87640021
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202310730806.5A Pending CN116643996A (zh) | 2023-06-20 | 2023-06-20 | 基于Monkey的参数可定制的自动测试系统及方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN116643996A (zh) |
-
2023
- 2023-06-20 CN CN202310730806.5A patent/CN116643996A/zh active Pending
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11281570B2 (en) | Software testing method, system, apparatus, device medium, and computer program product | |
CN109683899B (zh) | 一种软件集成方法及装置 | |
US8276126B2 (en) | Determining causes of software regressions based on regression and delta information | |
CN103150249B (zh) | 一种自动化测试的方法和系统 | |
US7895565B1 (en) | Integrated system and method for validating the functionality and performance of software applications | |
US7010782B2 (en) | Interactive automatic-test GUI for testing devices and equipment using shell-level, CLI, and SNMP commands | |
CN103365770B (zh) | 移动终端软件测试系统及软件测试方法 | |
CN105094783A (zh) | 安卓应用稳定性测试的方法及装置 | |
CN109614391B (zh) | 数据库诊断系统、数据库诊断方法及非临时性机器可读介质 | |
WO2019182932A1 (en) | Unified test automation system | |
CN105095059B (zh) | 一种自动化测试的方法和装置 | |
CN111124919A (zh) | 一种用户界面的测试方法、装置、设备及存储介质 | |
Derakhshanfar et al. | Search‐based crash reproduction using behavioural model seeding | |
CN105653946A (zh) | 基于组合事件行为触发的Android恶意行为检测系统及其检测方法 | |
CN103678124A (zh) | 基于持续集成环境的视频监控平台自动测试方法及装置 | |
CN112433948A (zh) | 一种基于网络数据分析的仿真测试系统及方法 | |
US20190236223A1 (en) | Identification of changes in functional behavior and runtime behavior of a system during maintenance cycles | |
CN116643996A (zh) | 基于Monkey的参数可定制的自动测试系统及方法 | |
CN116383025A (zh) | 基于Jmeter的性能测试方法、装置、设备及介质 | |
CN109783368A (zh) | 梯形图编程软件测试系统及方法 | |
CN115759518A (zh) | 基于混沌工程的可用性治理系统 | |
KR102430523B1 (ko) | 웹 기반 모바일 디바이스 검증 자동화 플랫폼 시스템 및 그 검증 방법 | |
CN118227506B (zh) | 基于rpa机器人的ui自动化测试系统及方法 | |
CN111813662A (zh) | 用户行为驱动的可持续集成的测试方法、装置和设备 | |
CN111444108A (zh) | 一种基于s7工业协议的行为审计自动化测试方法 |
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 |