最近在研究Android APP性能测试。所以发现一些有趣的东西,在这里进行分享。我们先讲第一个内容,如何获取APP冷/热启动时间?为什么要做这个测试,道理其实很简单,如果启动APP特别耗时的话,用户反馈百分之99不好。所以在这里我们可以获取APP冷/热启动时间,同竞品进行比较。

环境准备(可参考我写的monkey测试)

  • adb
  • 手机/模拟器
  • cmder
  • python2

获取APK包名及主活动名

  1. adb logcat | grep START //监控指令

具体步骤:

1、cmder下输入  adb logcat | grep START

2、点击想监控的APP,比如这里我点击的是手机自带浏览器,然后会生成一些log,我们找到cmp,如下 com.android.browser 是我们要找的包名,.BrowserActivity 是我们找的主活动名

Windows下获取APP 冷/热启动时间

冷启动

  1. adb shell am start -W -n com.android.browser/.BrowserActivity

冷启动停止APP

  1. adb shell am force-stop com.android.browser

热启动

  1. adb shell am start -W -n com.android.browser/.BrowserActivity

热启动停止APP

  1. adb shell input keyevent 3

python脚本实现APP 冷/热启动时间

思路:

1. 创建一个APP类,进行APP相关操作,其中包含,冷/热启动APP,冷/热关闭APP,获取冷/热启动时间

2. 创建一个Controller类,主要实现多次启动/关闭APP,获取时间戳,数据的存储

  1. # /usr/bin/python
  2. # encoding:utf-8
  3. import csv
  4. import os
  5. import time
  6.  
  7. class App(object):
  8. def __init__(self):
  9. self.content = ""
  10. self.startTime = 0
  11.  
  12. # 启动App
  13. def LaunchApp(self):
  14. cmd = 'adb shell am start -W -n com.begoit.studyplan/.ui.act.SplashActivity'
  15. self.content = os.popen(cmd)
  16.  
  17. # 停止App
  18. def StopApp(self):
  19. # cmd = 'adb shell am force-stop com.android.browser'
  20. cmd = 'adb shell input keyevent 3'
  21. os.popen(cmd)
  22.  
  23. # 获取启动时间
  24. def GetLaunchedTime(self):
  25. for line in self.content.readlines():
  26. if "ThisTime" in line:
  27. self.startTime = line.split(":")[1]
  28. break
  29. return self.startTime
  30.  
  31. # 控制类
  32. class Controller(object):
  33. def __init__(self, count):
  34. self.app = App()
  35. self.counter = count
  36. self.alldata = [("timestamp", "elapsedtime")]
  37.  
  38. # 单次测试过程
  39. def testprocess(self):
  40. self.app.LaunchApp()
  41. time.sleep(5)
  42. elpasedtime = self.app.GetLaunchedTime()
  43. self.app.StopApp()
  44. time.sleep(3)
  45. currenttime = self.getCurrentTime()
  46. self.alldata.append((currenttime, elpasedtime))
  47.  
  48. # 多次执行测试过程
  49. def run(self):
  50. while self.counter > 0:
  51. self.testprocess()
  52. self.counter = self.counter - 1
  53.  
  54. # 获取当前的时间戳
  55. def getCurrentTime(self):
  56. currentTime = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
  57. return currentTime
  58.  
  59. # 数据的存储
  60. def SaveDataToCSV(self):
  61. csvfile = file('startTime2.csv', 'wb')
  62. writer = csv.writer(csvfile)
  63. writer.writerows(self.alldata)
  64. csvfile.close()
  65.  
  66. if __name__ == "__main__":
  67. controller = Controller(5)
  68. controller.run()
  69. controller.SaveDataToCSV()

运行结果展示:

总结:

我们通过两种方式实现记录APP冷/热启动时间,进行比较,编写脚本方式相对简单些。也更容易对测试结果进行分析。所以在这里推荐大家学习python基础知识。关于adb shell am 的命令推荐阅读:https://blog.csdn.net/soslinken/article/details/50245865

