安卓APP启动时间测试

本文介绍了安卓APP的冷启动和热启动概念,详细阐述了冷启动测试启动过程及命令,包括测试返回数据的各个指标。同时,讨论了热启动测试启动时间,指出热启动与冷启动的主要区别在于退出APP的方式。通过脚本自动化启动和退出操作,可以有效地获取并分析APP的启动时间数据。

启动APP分为两种冷启动和热启动
冷启动指的是进程首次创建 第一次启动 加载资源的过程
热启动指的是 APP启动后 按HOME退到后台 再次打开APP的时候

冷启动测试启动

启动APP命令

adb shell am start -W -n package/activity

测试返回数据

ThisTime:本次启动时间(毫秒)
TotalTime:启动总时间
WaitTime:等待时间
在这里插入图片描述
冷启动需要关闭APP
停止APP命令

adb shell am force-stop package

热启动测试启动时间

热启动开启APP的命令和冷启动一样 不同的是退出时不同
热启动时退出APP的命令

adb shell input keyevent 3

那么只需要把启动和退出APP的命令操作 变成脚本化 就可获取 启动时间了


#/usr/bin/python
#encoding:utf-8
import csv
import os
import time

#app类
class App(object):
    def __init__(self):
        self.content = ""
        self.startTime = 0

    #启动App
    def LaunchApp(self):
        cmd = 'adb shell am start -W -n package/Activity
        self.content=os.popen(cmd)

    #停止App
    def StopApp(self):
        #cmd = 'adb shell am force-stop package'
        cmd = 'adb shell input keyevent 3'
        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", "elapsedtime")]

    #单次测试过程
    def testprocess(self):
        self.app.LaunchApp()
        print("1")
        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 = open('startTime2.csv', mode='w')
        writer = csv.writer(csvfile)
        writer.writerows(self.alldata)
        csvfile.close()

if __name__ == "__main__":
    controller = Controller(10)
    controller.run()
    controller.SaveDataToCSV()


执行完毕后 测试数据就写入到了Excel文件里了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值