壓測app:啟動時間,cpu,流量,電量,內存,fps,過度渲染
環境的配置
1. Android SDK 2. Python 3.pyCharm
1. Android SDK
下載網址:http://www.androiddevtools.cn/index.html
環境變量: ANDROID_HOME:D:\Appium\Android Sdk\android-sdk
PATH:D:\Appium\Android Sdk\android-sdk\platform-tools
D:\Appium\Android Sdk\android-sdk\tools
添加完環境變量后,鏈接真機,輸入 adb devices 有輸出,判斷android sdk 添加成功
2.python
下載地址:https://www.python.org/downloads/
3.pyCharm 直接下載安裝
獲取app的包名和activity名 : adb shell "logcat | grep START" 然后啟動app 找到 cmp="com.zgjky.app/.activity.welcomepage.Welcome_Activity”
啟動時間:
冷啟動:程序(進程)首次啟動 熱啟動:程序(進程)推到后台
# encoding:utf-8遇到問題:當執行程序后,app啟動一次,然后就沒有然后了
import csv
import os
import time
#APP類
class App(object):
def __init__(self):
self.content = ""
self.startTime = 0
def LaunchApp(self):
#啟動APP
cmd = "adb shell am start -W -n com.zgjky.app/.activity.welcomepage.Welcome_Activity "
self.content= os.popen(cmd)
def StopApp(self):
#停止APP
cmd = "adb shell am force-stop com.zgjky.app"
os.popen(cmd)
#獲取啟動時間
def GetLaunchedTime(self):
for line in self.content.readlines():
if "ThisTime" in line:
self.startTime = line.split(":")[1]
break
return self.startTime
#控制類
class Controller(object):
def __init__(self,count):
self.app = App()
self.counter = count
self.alldata = [("timestamp","elpasedtime")]
#單次測試過程
def testprocess(self):
self.app.LaunchApp()
time.sleep(5)
elpasedtime = self.app.GetLaunchedTime()
self.app.StopApp()
time.sleep(3)
currenttime = self.getCurrentTime()
self.alldata.append((currenttime,elpasedtime))
#多次測試過程
def run(self):
while self.counter > 0:
self.testprocess()
self.counter = self.counter - 1
#獲取當前時間戳
def getCurrentTime(self):
currentTime = time.strftime("%Y-%m-%d %H:%M:%S",time.localtime())
return currentTime
#數據的存貯
def SaveDataToCSV(self):
csvfile = file("startTime.csv","wb")
writer = csv.writer(csvfile)
writer.writerows(self.alldata)
csvfile.close()
if __name__ == "__main__":
controller = Controller(11)
controller.run()
controller.SaveDataToCSV()
分析:csv文件,在python3.6中運行錯誤導致