1. 程式人生 > 其它 >Android-monkey測試

Android-monkey測試

1.什麼是monkey

~ monkey程式由android系統自帶,使用Java語言寫成,在Android檔案系統中的存放路徑是:/system/framework/monkey.jar

~Monkey.jar程式是由一個名為“monkey”的Shell指令碼來啟動執行,shell指令碼在Android檔案系統中的存放路徑是:/system/bin/monkey

~Monkey測試是Android平臺自動化測試的一種手段,通過Monkey程式模擬使用者觸控式螢幕幕、滑動Trackball、按鍵等操作來對裝置上的程式進行測試,檢測程式多久的時間會發生異常

2.monkey命令

adb shell monkey -p cn.migu.mgpvrlauncher --throttle 500 -s 12 --hprof --ignore-crashes --ignore-timeouts --ignore-security-exceptions --ignore-native-crashes --monitor-native-crashes -v -v -v 10000>log檔案存放位置

引數:-p 指定啟動包名

--throttle 時間間隔

-v:log每一個 -v 將增加反饋資訊的級別

3.monkey報告

裝置;pcio,oppo

啟動包名:cn.migu.mgpvrlauncher,cn.migu.cloudvrapk 事件count:10000 各事件執行佔比:

//0: 15.0%
// 1: 10.0%
// 2: 2.0%
// 3: 15.0%
// 4: -0.0%
// 5: -0.0%
// 6: 25.0%
// 7: 15.0%
// 8: 2.0%
// 9: 2.0%
// 10: 1.0%
// 11: 13.0%

--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組成)

--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 {+百分比}

調整其它型別事件的百分比。它包羅了所有其它型別的事件,如:按鍵、其它不常用的裝置按鈕、等等

--pct -anyevent{+百分比}

指定多個事件的百分比

adb shell monkey -p com.htc.Weather--pct-anyevent 50 --pct-appswitch 50 1000

耗時:pico:1169574ms(約19.4分鐘) oppo:1195275ms(約19.9分鐘)

4.測試結果

無ANR(Application Not Responding),Crash,Exception,GC(記憶體洩漏)問題

(由於本次測試持續時間短,事件數少,未發現任何異常,建議monkey執行時間和事件加長)

日誌分析

1.在日誌中搜索關鍵字:

1)搜尋報告中的關鍵字“ANR”,看有無應用無響應的事件(Application Not Responding)

2)搜尋報告中的關鍵字“crash”,看有無崩潰的事件

3)搜尋報告中的關鍵字“exception”,看有無其他異常事件。(如果出現空指標, NullPointerException,需格外重視)

下面的屬於monkey自己的問題,忽略

:Sending Flip keyboardOpen=false

Got IOException performingflipjava.io.IOException: write failed: EINVAL (Invalid argument)

// Injection Failed

4)記憶體洩露問題搜尋"GC"(需進一步分析)

2. 初步分析法: monkey出現錯誤後,一般的分析步驟

1)先找到出現錯誤的位置

2)查看出現錯誤之前2個switch之間的activity

3)手動執行事件,復現問題

4)若以上步驟還不能找出,產生錯誤時,有會seed值,輸入相同的seed值,重新按照之前命令跑monkey