monkey調研

一、monkey介紹

Monkey是Android中的一個命令行工具,可以運行在模擬器里或實際設備中。它向系統發送偽隨機的用戶事件流(如按鍵輸入、觸摸屏輸入、手勢輸入等),實現對正在開發的應用程序進行壓力測試。Monkey測試是一種為了測試軟件的穩定性、健壯性的快速有效的方法。

該工具用于進行壓力測試。然后開發人員結合monkey 打印的日志和系統打印的日志,分析測試中的問題

二、Monkey 測試的特點:

Monkey 測試,所有的事件都是隨機產生的,不帶任何人的主觀性。

1、測試的對象僅為應用程序包,有一定的局限性。

2、Monky測試使用的事件數據流是隨機的,不能進行自定義。

3、可對MonkeyTest的對象,事件數量,類型,頻率等進行設置。

三、實例

以com.android.calculator2作為對象進行MonkeyTest

#monkey -p com.android.calculator2 -v 500

其中-p表示對象包 –v 表示反饋信息級別

運行過程中,Emulator中的應用程序在不斷地切換畫面。

按照選定的不同級別的反饋信息,在Monkey中還可以看到其執行過程報告和生成的事件。?

四、使用monkey help 命令查看命令參數

C:\Users\chenfenping>adb shell monkey -help

usage: monkey [-p ALLOWED_PACKAGE [-p ALLOWED_PACKAGE] ...]

[-c MAIN_CATEGORY [-c MAIN_CATEGORY] ...]

[--ignore-crashes] [--ignore-timeouts]

[--ignore-security-exceptions]

[--monitor-native-crashes] [--ignore-native-crashes]

[--kill-process-after-error] [--hprof]

[--pct-touch PERCENT] [--pct-motion PERCENT]

[--pct-trackball PERCENT] [--pct-syskeys PERCENT]

[--pct-nav PERCENT] [--pct-majornav PERCENT]

[--pct-appswitch PERCENT] [--pct-flip PERCENT]

[--pct-anyevent PERCENT] [--pct-pinchzoom PERCENT]

[--pkg-blacklist-file PACKAGE_BLACKLIST_FILE]

[--pkg-whitelist-file PACKAGE_WHITELIST_FILE]

[--wait-dbg] [--dbg-no-events]

[--setup scriptfile] [-f scriptfile [-f scriptfile] ...]

[--port port]

[-s SEED] [-v [-v] ...]

[--throttle MILLISEC] [--randomize-throttle]

[--profile-wait MILLISEC]

[--device-sleep-time MILLISEC]

[--randomize-script]

[--script-log]

[--bugreport]

[--periodic-bugreport]

COUNT

1 參數: -p

用于約束限制,用此參數指定一個或多個包(Package,即App)。指定包之后,monkey將只允許系統啟動指定的APP,如果不指定包,將允許系統啟動設備中的所有APP.

* 指定一個包: adb shell monkey -p cn.emoney.acg 10

* 指定多個包:adb shell monkey -p cn.emoney.acg –p cn.emoney.wea -p cn.emoney.acg 100

* 不指定包:adb shell monkey 100


2 參數: -v

用于指定反饋信息級別(信息級別就是日志的詳細程度),總共分3個級別,分別對應的參數如下表所示:

日志級別 Level0

示例 adb shell monkey -p cn.emoney.acg –v 100

說明缺省值,僅提供啟動提示、測試完成和最終結果等少量信息


日志級別 Level 1

示例 adb shell monkey -p cn.emoney.acg –v -v 100

說明提供較為詳細的日志,包括每個發送到Activity的事件信息


日志級別 Level 2

示例 adb shell monkey -p cn.emoney.acg –v -v –v 100

說明最詳細的日志,包括了測試中選中/未選中的Activity信息

3 參數: -s

用于指定偽隨機數生成器的seed值,如果seed相同,則兩次Monkey測試所產生的事件序列也相同的。

Monkey 測試1:adb shell monkey -p cn.emoney.acg -s 10? 100

Monkey 測試2:adb shell monkey -p cn.emoney.acg –s 10 100

兩次測試的效果是相同的,因為模擬的用戶操作序列(每次操作按照一定的先后順序所組成的一系列操作,即一個序列)是一樣的。

4 參數: --throttle<毫秒>

用于指定用戶操作(即事件)間的時延,單位是毫秒;

adb shell monkey -p cn.emoney.acg --throttle 5000 100

5 參數: --ignore-crashes

用于指定當應用程序崩潰時(Force& Close錯誤),Monkey是否停止運行。如果使用此參數,即使應用程序崩潰,Monkey依然會發送事件,直到事件計數完成。

adb shellmonkey -p cn.emoney.acg --ignore-crashes 1000

測試過程中即使程序崩潰,Monkey依然會繼續發送事件直到事件數目達到1000為止

adb shellmonkey -p cn.emoney.acg 1000

測試過程中,如果acg程序崩潰,Monkey將會停止運行


6 參數: --ignore-timeouts

