monkey自动化测试(1)----命令行

2024-08-22 20:08

本文主要是介绍monkey自动化测试(1)----命令行,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

由于公司业务需要,需要对相应的一些apk进行相应的一些压力测试。当然,现在被使用得比较多的下面介绍几种
android测试框架lint
CTS
Monkey
Monkeyrunner
benchmark
其它test tool等等。
最终讨论后决定采取Monkey/MonkeyRunner来进行测试,但是楼主没有相关的经验,所以一边查阅资料,一边学习。

2326194-879dcfd55f73bb05.jpg
程序猿日常

参考文献:
https://www.cnblogs.com/zhaoyanjun/p/6861278.html 【monkey架构设计】
https://www.cnblogs.com/plokmju/p/6445975.html 【monkey的用法】

Monkey

什么是Monkey

Monkey是Android中的一个命令行工具,可以运行在模拟器里或实际设备中。它向系统发送伪随机的用户事件流(如按键输入、触摸屏输入、手势输入等),实现对正在开发的应用程序进行压力测试。Monkey测试是一种为了测试软件的稳定性、健壮性的快速有效的方法。(其实可以想象成一只猴子啥都不知道,疯狂乱敲......)

monkey的特点

Monkey 程序是由 Android 系统自带,使用 Java 语言写成。在Android文件系统中的存放路径是:

/system/framework/monkey.jar;

Monkey.jar程序是由一个名为“monkey”的Shell脚本来启动执行,shell脚本在Android文件系统中 的存放路径是:

/system/bin/monkey;

也就是说monkey可以直接通过打包进测试工具中,被测试人员直接使用,网络上许多第三方的monkey工具就是通过对原生的Monkey.jar包进行二次开发实现。

Monkey测试的停止条件

  • 如果限定了Monkey运行在一个或几个特定的包上,那么它会监测试图转到其它包的操作,并对其进行阻止。

  • 如果应用程序崩溃或接收到任何失控异常,Monkey将停止并报错,前提在于没有配置crash继续执行的操作下。

  • 如果应用程序产生了应用程序不响应(application not responding)的错误,Monkey将会停止并报错,前提在于没有配置ANR继续执行的操作下

Monkey 架构

Monkey 运行在设备或模拟器上面,可以脱离PC运行(一般在一些大公司中都是将其抽离成一个测试专用的APP工具,使用相应的操作来完成测试,不过楼主暂时没有找到比较好的二次开发工具,希望有大神可以指导一下)
2326194-c0555a30ab0517e0.png
Monkey启动架构图

Monkey的基本用法

由于Monkey的命令行过多,这里选择比较常用的操作命令行来做引申讲解,有兴趣的朋友可以到google官网继续学习。


2326194-148b1938e1ec0529.png
常用命令行.png

基本语法如下:

adb shell monkey [options]

例如:monkey -p your.package.name -v 500

如果不指定options,Monkey将以无反馈模式启动,并把事件任意发送到安装在目标环境中的全部包。下面是一个更为典型的命令行示例,它启动指定的应用程序,并向其发送500个伪随机事件。

可以在Android Studio中可以直接使用,但是也可以在android sdk中的platform-tools目录下,直接cmd输入命令 adb shell 。


2326194-5f37b2ccb44c22e9.png
基本用法

接下来就开始啃啃这块最难的硬骨头:

  • 1、允许启动手机里面所有的 App , 随机操作 1000 次
adb shell monkey 1000
  • 2、-p : 允许启动 App 的包名
    • 启动一个包名的应用

      由于楼主的手机是小米手机,所以测试小米的计算器功能,其包名为com.miui.calculator,具体命令行为:

adb shell monkey -p com.miui.calculator 1000

最终效果是monkey会调用小米自带的计算器功能运行1000次。

  • 启动一个包名的应用
    在一些讲解命令行时,只讲到单APP的调试,但是monkey具备同时对多设备进行调试的能力,只需要增加多个 -p 包名字段就可以实现。
