APP稳定性测试神器之Monkey-随机事件测试

APP稳定性测试神器之Monkey-随机事件测试

Monkey是Android中的一个命令行工具,可以运行在模拟器里或者现实设备中,向系统发送伪随机的用户事件流(点击、滑动、Application切换、横竖屏、应用关闭)实现对正在开发的应用程序进行压力测试。monkey测试是一种为了测试软件的稳定性,健壮性的快速有效的方法,只针对Activity做测试,不能对Service做测试。

一、Monkey 命令基本参数介绍

0、–help : 列出简单的用法

adb shell monkey -help

1、允许启动手机里面所有的 App , 随机操作 1000 次

adb shell monkey 1000

2、-p : 允许启动 App 的包名

启动一个包名的应用,QQ 的包名为: com.tencent.mobileqq

案例:随机操作 手机 QQ 1000 次

#获取App的包名,先启动qq并获取焦点

adb shell dumpsys window | findstr mCurrentFocus

#启动App

adb shell monkey -p com.tencent.mobileqq 1000

启动指定的多个 App,微信的包名为:com.tencent.mm

案例:随机操作 手机 QQ 和 微信 1000 次

adb shell monkey -p com.tencent.mobileqq -p com.tencent.mm 1000

3、-v : 操作日志记录

命令行的每一个-v将增加反馈信息的级别。

-v:Level 0(缺省值)除 启动提示、测试完成和最终结果之外,提供较少信息。

-v -v :Level 1提供较为详细的测试信息,如逐个发送到Activity的 事件。

-v -v -v :Level 2提供更加详细的设置信息,如测试中被选中的或未被选中的Activity。

adb shell monkey -p com.tencent.mobileqq -v -v -v 100

4、-s : 伪随机数生成器的seed值

如果用相同的seed值再次运行monkey,将生成相同的事件序列。

adb shell monkey -s 12345 -v 10

5、--throttle : 插入固定延迟

在事件之间插入固定延迟。通过这个选项可以减缓Monkey的执行速度。如果不指定该选项,Monkey将不会被延迟,事件将尽可能快地被执行。

案例:随机执行 500 个事件,每个事件之间延迟 500 毫秒被执行。

adb shell monkey –-throttle 500 -v 500

6、--ignore-crashes : 忽略操作是崩溃异常

通常,应用发生崩溃或异常时Monkey会停止运行。如果设置此项,Monkey将继续发送事件给系统,直到事件计数完成。

adb shell monkey –-ignore-crashes -v 1000

7、--ignore-timeouts : 忽略超时

通常,应用程序发生任何超时错误(如“Application Not responding”对话框)Monkey将停止运行,设置此项,Monkey将继续发送事件给系统,直到事件计数完成。

adb shell monkey –-ignore-timeouts -v 1000

8、--ignore-security-exceptions : 忽略程序发生许可异常

通常,当程序发生许可错误(例如启动一些需要许可的Activity)导致的异常时,Monkey将停止运行。设置此项,Monkey将继续发送事件给系统,直到事件计数完成。

adb shell monkey –-ignore-security-exceptions -v 1000

9、调整触摸事件百分比

触摸事件不单单是按键,它泛指发生在某一位置的一个down-up事件。

#调整触摸事件百分比为100%

adb shell monkey -v -v --pct-touch 100 200

10、调整手势事件百分比

#调整手势占比为100%

adb shell monkey -v -v --pct-motion 100 200

11、调整应用启动事件的百分比

如果你希望调整应用启动事件的百分比。

--pct-appswitch:后面接应用启动事件百分比。

adb shell monkey --pct-appswtich <percent>

12、调整屏幕旋转事件百分比

--pct-rotation 后面接屏幕旋转事件的比例值。

adb shell monkey --pct-rotation <percent>

二、Monkey随机测试实战(免费领取Python自动化学习资料  工具,面试宝典面试技巧,加QQ群,785128166,群内还会大佬技术交流)

1、测试案例

对QQ进行随机测试,测试希望通过Monkey来模拟用户的随机操作,检查被测应用是否会出现异常(应用崩溃或者无响应)。

2、需求分析

这个测试的目的是希望模拟用户操作,因此需要让Monkey执行的事件尽可能地接近用户的常规操作,这样才可以最大限度地发现用户使用过程中可能出现的问题。

测试是指定应用,因此需要使用-p指定被测app包名:com.tencent.mobileqq

触摸事件和手势事件是用户最常见的操作,所以通过--pct-touch和--pct-motion将这两个事件的占比调整到40%与25%;

目标应用包含了多个Activity,为了能覆盖大部分的Activity,所以通过--pct-appswitch将Activity切换的事件占比调整到10%;

被测应用在测试中出现过不少横竖屏之间切换的问题,这个场景也必须关注,因此通过--pct-rotation把横竖屏切换事件调整到10%。

使用-s参数来指定命令执行的seed值 Monkey会根据seed值来生成对应事件流,同一个seed生成的事件流是完全相同的。这里指定了seed值,是为了测试发现问题时,便于进行问题复现。