用于指定當應用程序發生ANR(Application No Responding)錯誤時,Monkey是否停止運行。如果使用此參數,即使應用程序發生ANR錯誤,Monkey依然會發送事件,直到事件計數完成。

adb shellmonkey -p cn.emoney.acg --ignore-timeouts 1000


7 參數: --ignore-security-exceptions

用于指定當應用程序發生許可錯誤時(如證書許可,網絡許可等),Monkey是否停止運行。如果使用此參數,即使應用程序發生許可錯誤,Monkey依然會發送事件,直到事件計數完成。

adb shellmonkey -p cn.emoney.acg --ignore-security-exception 1000


8 參數: --kill-process-after-error

用于指定當應用程序發生錯誤時,是否停止其運行。如果指定此參數,當應用程序發生錯誤時,應用程序停止運行并保持在當前狀態

(注意:應用程序僅是靜止在發生錯誤時的狀態,系統并不會結束該應用程序的進程)。

adb shellmonkey -p cn.emoney.acg --kill-process-after-error 1000


9 參數: --monitor-native-crashes

用于指定是否監視并報告應用程序發生崩潰的本地代碼。

adb shellmonkey -p cn.emoney.acg --monitor-native-crashes 1000


10 參數: --pct-{+事件類別}{+事件類別百分比}

用于指定每種類別事件的數目百分比(在Monkey事件序列中,該類事件數目占總事件數目的百分比)

示例:

--pct-touch{+百分比}

調整觸摸事件的百分比(觸摸事件是一個down-up事件,它發生在屏幕上的某單一位置)

adb shell monkey -p cn.emoney.acg --pct-touch 10 1000

--pct-motion?{+百分比}

調整動作事件的百分比(動作事件由屏幕上某處的一個down事件、一系列的偽隨件機事和一個up事件組成)

adb shell monkey -p cn.emoney.acg --pct-motion 20 1000

--pct-trackball?{+百分比}

調整軌跡事件的百分比(軌跡事件由一個或幾個隨機的移動組成,有時還伴隨有點擊)

adb shell monkey -p cn.emoney.acg --pct-trackball 30 1000

--pct-nav?{+百分比}

調整“基本”導航事件的百分比(導航事件由來自方向輸入設備的up/down/left/right組成)

adb shell monkey -p cn.emoney.acg --pct-nav 40 1000

--pct-majornav?{+百分比}

調整“主要”導航事件的百分比(這些導航事件通常引發圖形界面中的動作,如:5-way鍵盤的中間按鍵、回退按鍵、菜單按鍵)

adb shell monkey -p cn.emoney.acg --pct-majornav 50 1000

七、輸出monkeylog

跑monkey的時候或者想抓程序log導出時,有時會提示:cannot create D:monkeytest.txt: read-only file system

為什么有時候可以有時候不可以?

后來發現跟使用使用習慣不一樣,一會是先進入adb shell 再用命令,一會是直接命令進入。

進入adb shell后再用命令就會失敗~

正確方法:退出shell或者執行命令時先不要進shell

C:\Documents and Settings\Administrator>adb shell monkey -p 包名

?-v 300 ?>e:\text.txt


進入adb shell后就相當于進入linux的root下面,沒有權限在里面創建文件~

五、Monkey測試結果分析

一. 初步分析方法:

Monkey測試出現錯誤后,一般的查錯步驟為以下幾步:

1、找到是monkey里面的哪個地方出錯

2、查看Monkey里面出錯前的一些事件動作,并手動執行該動作

3、若以上步驟還不能找出,可以使用之前執行的monkey命令再執行一遍,注意seed值要一樣--復現

一般的測試結果分析:

1、 ANR問題:在日志中搜索“ANR”

2、崩潰問題:在日志中搜索“Exception”? Force Close

二. 詳細分析monkey日志:

將執行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 exception

11-01?08:53:27.133: ERROR/AndroidRuntime(1973): java.lang.NullPointerException

11-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)

四、總結:

在monkey測試中常用的命令組合有:

1、monkey -p com.yourpackage -v?500//簡單的輸出測試的信息。

2、monkey -p com.yourpackage -v -v ?500?//以深度為二級輸出測試信息。

4、monkey -p com.yourpackage -s 數字 -v?500//為隨機數的事件序列定一個值,若出現問題下次可以重復同樣的系列進行排錯。

5、monkey -p com.yourpackage -v --throttle?3000?500//為每一次執行一次有效的事件后休眠3000毫秒。


五、附錄:

以下內容為android系統中的keycode值,在以后的調試中會經常需要查詢:

字母和數字鍵的鍵碼值(keyCode)





備注:以上內容轉載自網上,原文地址:https://www.cnblogs.com/aland-1415/p/6949964.html

?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,316評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,481評論 3 415
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,241評論 0 374
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,939評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,697評論 6 409
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,182評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,247評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,406評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,933評論 1 334
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,772評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,973評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,516評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,209評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,638評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,866評論 1 285
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,644評論 3 391
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,953評論 2 373

推薦閱讀更多精彩內容