关于测试:0320-专项测试APP-启动性能分析

4次阅读

共计 858 个字符,预计需要花费 3 分钟才能阅读完成。

Activity 启动流程

  • Application OnCreate

    • 加载第三方的 sdk
  • Activity OnCreate

    • 加载本身的逻辑
    • 发送近程数据申请
    • 渲染界面

APP 启动性能指标

  1. 冷启动:最重要的启动指标,着重优化,倡议工夫 5 秒
  2. 暖启动:倡议工夫 2 秒
  3. 热启动:倡议工夫 1.5 秒
  4. 首屏启动

测试的次要流程

  1. adb logcat:不够精确
  2. 录屏 + 视频拆帧:较精确,须要人工操作
  3. uiautomator 等自动化工具,进行 200ms 巡检界面变动
  4. traceview
  5. 硬埋点:最精确,而且覆盖度更广

adb logcat

  • 清理缓存数据:adb shell pm clear package 
  • 进行过程:adb shell am force-stop package 
  • 启动 APP:adb shell am start -S -W package/activity 
  • 获取数据:adb logcat | grep -i displayed 

通过 adb logcat 获取后果:

  • startTime:记录刚筹备调用 startActivityAndWait() 的工夫点
  • endTime:记录 startActivityAndWait() 函数调用返回的工夫点
  • waitTime:startActivityAndWait() 调用耗时;waitTime = endTime – startTime

应用 ffmpeg 拆帧

  1. 革除利用缓存:adb shell am force-stop package 
  2. 进行 30s 录屏,并存放到手机的指定地址:adb shell screenrecord --bugreport --time-limit 30 录屏文件门路 & 
  3. 启动 APP,跳转到指定界面:adb shell am start -S -W package/activity 
  4. 把录屏文件从手机拉取到电脑:adb pull 录屏文件门路 寄存门路  
  5. 将视频转换为 gif 格:ffmpeg -i 录屏文件 拆分格局  
  6. 将视频拆帧,每秒拆成 10 份,存储为 jpg 格局图片:ffmpeg -i 录屏文件 -r 10 frames_%03d.jpg 
  7. 再通过逐帧剖析图片,找到点击的工夫以及关上指定界面的工夫,从而推算启动工夫
正文完
 0