1、获取APP 冷/热启动时间的更多相关文章

  1. 2、获取APP CPU占用率

    前面已经介绍过如何获取包名和主活动名.这里不再过多赘述.我们依旧采取两种方案实现APP CPU占有率 Windows下获取APP CPU占用率 adb shell "dumpsys cpui ...

  2. Android 查看App冷启动时间/热启动时间/页面打开时间

    Android 查看App冷启动时间/热启动时间/页面打开时间 冷启动时间 热启动时间 页面打开时间 通过adb查看 adb shell am start -W packageName/Activit ...

  3. 获取app启动时间

    启动APP并收集消耗时间的命令: adb shell am  start -W -n package/activity 手动关闭谷歌浏览器APP(也可以使用命令关闭adb shell am force ...

  4. 3、获取APP 内存占用率

    关于APP内存占用,不用多说,应该是APP性能测试中比较重要的一点.试想一下,开个应用把手机内存占满了,其它应用无法打开,那么这个应用还会有人安装吗?我觉得是没有的.下面就通过adb命令获取APP虚存 ...

  5. iOS获取app图标和启动图片名字(AppIcon and LaunchImage's name)

    在某种场景下,可能我们需要获取app的图标名称和启动图片的名称.比如说app在前台时,收到了远程通知但是通知栏是不会有通知提醒的,这时我想做个模拟通知提示,需要用到icon名称:再比如在加载某个控制器 ...

  6. NSDate获取当前时区的时间

    [NSDate date]获取的是GMT时间,要想获得某个时区的时间,以下代码可以解决这个问题 NSDate *date = [NSDate date]; NSTimeZone *zone = [NS ...

  7. python 获取文件大小,创建时间和访问时间

    # -*- coding: UTF8 -*- import timeimport datetime import os 1. '''把时间戳转化为时间: 1479264792 to 2016-11-1 ...

  8. 获取APP应用的包名信息

    语言: python 3.7 需求:获取APP的包名和程序入口信息,以便在 Appium 脚本中配置 appPackage 和 appActivity 参数. 场景一 资源:已有APP应用的apk安装 ...

  9. Appium+Python自动化 3 -获取 app 包名和 activity

    方法一: ①手机通过USB连接电脑 ②打开手机上被测app ③在电脑上 dos命令窗口,输入命令 adb shell dumpsys window w | findstr \/ | findstr n ...

随机推荐

  1. Hive 数据类型转换(转)

    原文连接:https://www.iteblog.com/archives/892.html 在<Hive内置数据类型>文章中,我们提到了Hive内置数据类型由基本数据类型和复杂数据类型组 ...

  2. Windows-右键菜单添加选项

    新建 add.reg 输入选项名和选项对应程序路径 Windows Registry Editor Version 5.00 [HKEY_CLASSES_ROOT\*\shell\选项名] [HKEY ...

  3. Angularjs实现简单的登陆框

    ​ <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&q ...

  4. 数据库的基本使用(C#语言)

    目录 insert select 的使用 delete update 更新 Like模糊查询 Order 排序 GETDATA() 聚合函数:MAX,MIN,AVG,SUM,COUNT Max COU ...

  5. UVA 822 Queue and A

    题目链接:https://vjudge.net/problem/UVA-822 翻译摘自:<算法禁赛入门经典> 题目大意 你的任务是模拟一个客户中心运作情况.客服请求一共有n(1 ≤ n ...

  6. Rust <7>:数据结构==>链表

    enum List { Cons(u64, Box<List>), NULL, } impl List { fn new() -> List { List::NULL } fn pr ...

  7. C语言博客作业02

    2.1 一.请仔细阅读<提问的智慧>,用自己的话描述你的收获,并举例子说明应该如何提问. 答:1.提问是思考的另一种方式,一个好的提问能体现出我们在认真的,聪明的思考; 2.做什么事情都要 ...

  8. nginx中root与alias关键字的区别

    前言 近段时间秋招上岸了,于是每天疯狂补各种分布式基础,每天都在痛苦与快乐中度过. 在学习 nginx 的时候,遇到配置上的问题:root 与 alias 的区别,卡了大概三个小时,记录下来警醒自己不 ...

  9. UVA 10806 Cheerleaders

    Cheerleaders Description   C Cheerleaders In most professional sporting events, cheerleaders play a ...

  10. ACM之map常用用法

    map 在STL的头文件中<map>中定义了模版类map和multimap,用有序二叉树表存储类型为pair<const Key, T>的元素对序列.序列中的元素以const ...