APP 性能测试-冷启动耗时(结合Python生成性能测试报告)

1.启动(注意:获取app启动包名和启动名(手机需要先打开对应app))
测试标准:冷启动时间不超过1.5s, 热启动不超过1s
获取软件包名:adb shell "dumpsys window | grep mCurrentFocus"
在这里插入图片描述
①冷启动(杀掉软件进程,使用首个activity启动命令)
1.首先获取软件包以及首个activity
通过adb shell monkey来获取,如下命令

adb shell monkey -p com.citiccard.mobilebank -vvv 1

获取得到首个Activity:com.zhd.maxsurvey/.SplashActivity
在这里插入图片描述

2.获取首个activity启动时间
首个activity启动时间(如已经启动软件则需要杀掉进程重新使用该命令启动)
adb shell am start -W com.zhd.maxsurvey/.SplashActivity
在这里插入图片描述
在这里插入图片描述
在第①个时间段内,AMS 创建 ActivityRecord 记录块和选择合理的 Task、将当前Resume 的 Activity 进行 pause
在第②个时间段内,启动进程、调用无界面 Activity 的 onCreate() 等、 pause/finish 无界面的 Activity
在第③个时间段内,调用有界面 Activity 的 onCreate、onResume
参考文档:https://blog.51cto.com/u_14496797/5360305
后续总结该段落
ThisTime : ThisTime 表示一连串启动 Activity 的最后一个 Activity 的启动耗时
TotalTime : 启动一连串的 Activity 总耗时.(有几个Activity 就统计几个),表示新应用启动的耗时,包括新进程的启动和 Activity 的启动,但不包括前一个应用 Activity pause 的耗时。也就是说,开发者一般只要关心 TotalTime 即可,这个时间才是自己应用真正启动的耗时
WaitTime : 应用进程的创建过程 + TotalTime,就是总的耗时,包括前一个应用 Activity pause 的时间和新应用启动的时间
(如果只关心某个应用自身启动耗时,参考TotalTime;如果关心系统启动应用耗时,参考WaitTime;如果关心应用有界面Activity启动耗时,参考ThisTime)
重复测试冷启动需要杀掉进程
停止APP进程,并且清除这个APP进程产生的所有数据

adb shell pm clear package

强制停止APP进程,不会清除APP进程在系统中产生的数据

adb shell am force-stop package

②热启动(命令与冷启动命令一致,App退到后台,不杀进程,命令同冷启动)
adb shell am start -W com.zhd.maxsurvey/.SplashActivity
在这里插入图片描述
冷启动app类

class App():
    def __init__(self,packagename,firstActivity):
        """构造方法"""
        #包名
        self.packagename = packagename
        #首个Activity
        self.firstActivty= firstActivity
        self.content="" #执行命令的文本
        self.startTime="" #启动的时间
    def startApp(self):
        """开启app"""
        cmd = "adb shell am start -W -n "+self.packagename+self.firstActivty
        self.content = os.popen(cmd)
        print(type(self.content))
    def stopApp(self):
        """停止app"""
        cmd = "adb shell am force-stop"+self.packagename
        os.popen(cmd)
    def getStartTime(self):
        """获取启动时间"""
        for line in self.content.readlines():
            if "ThisTime" in line:
                self.startTime = line.split(":")[1]
                break
        return self.startTime

冷启动管理运行类(运行次数,运行时间,文件保存)

class Manager():
    def __init__(self,count,App):
        self.count= count
        self.app =App
        self.file = open("starttime.txt","w")
    def run(self):
        while self.count>0:
            self.app.startApp()
            time.sleep(2)
            #获取时间
            self.file.write(self.app.getStartTime())
            self.app.stopApp()
            time.sleep(2)
            self.count=self.count-1
        #关闭资源
        self.file.close()

调用例子:

