Android Monkey 引數和日誌
阿新 • • 發佈:2019-02-12
1 首先配置monkey配置, 主要就是adb系統環境配置;如果安裝了appium基本可以滿足環境。(具體的環境安裝請百度)
2 除錯我們配置是否正常,開啟cmd 輸入 adb shell有響應,就ok。Monkey的基本語法:adb shell monkey [options]如果不指定options,Monkey將以無反饋模式啟動,並把事件任意傳送到安裝在目標環境中的全部包。adb shell monkey -p 【your.package.name】 -v 【number】-p:package的意思 + 指定報名 + -v number次數Monkey命令引數介紹:要獲取Monkey命令自帶的簡單幫助,在CMD中執行命令adb shell monkey –help 引數: -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引數: -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資訊引數: -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值,就可以保證兩次測試產生的隨機操作序列是完全相同的,所以這個操作序列是偽隨機的;引數: --throttle <毫秒>用於指定使用者操作(即事件)間的時延,單位是毫秒;* 示例:adb shell monkey -p com.htc.Weather –throttle 3000 100說明:這裡是間隔3秒,執行100次隨機事件引數: --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將會停止執行。引數: --ignore-timeouts用於指定當應用程式發生ANR(Application No Responding)錯誤時,Monkey是否停止執行。如果使用此引數,即使應用程式發生ANR錯誤,Monkey依然會發送事件,直到事件計數完成。引數: --ignore-security-exceptions用於指定當應用程式發生許可錯誤時(如證書許可,網路許可等),Monkey是否停止執行。如果使用此引數,即使應用程式發生許可錯誤,Monkey依然會發送事件,直到事件計數完成。引數: --kill-process-after-error用於指定當應用程式發生錯誤時,是否停止其執行。如果指定此引數,當應用程式發生錯誤時,應用程式停止執行並保持在當前狀態(注意:應用程式僅是靜止在發生錯誤時的狀態,系統並不會結束該應用程式的程序)。引數: --monitor-native-crashes用於指定是否監視並報告應用程式發生崩潰的原生代碼。引數: --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%;例項:adb -s emulator-5556 shell monkey -p 包名 --ignore-crashes --ignore-timeouts --ignore-native-crashes --pct-touch 30 -s 1 -v -v --throttle 200 100000 2 logcat >C:/error.txt 1 logcat>C:/info.txtLog分析Log 在android中的地位非常重要,要是作為一個android程式設計師不能過分析log這關,算是android沒有入門吧。下面我們就來說說如何處理log檔案 。(1)什麼時候會有Log檔案的產生 ?1.程式異常退出 , uncaused exception2.程式強制關閉 ,Force Closed (簡稱FC)3.程式無響應 , Application No Response (簡稱ANR) , 順便,一般主執行緒超過5秒麼有處理就會ANR4.手動生成 。拿到一個日誌檔案,要分成多段來看 。log檔案很長,其中包含十幾個小單元資訊,事實上他主要由三大塊兒組成 。1.系統基本資訊 ,包括 記憶體,CPU ,程序佇列 ,虛擬記憶體 , 垃圾回收等資訊。------ MEMORY INFO (/proc/meminfo) ------ ------ CPU INFO (top -n 1 -d 1 -m 30 -t) ------ ------ PROCRANK (procrank) ------ ------ VIRTUAL MEMORY STATS (/proc/vmstat) ------ ------ VMALLOC INFO (/proc/vmallocinfo) ------2.時間資訊,也是我們主要分析的資訊。------ VMALLOC INFO (/proc/vmallocinfo) ------ ------ EVENT INFO (/proc/vmallocinfo) ------3.虛擬機器資訊,包括程序的,執行緒的跟蹤資訊,這是用來跟蹤程序和執行緒具體點的好地方。------ VM TRACES JUST NOW (/data/anr/traces.txt.bugreport: 2011-01-15 16:49:02) ------ ------ VM TRACES AT LAST ANR (/data/anr/traces.txt: 2011-01-15 16:49:02) ------
2 除錯我們配置是否正常,開啟cmd 輸入 adb shell有響應,就ok。Monkey的基本語法:adb shell monkey [options]如果不指定options,Monkey將以無反饋模式啟動,並把事件任意傳送到安裝在目標環境中的全部包。adb shell monkey -p 【your.package.name】 -v 【number】-p:package的意思 + 指定報名 + -v number次數Monkey命令引數介紹:要獲取Monkey命令自帶的簡單幫助,在CMD中執行命令adb shell monkey –help