adb shell monkey -p com.miui.calculator -p com.android.thememanager 1000

该命令行可以实现对多个应用进行开启的功能。

  • 3、-v : 操作日志记录
    命令行不同个数的-v会有不同的效果
    • -v:Level 0(缺省值)除 启动提示、测试完成和最终结果之外,提供较少信息。
    • -v -v :Level 1提供较为详细的测试信息,如逐个发送到Activity的 事件。
    • -v -v -v :Level 2提供更加详细的设置信息,如测试中被选中的或未被选中的Activity。
      如:
adb shell monkey -p com.miui.calculator -v -v -v 1000
  • 4、-s 伪随机数生成器的seed值
    测试为了人员能够重现测试到的bug问题,需要能够对Monkey的随机生成事件有重现能力,monkey允许对随机事件的seed值做设置,当两次seed值一样,整个测试效果将会产生相同的事件序列。
adb shell monkey -p com.miui.calculator -s 12345 -v 1000
  • 5、--ignore-crashes 忽略崩溃/--ignore-timeouts 忽略超时/--ignore-security-exceptions 忽略安全异常
    一般情况下,APP在操作过程中会存在崩溃、超时、异常等情况,按照前面所提到的,这会导致monkey直接停止测试。如果想要忽略掉这些情况,直接配置忽略设置就可以了。ps:这里的超时并不是网络超时,而是相应超时导致的ANR。
adb shell monkey -p com.miui.calculator--ignore-crashes --ignore-timeouts --ignore-security-exceptions-v 1000
  • 6.--throttle : 事件之间加入延时操作
    在某些不需要频率过快,或需要定频率进行交互时,可以采用--throttle来做事件之间的延时操作。
·adb shell monkey -p com.miui.calculator --throttle 500 -v 1000
  • 7、指定Monkey事件
    在Monkey中,虽然输入的事件是随机产生的,但是可以指定输入事件类型的百分比,让其控制在我们需要的范围内。
    在Monkey中,可以设定的事件类型有:
  * --pct-touch <percent>:指定触摸事件的百分比。* --pct-motion <percent>:指定滑动事件的百分比。* --pct-trackball <percent>:指定轨迹球事件的百分比。* --pct-nav <percent>:指定导航事件中,up、down、left、right等事件的百分比。* --pct-majornav <percent>:指定导航事件中,back、menu等事件的百分比。* --pct-syskeys <percent>:指定系统按键的百分比,包括HOME、Back、音量等。* --pct-appswitch <percent>:指定Activity之间切换的比例。* --pct-anyevent <percent>:指定任意事件的百分比。

其中,当不作任何配置的时候,默认为--pct-anyevent <percent>,此时所有事件的触发均为随机的。当所有事件的百分比加起重来小于100%的时候,多余的随机事件也将被转化为--pct-anyevent <percent>事件。超过时,系统会重新运算相应的比例。

到此,基本的命令行就已经讲解完毕,如果还有需要的配置命令行,请参考--help进行拓展,这里就不赘述,最后附上命令行:

adb shell --help

最终效果粘贴在下面:

usage: monkey [-p ALLOWED_PACKAGE [-p ALLOWED_PACKAGE] ...]//调试的应用包名[-c MAIN_CATEGORY [-c MAIN_CATEGORY] ...]//测试对应的categrory[--ignore-crashes] [--ignore-timeouts][--ignore-security-exceptions][--monitor-native-crashes] [--ignore-native-crashes]//忽略系列的大爷们[--kill-process-after-error] [--hprof]//默认[--pct-touch PERCENT] [--pct-motion PERCENT][--pct-trackball PERCENT] [--pct-syskeys PERCENT][--pct-nav PERCENT] [--pct-majornav PERCENT][--pct-appswitch PERCENT] [--pct-flip PERCENT][--pct-anyevent PERCENT] [--pct-pinchzoom PERCENT]//事件百分比设置[--pkg-blacklist-file PACKAGE_BLACKLIST_FILE][--pkg-whitelist-file PACKAGE_WHITELIST_FILE][--wait-dbg] [--dbg-no-events][--setup scriptfile] [-f scriptfile [-f scriptfile] ...][--port port][-s SEED] [-v [-v] ...]//设置随机数生成器的seed值[--throttle MILLISEC] [--randomize-throttle]//延时操作[--profile-wait MILLISEC][--device-sleep-time MILLISEC][--randomize-script][--script-log][--bugreport][--periodic-bugreport]COUNT

