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

相关文章

redis-cli命令行工具的使用小结

《redis-cli命令行工具的使用小结》redis-cli是Redis的命令行客户端,支持多种参数用于连接、操作和管理Redis数据库,本文给大家介绍redis-cli命令行工具的使用小结,感兴趣的... 目录基本连接参数基本连接方式连接远程服务器带密码连接操作与格式参数-r参数重复执行命令-i参数指定命

Python Invoke自动化任务库的使用

《PythonInvoke自动化任务库的使用》Invoke是一个强大的Python库,用于编写自动化脚本,本文就来介绍一下PythonInvoke自动化任务库的使用,具有一定的参考价值,感兴趣的可以... 目录什么是 Invoke?如何安装 Invoke?Invoke 基础1. 运行测试2. 构建文档3.

Windows自动化Python pyautogui RPA操作实现

《Windows自动化PythonpyautoguiRPA操作实现》本文详细介绍了使用Python的pyautogui库进行Windows自动化操作的实现方法,文中通过示例代码介绍的非常详细,对大... 目录依赖包睡眠:鼠标事件:杀死进程:获取所有窗口的名称:显示窗口:根据图片找元素:输入文字:打开应用:依

Jenkins中自动化部署Spring Boot项目的全过程

《Jenkins中自动化部署SpringBoot项目的全过程》:本文主要介绍如何使用Jenkins从Git仓库拉取SpringBoot项目并进行自动化部署,通过配置Jenkins任务,实现项目的... 目录准备工作启动 Jenkins配置 Jenkins创建及配置任务源码管理构建触发器构建构建后操作构建任务

如何测试计算机的内存是否存在问题? 判断电脑内存故障的多种方法

《如何测试计算机的内存是否存在问题?判断电脑内存故障的多种方法》内存是电脑中非常重要的组件之一,如果内存出现故障,可能会导致电脑出现各种问题,如蓝屏、死机、程序崩溃等,如何判断内存是否出现故障呢?下... 如果你的电脑是崩溃、冻结还是不稳定,那么它的内存可能有问题。要进行检查,你可以使用Windows 11

性能测试介绍

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

字节面试 | 如何测试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