app = App(packagename, firstActivity)
m = Manager(6, app)#运行6次
m.run()
<think>好的,用户想了解如何通过脚本或工具自动计算Android和iOS应用的启动耗时,进行性能测试。我需要先整理现有的知识,然后结合提供的引用内容给出具体的步骤和工具推荐。 首先,用户的问题分为Android和iOS两个平台,可能需要分别处理。根据引用内容,特别是引用1和引用4,提到了使用命令行工具和脚本来自动化获取启动时间。 对于iOS部分,引用1提到使用xcrun simctl命令来启动应用,并通过log show获取启动日志中的"Total pre-main"时间。这可能对应冷启动时间。需要详细说明如何编写脚本,包括启动应用、终止进程、获取日志的具体命令。另外,Instruments工具也是iOS性能测试的常用工具,引用1和引用2都提到了Xcode Instruments,可以用来进行热启动测试,但用户可能需要自动化脚本,所以可能需要结合命令行工具。 对于Android部分,引用4提到使用adb logcat来过滤ActivityManager的日志,查找Displayed的时间。这里需要给出具体的adb命令,以及如何用脚本解析这些日志。另外,引用2和引用3提到的自动化测试工具,比如AppCrawler和MobSF,可能也可以用于性能测试,但用户的问题更偏向启动时间的测量,可能需要更直接的方法。 还需要注意用户提到的自动化,因此需要建议如何编写脚本来自动执行这些命令并提取时间数据。例如,使用Shell脚本或Python脚本结合grep/awk处理日志。 可能的问题点:是否需要区分冷启动和热启动?引用1中提到了冷启动测试和热启动测试,用户的问题中可能都需要涵盖。因此回答中需要分别说明两种启动方式的测试方法。 工具方面,除了命令行工具,还可以提到一些自动化测试框架,比如Android的Jetpack Macrobenchmark或iOS的XCTest,但根据引用内容,用户可能更倾向于现有的脚本方案,所以重点放在脚本和命令行工具上。 总结步骤: 1. Android使用adb logcat捕获Displayed时间。 2. iOS使用xcrun simctl启动应用,并通过log命令获取pre-main时间。 3. 提供示例脚本,说明如何自动化执行命令和提取时间。 4. 推荐其他工具如Instruments、MobSF、Drozer等,但主要回答集中在用户的问题,即启动时间的自动化测量。 需要确保引用正确的引用来源,比如引用1关于iOS的冷启动测试脚本,引用4关于测试工具实现自动化启动时间获取。同时,引用3提到的MobSF可能适用于安全测试,但这里可能不相关,不过用户问题中提到了性能测试,所以可能不需要引用这部分,但根据引用内容,需要适当提及。 最后,生成相关问题,可能需要涉及性能测试的其他方面,工具对比,优化方法等。</think>### 如何通过脚本或工具自动计算App启动耗时(Android/iOS) #### **一、Android平台自动化测量方法** 1. **使用`adb logcat`捕获启动时间** - **冷启动**:通过过滤`ActivityManager`日志中的`Displayed`字段获取启动耗时 ```bash adb logcat -c && adb logcat -s ActivityManager | grep "Displayed" ``` 启动应用后,日志会输出类似: `ActivityManager: Displayed com.example.app/.MainActivity: +1s234ms` 其中`1s234ms`即为启动耗时[^4]。 - **自动化脚本示例**(Shell/Python): 使用`adb`命令启动应用并提取时间: ```python import subprocess subprocess.run("adb shell am start -W com.example.app/.MainActivity", shell=True) result = subprocess.check_output("adb logcat -d -s ActivityManager | grep Displayed", shell=True) print("启动耗时:", result.decode().split()[-1]) ``` 2. **进阶工具推荐** - **Android Profiler**:实时监控CPU/内存指标,需手动操作 - **Jetpack Macrobenchmark**:支持自动化性能测试框架,可编程化测量启动时间--- #### **二、iOS平台自动化测量方法** 1. **使用`xcrun simctl`与系统日志** - **冷启动测试脚本**(需替换Bundle ID): ```bash # 启动应用并记录时间戳 xcrun simctl launch booted com.yourcompany.app \ --terminate-running-process \ --args "-StartFromCold 1" # 提取pre-main耗时 log show --predicate 'process == "YourApp"' \ --debug --info --last 5m | grep "Total pre-main" ``` 输出示例:`Total pre-main time: 2.3 seconds`[^1]。 - **热启动测试**: 通过`Xcode Instruments`的**Time Profiler**模板,手动录制启动过程,但可通过`xcodebuild`命令实现部分自动化。 2. **自动化脚本优化** - 使用`os_log`在代码中埋点,结合`log stream`命令精准捕获阶段耗时--- #### **三、跨平台工具推荐** 1. **Appium**:支持Android/iOS自动化测试,可集成启动时间测量逻辑 2. **MobSF**:支持静态分析与动态监控,扩展性强(需自定义脚本)[^3] 3. **PerfDog**(腾讯):商业级性能测试工具,支持自动化数据导出。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值