zoukankan      html  css  js  c++  java
  • APP性能测试(启动时间)

    #encoding:utf-8
    import csv
    import os
    import time
    
    
    class App(object):
        def __init__(self):
            self.content = ""
            self.startTime = 0
    
        #启动App
        def LaunchApp(self):
            cmd = 'adb shell am start -W -n com.android.browser/.BrowserActivity'
            self.content=os.popen(cmd)
    
        #停止App
        def StopApp(self):
            #cmd = 'adb shell am force-stop com.android.browser'
            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()
            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('startTime2.csv', 'wb')
            writer = csv.writer(csvfile)
            writer.writerows(self.alldata)
            csvfile.close()
    
    if __name__ == "__main__":
        controller = Controller(10)
        controller.run()
        controller.SaveDataToCSV()
  • 相关阅读:
    第十周(11.18-11.24)----结对编程----感悟
    第十周(11.18-11.24)----分数计算----(2)对两个分数进行加减乘除
    第十周(11.18-11.24)----规格说明书练习----吉林市1日游
    浪潮之巅读后感
    闽江学院软件学院2015级学生职业人物访谈
    第五作业
    第4周~第12周周记
    兴趣问题清单
    学习进度
    价值观作业
  • 原文地址:https://www.cnblogs.com/vigo01/p/7545770.html
Copyright © 2011-2022 走看看