使用--throttle参数来控制Monkey每个操作之间的时间间隔 指定操作之间的时间间隔,一方面是希望能更接近用户的操作场景,正常用户操作都会有一定的时间间隔;另一方面也是不希望因为过于频繁的操作而导致系统崩溃,尤其是在比较低端的手机上执行测试时。因此通过--throttle设置Monkey每个操作固定延迟0.4秒。

使用--ignore-crashs和--ignore-timeouts参数使Monkey遇到意外时能继续执行 在执行Monkey测试时,会因为应用的崩溃或没有响应而意外终止,所以需要在命令中增加限制参数--ignore-crash和--ignore-timeouts,让Monkey在遇到崩溃或没有响应的时候,能在日志中记录相关信息,并继续执行后续的测试。

使用-v指定log的详细级别 Monkey的日志输出有3个级别:日志的级别越高,其详细程度也越高。为了方便问题的定位,这里将日志设为 -v -v.

3、monkey指令

#完整的monkey指令,直接在cmd下运行即可

adb shell monkey -p com.tencent.mobileqq --pct-touch 40 --pct-motion 25 --pct-appswitch 10 --pct-rotation 5 -s 1666 --throttle 400 --ignore-crashes --ignore-timeouts -v -v  20

4、执行结果

C:\Users\chang>adb shell monkey -p com.tencent.mobileqq --pct-touch 40 --pct-motion 25 --pct-appswitch 10 --pct-rotation 5 -s 1666 --throttle 400 --ignore-crashes --ignore-timeouts -v -v  20

:Monkey: seed=1666 count=20

:AllowPackage: com.tencent.mobileqq

:IncludeCategory: android.intent.category.LAUNCHER

:IncludeCategory: android.intent.category.MONKEY

// Selecting main activities from category android.intent.category.LAUNCHER

//  + Using main activity com.tencent.mobileqq.activity.SplashActivity (from package com.tencent.mobileqq)

// Selecting main activities from category android.intent.category.MONKEY

// Seeded: 1666

// Event percentages:

//  0: 40.0%

//  1: 25.0%

//  2: 0.5479452%

//  3: 4.109589%

//  4: 5.0%

//  5: 6.849315%

//  6: 4.109589%

//  7: 0.5479452%

//  8: 10.0%

//  9: 0.2739726%

//  10: 3.5616438%

:Switch: #Intent;action=android.intent.action.MAIN;category=android.intent.category.LAUNCHER;launchFlags=0x10200000;component=com.tencent.mobileqq/.activity.SplashActivity;end

    // Allowing start of Intent { act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] cmp=com.tencent.mobileqq/.activity.SplashActivity } in package com.tencent.mobileqq

Sleeping for 400 milliseconds

    // Allowing start of Intent { cmp=com.tencent.mobileqq/.activity.LoginActivity } in package com.tencent.mobileqq

    // activityResuming(com.tencent.mobileqq)

    // activityResuming(com.tencent.mobileqq)

:Sending Touch (ACTION_DOWN): 0:(19.0,822.0)

:Sending Touch (ACTION_UP): 0:(18.467697,833.23395)

Sleeping for 400 milliseconds

:Sending Touch (ACTION_DOWN): 0:(292.0,564.0)

:Sending Touch (ACTION_UP): 0:(292.24872,574.4084)

Sleeping for 400 milliseconds

:Sending Touch (ACTION_DOWN): 0:(223.0,264.0)

:Sending Touch (ACTION_UP): 0:(220.5615,265.7382)

Sleeping for 400 milliseconds

:Sending Touch (ACTION_DOWN): 0:(241.0,660.0)

:Sending Touch (ACTION_MOVE): 0:(221.0623,659.5999)

:Sending Touch (ACTION_MOVE): 0:(214.96077,659.1779)

:Sending Touch (ACTION_MOVE): 0:(192.31989,658.8912)

:Sending Touch (ACTION_MOVE): 0:(191.0637,658.5243)

:Sending Touch (ACTION_MOVE): 0:(177.8515,657.96515)

:Sending Touch (ACTION_UP): 0:(160.01547,656.31335)

Sleeping for 400 milliseconds

:Sending Touch (ACTION_DOWN): 0:(104.0,225.0)

:Sending Touch (ACTION_UP): 0:(104.47486,227.16228)

Sleeping for 400 milliseconds

:Sending Touch (ACTION_DOWN): 0:(131.0,833.0)

:Sending Touch (ACTION_UP): 0:(124.2063,833.3685)

Sleeping for 400 milliseconds

    // Allowing start of Intent { cmp=com.tencent.mobileqq/.activity.RegisterPhoneNumActivity } in package com.tencent.mobileqq

:Sending Touch (ACTION_DOWN): 0:(367.0,597.0)

:Sending Touch (ACTION_UP): 0:(366.77362,594.3969)

Events injected: 20

:Sending rotation degree=0, persist=false

:Dropped: keys=0 pointers=0 trackballs=0 flips=0 rotations=0

## Network stats: elapsed time=2832ms (0ms mobile, 0ms wifi, 2832ms not connected)

// Monkey finished

欢迎关注作者,如果觉得写的还不错,就给点个赞、收藏(后续持续更新)。

猜你喜欢

转载自blog.csdn.net/PythonCS001/article/details/108321789