Monkey测试是Android自动化测试的一种手段,Monkey测试本身非常简单,就是模拟用户的按键输入,触摸屏输入,手势输入等,看设备多长时间会出异常。
当Monkey程序在模拟器或设备运行的时候,如果用户出发了比如点击,触摸,手势或一些系统级别的事件的时候,它就会产生随机脉冲,所以可以用Monkey用随机重复的方法去负荷测试你开发的软件.
最简单的方法就是用用下面的命令来使用Monkey,这个命令将会启动你的软件并且触发500个事件.
$
adb shell monkey -v -p your.package.name
500
更多的关于命令Monkey的命令的信息,可以查看UI/Application
Monkey是一个命令行工具,可以运行在模拟器里或实际设备中。它向系统发送伪随机的用户事件流,实现对正在开发的应用程序进行压力测试。Monkey包括许多选项,它们大致分为四大类:
?
基本配置选项,如设置尝试的事件数量。
? 运行约束选项,如设置只对单独的一个包进行测试。
?
事件类型和频率。
?
调试选项。
在Monkey运行的时候,它生成事件,并把它们发给系统。同时,Monkey还对测试中的系统进行监测,对下列三种情况进行特殊处理:
?
如果限定了Monkey运行在一个或几个特定的包上,那么它会监测试图转到其它包的操作,并对其进行阻止。
?
如果应用程序崩溃或接收到任何失控异常,Monkey将停止并报错。
? 如果应用程序产生了应用程序不响应(application
not
responding)的错误,Monkey将会停止并报错。
按照选定的不同级别的反馈信息,在Monkey中还可以看到其执行过程报告和生成的事件。
Monkey基本用法
:
可以通过开发机器上的命令行或脚本来启动Monkey。由于Monkey运行在模拟器/设备环境中,所以必须用其环境中的shell来进行启动。可以通过在每条命令前加上adb
shell来达到目的,也可以进入Shell后直接输入Monkey命令。基本语法如下:
$ adb shell monkey
[options]
如果不指定options,Monkey将以无反馈模式启动,并把事件任意发送到安装在目标环境中的全部包。下面是一个更为典型的命令行示例,它启动指定的应用程序,并向其发送500个伪随机事件:
$
adb shell monkey -p your.package.name -v
500
命令选项参考:
下表中列出了Monkey命令行可用的全部选项。
类别
选项
说明
常规
--help
列出简单的用法。
-v
命令行的每一个
-v 将增加反馈信息的级别。 Level 0( 缺省值 ) 除启动提示、测试完成和最终结果之外,提供较少信息。 Level
1提供较为详细的测试信息,如逐个发送到 ActivITy 的事件。 Level 2 提供更加详细的设置信息,如测试中被选中的或未被选中的Activity
。
事件
-s
<seed>
伪随机数生成器的 seed 值。如果用相同的 seed 值再次运行 Monkey
,它将生成相同的事件序列。
--throttle
<milliseconds>
在事件之间插入固定延迟。通过这个选项可以减缓
Monkey
相关文章
- 01-12Android studio (AS)实现Getter和Setter的快捷键
- 01-12android – 如何获取位图信息,然后从internet-inputStream解码位图?
- 01-12android-如何将appium与机器人框架集成?
- 01-12RobotFramework +appium实现Android自动化
- 01-12挂在inStream.readline()上的Android TCP应用
- 01-12android-如何将流程的标准输出绑定到TextView
- 01-12android-客户端如何保持等待可能的服务器消息?
- 01-12android-具有Robotframework的MonkeyRunner
- 01-12android – 如何将两个mp3文件合并为一个(组合/连接)
- 01-12如何在kotlin android中用responseInputStream.read编写while循环–while((i = responseInputStream.read(byteContain