美文网首页软件测试
APP稳定性测试神器之Monkey-随机事件测试

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

作者: 测试allen说 | 来源:发表于2020-04-21 23:00 被阅读0次

    知乎首发地址:https://zhuanlan.zhihu.com/p/133858779

    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随机测试实战

    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

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

    【全文手打 如需转载 请标注此出处】

    相关文章

      网友评论

        本文标题:APP稳定性测试神器之Monkey-随机事件测试

        本文链接:https://www.haomeiwen.com/subject/hvqvihtx.html