如何進行Monkey Test
目錄
一 簡介
二 測試准備
三 基本命令格式
四 測試Log獲取
五 Monkey命令參數介紹
六 保存monkey log以及手機log到sdcard(新增)
一、簡介
Monkey是Android中的一個命令行工具,可以運行在模擬器里或實際設備中。它向系統發送偽隨機的用戶事件流(如按鍵輸入、觸摸屏輸入、手勢輸入等),實現對正在開發的應用程序進行壓力測試。Monkey包括許多選項,它們大致分為四大類:
- 基本配置選項,如設置嘗試的事件數量
- 運行約束選項,如設置只對單獨的一個包進行測試
- 事件類型和頻率
- 調試選項
在Monkey運行的時候,它生成事件,並把它們發給系統。同時,Monkey還對測試中的系統進行監測,對下列三種情況進行特殊處理(自動停止):
- 如果限定了Monkey運行在一個或幾個特定的包上,那么它會監測試圖轉到其它包的操作,並對其進行阻止。
- 如果應用程序崩潰或接收到任何失控異常,Monkey將停止並報錯。
- 如果應用程序產生了應用程序不響應(application not responding)的錯誤,Monkey將會停止並報錯。
按照選定的不同級別的反饋信息,在Monkey中還可以看到其執行過程報告和生成的事件
二、測試准備
Monkey test前必須先進入android設備的adb shell(Android SDK環境配置不在此描述,網上有很多)步驟如下:
1. 開始—>運行—>cmd
2. usb連接手機,輸入 adb shell 命令,待出現 即可輸入以下內容
3. 進入手機后,輸入相應的monkey命令即可測試
三、基本命令格式
adb shell monkey –p 程序包 –v 測試次數
比如“adb shell monkey –p com.htc.Weather –v 20000”意思是對com.htc.Weather 這個程序包單獨進行一次20000次的monkey測試
其中程序包名稱可以在串口終端這句命令獲得:ls data/data 顯示所有程序包
四、測試Log獲取
用Monkey test測試,為了方便分析問題,可以在命令monkey命令后面加上 “|logcat -v time”,這樣就能邊測試邊打印Log(記得用終端保存Log文本)例如:
adb shell monkey –p com.htc.Weather –v 20000|logcat -v time
但是這個組合在monkey測試完成后,logcat仍然在執行,測試時需要注意。
如果測試monkey碰到crash或者anr(程序強制性退出或不響應)現象時,在抓取log的同時需要提供traces.txt,步驟如下:
1. 測試版本需要具備root權限
2. 進入data/anr目錄下面
3. 將traces.txt文件拷貝到TF卡中,然后拷貝出來發給軟件分析即可
五、Monkey命令參數介紹
1) 參數:-p
參數-p用於約束限制,用此參數指定一個或多個包(Package,即App)。指定
包之后,Monkey將只允許系統啟動指定的APP。如果不指定包,Monkey將允許系統啟動設備中的所有APP。
* 指定一個包: adb shell monkey -p com.htc.Weather 100
說明:com.htc.Weather為包名,100是事件計數(即讓Monkey程序模擬100次隨機用戶事件)。
* 指定多個包:adb shell monkey -p com.htc.Weather –p com.htc.pdfreader -p com.htc.photo.widgets 100
* 不指定包:adb shell monkey 100
說明:Monkey隨機啟動APP並發送100個隨機事件。
* 要查看設備中所有的包,在CMD窗口中執行以下命令:
>adb shell
#cd data/data
#ls
2) 參數: -v
用於指定反饋信息級別(信息級別就是日志的詳細程度),總共分3個級別,分別對應的參數如下表所示:
日志級別 Level 0
示例 adb shell monkey -p com.htc.Weather –v 100
說明 缺省值,僅提供啟動提示、測試完成和最終結果等少量信息
日志級別 Level 1
示例 adb shell monkey -p com.htc.Weather –v -v 100
說明 提供較為詳細的日志,包括每個發送到Activity的事件信息
日志級別 Level 2
示例 adb shell monkey -p com.htc.Weather –v -v –v 100
說明 最詳細的日志,包括了測試中選中/未選中的Activity信息
3)參數: -s
用於指定偽隨機數生成器的seed值,如果seed相同,則兩次Monkey測試所產生的事件序列也相同的。
* 示例:
Monkey測試1:adb shell monkey -p com.htc.Weather –s 10 100
Monkey測試2:adb shell monkey -p com.htc.Weather –s 10 100
兩次測試的效果是相同的,因為模擬的用戶操作序列(每次操作按照一定的先后順序所組成的一系列操作,即一個序列)是一樣的。操作序列雖然是隨機生成的,但是只要我們指定了相同的Seed值,就可以保證兩次測試產生的隨機操作序列是完全相同的,所以這個操作序列偽隨機的;
4) 參數: --throttle <毫秒>
用於指定用戶操作(即事件)間的時延,單位是毫秒;
* 示例:adb shell monkey -p com.htc.Weather –throttle 3000 100
5) 參數: --ignore-crashes
用於指定當應用程序崩潰時(Force & Close錯誤),Monkey是否停止運行。如果使用此參數,即使應用程序崩潰,Monkey依然會發送事件,直到事件計數完成。
* 示例1:adb shell monkey -p com.htc.Weather --ignore-crashes 1000
測試過程中即使Weather程序崩潰,Monkey依然會繼續發送事件直到事件數目達到1000為止;
* 示例2:adb shell monkey -p com.htc.Weather 1000
測試過程中,如果Weather程序崩潰,Monkey將會停止運行。
6) 參數: --ignore-timeouts
用於指定當應用程序發生ANR(Application No Responding)錯誤時,Monkey是否停止運行。如果使用此參數,即使應用程序發生ANR錯誤,Monkey依然會發送事件,直到事件計數完成。
7) 參數: --ignore-security-exceptions
用於指定當應用程序發生許可錯誤時(如證書許可,網絡許可等),Monkey是否停止運行。如果使用此參數,即使應用程序發生許可錯誤,Monkey依然會發送事件,直到事件計數完成。
8) 參數: --kill-process-after-error
用於指定當應用程序發生錯誤時,是否停止其運行。如果指定此參數,當應用程序發生錯誤時,應用程序停止運行並保持在當前狀態(注意:應用程序僅是靜止在發生錯誤時的狀態,系統並不會結束該應用程序的進程)。
9) 參數: --monitor-native-crashes
用於指定是否監視並報告應用程序發生崩潰的本地代碼。
10) 參數: --pct-{+事件類別} {+事件類別百分比}
用於指定每種類別事件的數目百分比(在Monkey事件序列中,該類事件數目占總事件數目的百分比)
參數:
使用說明:
示例:
--pct-touch {+百分比}
調整觸摸事件的百分比(觸摸事件是一個down-up事件,它發生在屏幕上的某單一位置)
adb shell monkey -p com.htc.Weather --pct-touch 10 1000
--pct-motion {+百分比}
調整動作事件的百分比(動作事件由屏幕上某處的一個down事件、一系列的偽隨機事件和一個up事件組成)adb shell monkey -p com.htc.Weather --pct-motion 20 1000
--pct-trackball {+百分比}
調整軌跡事件的百分比(軌跡事件由一個或幾個隨機的移動組成,有時還伴隨有點擊)
adb shell monkey -p com.htc.Weather --pct-trackball 30 1000
--pct-nav {+百分比}
調整“基本”導航事件的百分比(導航事件由來自方向輸入設備的up/down/left/right組成)
adb shell monkey -p com.htc.Weather --pct-nav 40 1000
--pct-majornav {+百分比}
調整“主要”導航事件的百分比(這些導航事件通常引發圖形界面中的動作,如:5-way鍵盤的中間按鍵、回退按鍵、菜單按鍵)
adb shell monkey -p com.htc.Weather --pct-majornav 50 1000
--pct-syskeys {+百分比}
調整“系統”按鍵事件的百分比(這些按鍵通常被保留,由系統使用,如Home、Back、Start Call、End Call及音量控制鍵)
adb shell monkey -p com.htc.Weather --pct-syskeys 60 1000
--pct-appswitch {+百分比}
調整啟動Activity的百分比。在隨機間隔里,Monkey將執行一個startActivity()調用,作為最大程度覆蓋包中全部Activity的一種方法
adb shell monkey -p com.htc.Weather --pct-appswitch 70 1000
--pct-anyevent {+百分比}
調整其它類型事件的百分比。它包羅了所有其它類型的事件,如:按鍵、其它不常用的設備按鈕、等等
adb shell monkey -p com.htc.Weather
--pct -anyevent 100 1000* 指定多個類型事件的百分比:
adb shell monkey -p com.htc.Weather --pct-anyevent 50 --pct-appswitch 50 1000
注意:各事件類型的百分比總數不能超過100%;
六 保存monkey log以及手機log到sdcard
最近很多同學在問如何保存log到sdcard,下面介紹下如何實現:
一、首先在cmd或終端中輸入adb shell
二、再執行monkey,比如
monkey -p com.storm.smart --throttle 500 --ignore-crashes --ignore-timeouts --ignore-security-exceptions --ignore-native-crashes --monitor-native-crashes -v -v -v 100 >/mnt/sdcard/monkey.txt & logcat -v time >/mnt/sdcard/logcat.txt
NOTE:如果不想生成logcat文件,刪除紅色標記(& logcat -v time >/mnt/sdcard/logcat.txt)中即可