adb shell monkey -p com.djc.qcyzt --pct-touch 40 --pct-motion 25
–pct-appswitch 10 --pct-rotation 10 -s 1666 --throttle 200 --ignore-crashes --ignore-timeouts --ignore-security-exceptions --ignore-native-crashes --monitor-native-crashes -v -v 100000 >d:\monkey.txt
Monkey 就是SDK中附带的一个工具。Monkey是Android中的一个命令行工具,可以运行在模拟器里或实际设备中。它向系统发送伪随机的用户事件流(如按键输入、触摸屏输入、手势输入等),实现对正在开发的应用程序进行压力测试。Monkey测试是一种为了测试软件的稳定性、健壮性的快速有效的方法。
该工具用于进行压力测试。然后开发人员结合monkey 打印的日志和系统打印的日志,分析测试中的问题
Monkey 测试,所有的事件都是随机产生的,不带任何人的主观性。
1、测试的对象仅为应用程序包,有一定的局限性。
2、Monky测试使用的事件数据流是随机的,不能进行自定义。
3、可对MonkeyTest的对象,事件数量,类型,频率等进行设置。
-p
如果用此参数指定了一个或几个包,Monkey将只允许系统启动这些包里的Activity。如果你的应用程序还需要访问其它包里的Activity(如选择取一个联系人),那些包也需要在此同时指定。如果不指定任何包,Monkey将允许系统启动全部包里的Activity。要指定多个包,需要使用多个-p选项,每个-p选项只能用于一个包。
-c
如果用此参数指定了一个或几个类别,Monkey将只允许系统启动被这些类别中的某个类别列出的Activity。如果不指定任何类别,Monkey将选择下列类别中列出的Activity:Intent.CATEGORY_LAUNCHER或Intent.CATEGORY_MONKEY。要指定多个类别,需要使用多个-c选项,每个-c选项只能用于一个类别。
调整事件百分比
a. adb shell monkey -v 100:对整机进行100次随机事件。
b. adb shell monkey -v --throttle 1000 100:对整机进行100次随机事件,每次事件的时间间隔为1000毫秒。
c. adb shell monkey -v -v -v --pct-touch100 --throttle 1000 100:对整机进行100次触摸事件,每次事件的时间间隔为1000毫秒。
adb shell monkey -v -p com.package.name --throttle 1000 100
a. 验证程序的健壮性:adb shell Monkey -v -p com.package.name --throttle 100 10000
对指定应用进行10000次随机时间,每一次执行一次有效的事件后休眠100毫秒
b. 对程序进行指定压力测试:adb shell Monkey -v -p com.package.name --pct-touch 100 --throttle 100 10000
对指定应用进行10000次触摸事件,每次事件的时间间隔为100毫秒
a. adb shell monkey -v -p com.package.name --pct-touch 100 --throttle 1000 100
对指定应用进行100次触摸事件,每次事件的时间间隔为1000毫秒
b. adb shell monkey -s 12 --throttle 450-p com.package.name --kill-process-after-error --ignore-timeouts–ignore-security-exceptions -v 10000 >D:\Monkey-logs\testlog.log
如何查找包名及启动的Activity名称:aapt dump badging [将本地APP包拖入,注:包名不要起中文] | findstr “launchable-activity”
adb shell monkey … >d:\monkeylog.txt:保存在手机上
adb shell monkey -v 100 >/sdcard/monkeylog.log
注:不能写成adb shell monkey -f /sdcard/kyb.txt -v 1 >/mnt/sdcard/monkeylog.log否则会报错“系统找不到指定的路径”
Monkey [option] 1>sdcard/monkey.txt 2>sdcard/error.txt
如:adb shell monkey -v 100 1>d:\monkey.log 2>d:\error.log
执行以上命令,monkey的运行日志和异常日志将被分开保存,此时monkey的运行日志将被保存在monkey.txt文件中,而异常日志将被保存在D盘下的error.txt中。
将执行Monkey生成的log,从手机中导出并打开查看该log;在log的最开始都会显示Monkey执行的seed值、执行次数和测试的包名。
首先我们需要查看Monkey测试中是否出现了ANR或者异常,具体方法如上述。然后我们要分析log中的具体信息,方法如下:
查看log中第一个Switch,主要是查看Monkey执行的是那一个Activity,譬如下面的log中,执行的是com.tencent.smtt.SplashActivity,在下一个swtich之间的,如果出现了崩溃或其他异常,可以在该Activity中查找问题的所在。
:Switch:#Intent;action=android.intent.action.MAIN;category=android.intent.category.LAUNCHER;launchFlags=0x10000000;component=com.tencent.smtt/.SplashActivity;end
// Allowing start of Intent {act=android.intent.action.MAIN
cat=[android.intent.category.LAUNCHER]cmp=com.tencent.smtt/.SplashActivity
} in package com.tencent.smtt
在下面的log中,Sending Pointer ACTION_DOWN和Sending Pointer ACTION_UP代表当前执行了一个单击的操作;
Sleeping for 500 milliseconds这句log是执行Monkey测试时,throttle设定的间隔时间,每出现一次,就代表一个事件。
SendKey(ACTION_DOWN) //KEYCODE_DPAD_DOWN 代表当前执行了一个点击下导航键的操作;
Sending Pointer ACTION_MOVE 代表当前执行了一个滑动界面的操作。 :Sending Pointer
ACTION_DOWN x=47.0 y=438.0 :Sending Pointer ACTION_MOVE x=-2.0 y=-4.0
ANR
如果Monkey测试顺利执行完成,在log的最后,会打印出当前执行事件的次数和所花费的时间;// Monkey finished代表执行完成。Monkey执行中断,在log的最后也能查看到当前已执行的次数。Monkey执行完成的log具体如下:
Events injected: 6000
:Dropped: keys=0 pointers=9 trackballs=0 flips=0
##Network stats: elapsed time=808384ms (0ms mobile, 808384ms wifi, 0msnot connected)
// Monkey finished
范例:
Monkey测试结果:
#monkey -p wfh.LessonTable -v -v -v 200
:Monkey: seed=0 count=200
:AllowPackage: wfh.LessonTable
:IncludeCategory: android.intent.category.LAUNCHER
:IncludeCategory: android.intent.category.MONKEY
// Selecting main activities from category
android.intent.category.LAUNCHER// - NOT USING main activity com.android.browser.BrowserActivity
(from package com.android.browser)// Seeded: 0
// Event percentages:
// 0: 15.0%
// 1: 10.0%
// 2: 15.0%
// 3: 25.0%
// 4: 15.0%
// 5: 2.0%
// 6: 2.0%
// 7: 1.0%
// 8: 15.0%
:Switch:
#Intent;action=android.intent.action.MAIN;category=android.intent.category.LAUNCHER;launchFlags=0x10000000;component=wfh.LessonTable/.MainTable;end// Allowing start of Intent { act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] cmp=wfh.LessonTable/.MainTable
} in package wfh.LessonTable
Sleeping for 0 milliseconds
:SendKey (ACTION_DOWN): 21 // KEYCODE_DPAD_LEFT
:SendKey (ACTION_UP): 21 // KEYCODE_DPAD_LEFT
Sleeping for 0 milliseconds
//------------------------------------用--throttle来设置一个起效的事件发生后时延时。:Sending Pointer ACTION_DOWN x=0.0 y=0.0
:Sending Pointer ACTION_UP x=0.0 y=0.0
Sleeping for 0 milliseconds
:Sending Pointer ACTION_MOVE x=0.0 y=0.0
当测试到ACTION_MOVE x=0.0 y=0.0这个动作时,发生了FC(Force Close)错误,以下为输出错误信息。同时在LogCat里面也有错误输出,而且LogCat里面的错误信息更为详细,在实际的测试中应该结合两者输出的信息进行调试程序。
// CRASH: wfh.LessonTable (pid 1973)
// Short Msg: java.lang.NullPointerException
// Long Msg: java.lang.NullPointerException
// Build Label:
android:generic/sdk/generic/:2.1-update1/ECLAIR/35983:eng/test-keys// Build Changelist: 35983
// Build Time: 1273161972
// ID:
// Tag: AndroidRuntime
// java.lang.NullPointerException:
// at android.widget.TabHost.dispatchKeyEvent(TabHost.java:279)
// at android.view.ViewGroup.dispatchKeyEvent(ViewGroup.java:748)
** Monkey aborted due to error.
Events injected: 190
:Dropped: keys=0 pointers=11 trackballs=0 flips=0
##Network stats: elapsed time=27954ms (27954ms mobile, 0ms wifi, 0ms not connected)
** System appears to have crashed at event 190 of 200 using seed 0
开始monkey测试时android的LogCat输出的信息:
11-01 08:52:53.712: DEBUG/AndroidRuntime(2077): >>>>>>>>>>>>>>
AndroidRuntime START <<<<<<<<<<<<<<11-01 08:52:53.742: DEBUG/AndroidRuntime(2077): CheckJNI is ON
11-01 08:52:54.453: DEBUG/AndroidRuntime(2077): —
以下为LogCat输出的错误信息,在以下的信息中首先从自己的包中找错误,如果没有自己的包的话就再找发生错误的包的第一个发生了异常。由错误提示可以看出很大的可能是因为TabHost引发的异常。经过查看代码发现是由于TabHost的编写不规范,TabHost与其中一个view放在了一起,在monkey测试做滚球上下滚动时当滚到TabHost时就发生了异常了。所以把TabHost与Activity分开写就不会出现些问题了。
11-01 08:53:27.113: ERROR/AndroidRuntime(1973): Uncaught handler:
thread main exiting due to uncaught exception11-01 08:53:27.133: ERROR/AndroidRuntime(1973):
java.lang.NullPointerException11-01 08:53:27.133: ERROR/AndroidRuntime(1973): at
android.widget.TabHost.dispatchKeyEvent(TabHost.java:279)11-01 08:53:27.133: ERROR/AndroidRuntime(1973): at
android.view.ViewGroup.dispatchKeyEvent(ViewGroup.java:748)
adb connect 127.0.0.1:62001
adb devices
常规Monkey测试执行的是随机的事件流,但如果只是想让Monkey测试某个特定场景这时候就需要用到自定义脚本了,Monkey支持执行用户自定义脚本的测试,用户只需要按照Monkey脚本的规范编写好脚本,存放到手机上,启动Monkey通过-f 参数调用脚本即可。
Monkey脚本只能通过坐标的方式来定位点击和移动事件的屏幕位置,这里就需要提前获取坐标信息。获取坐标信息的方法很多,最简单的方法就是打开手机中的开发人员选项,打开“显示指针位置”。随后,在屏幕上的每次操作,在导航栏上都会显示坐标信息。
注:手机没有开开发者选项时,到手机设置–关于手机–型号,连续点击7次就会出现该选项
Monkey脚本主要包含两部分,一部分是头文件信息,一部分是具体的monkey命令。
#头部: type = raw events count = 1 次数 speed = 1.0 时间
#下面为monkey命令: start data >> 具体的monkey脚本内容
注:头文件代码书写注意“=”两边预留空格,否则会出现如下报错。
type = raw events count = 1 speed = 1.0 start data >>
LaunchActivity(com.tal.kaoyan,com.tal.kaoyan.ui.activity.SplashActivity)
UserWait(2000) Tap(624,900,1000) #点击取消升级
UserWait(2000)Tap(806,64,1000) #点击跳过 UserWait(2000)Tap(217,378,1000)
#点击用户名输入框 DispatchString(zxw1234) UserWait(2000)Tap(197,461,1000) #点击密码输入框 DispatchString(zxw123456) UserWait(2000) Tap(343,637,1000) #点击登录按钮
脚本编写完成后,传到手机设备上,然后执行
adb push C:\Users\Shuqing\Desktop\kyb1.txt /sdcard
adb shell monkey -f /sdcard/kyb1.txt -v 1