如何关闭monkey

monkey在运行过程中就算PC拔掉USB数据线,也会继续进行,但是在某些情况下,将我们需要monkey关掉。这需要强制将正在运行monkey。
首先。使用

adb shell
ps | grep monkey
kill pid(前面会输出)

2326194-5061937b892ead49.png
最终效果图

接下来,会将如何对输出的log进行解读和调试。希望大家可以点赞评论

这篇关于monkey自动化测试(1)----命令行的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1097267

相关文章

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

【测试】输入正确用户名和密码,点击登录没有响应的可能性原因

目录 一、前端问题 1. 界面交互问题 2. 输入数据校验问题 二、网络问题 1. 网络连接中断 2. 代理设置问题 三、后端问题 1. 服务器故障 2. 数据库问题 3. 权限问题: 四、其他问题 1. 缓存问题 2. 第三方服务问题 3. 配置问题 一、前端问题 1. 界面交互问题 登录按钮的点击事件未正确绑定,导致点击后无法触发登录操作。 页面可能存在

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

用命令行的方式启动.netcore webapi

用命令行的方式启动.netcore web项目 进入指定的项目文件夹,比如我发布后的代码放在下面文件夹中 在此地址栏中输入“cmd”,打开命令提示符,进入到发布代码目录 命令行启动.netcore项目的命令为:  dotnet 项目启动文件.dll --urls="http://*:对外端口" --ip="本机ip" --port=项目内部端口 例: dotnet Imagine.M

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

如何使用Ansible实现CI/CD流水线的自动化

如何使用Ansible实现CI/CD流水线的自动化 持续集成(CI)和持续交付(CD)是现代软件开发过程中的核心实践,它们帮助团队更快地交付高质量的软件。Ansible,作为一个强大的自动化工具,可以在CI/CD流水线中发挥关键作用。本文将详细介绍如何使用Ansible实现CI/CD流水线的自动化,包括设计流水线的结构、配置管理、自动化测试、部署、以及集成Ansible与CI/CD工具(如Jen

Verybot之OpenCV应用一:安装与图像采集测试

在Verybot上安装OpenCV是很简单的,只需要执行:         sudo apt-get update         sudo apt-get install libopencv-dev         sudo apt-get install python-opencv         下面就对安装好的OpenCV进行一下测试,编写一个通过USB摄像头采

BIRT 报表的自动化测试

来源:http://www.ibm.com/developerworks/cn/opensource/os-cn-ecl-birttest/如何为 BIRT 报表编写自动化测试用例 BIRT 是一项很受欢迎的报表制作工具,但目前对其的测试还是以人工测试为主。本文介绍了如何对 BIRT 报表进行自动化测试,以及在实际项目中的一些测试实践,从而提高了测试的效率和准确性 -------

可测试,可维护,可移植:上位机软件分层设计的重要性

互联网中,软件工程师岗位会分前端工程师,后端工程师。这是由于互联网软件规模庞大,从业人员众多。前后端分别根据各自需求发展不一样的技术栈。那么上位机软件呢?它规模小,通常一个人就能开发一个项目。它还有必要分前后端吗? 有必要。本文从三个方面论述。分别是可测试,可维护,可移植。 可测试 软件黑盒测试更普遍,但很难覆盖所有应用场景。于是有了接口测试、模块化测试以及单元测试。都是通过降低测试对象