ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

APP性能测试——安装耗时测试

2022-09-13 15:33:45  阅读:259  来源: 互联网

标签:name package APP 耗时 测试 time 安装 setup


安装耗时:

    这里我们用pm命令安装app,来截取安装时间(不要使用adb install安装,因为那样多一个push app的耗时)。

示例代码:

import os,time,datetime

def setuptime(package_name):
    '''单次安装耗时'''
    os.popen('adb uninstall {}'.format(package_name)) #卸载app
    time.sleep(3)
    start_time=datetime.datetime.now()
    os.popen("adb shell pm install /data/local/tmp/ghost-09081547.apk") #通过pm命令安装apk
    end_time=datetime.datetime.now()
    setup_time=(end_time-start_time).total_seconds() #计算单次安装耗时
    return setup_time

def installTime(package_name):
    '''测试安装30次平均耗时并写入txt文本'''
    try:
        with open('F:/report/installtime.txt', 'wb+') as file:
            su_time = []
            for i in range(30):
                setup_time = setuptime(package_name)
                if setup_time==0:
                    continue
                else:
                    su_time.append(setup_time)
                    print("第{}次安装耗时为: {}s".format(i + 1,setup_time))
                    file.write(("第{}次安装耗时为: {}s\n".format(i + 1,setup_time)).encode())
            return su_time
    except os.error as error:
        print(error)

def getDev():
    '''获得设备id'''
    try:
        devices_info = os.popen('adb devices')
        data = devices_info.readlines()
        if len(data) != 0 and data[1].find('device'):
            s = data[1][:-7]
            return s
        return 0
    except Exception as error:
        print(error)


def main_setup(package_name):
    '''计算平均耗时并写入txt文本'''
    s = getDev()
    print('设备:{},APP包名:{}\n安装测试开始...'.format(s,package_name))
    time_list = installTime(package_name)
    total_time = 0
    for i in time_list:
        total_time += i
    avg_time = total_time / len(time_list)
    print('安装平均耗时: {}s'.format(avg_time))
    with open('F:/report/installtime.txt', 'ab+')as f:
        f.write(('\n设备{}平均安装耗时:{}s'.format(s,avg_time)).encode())


if __name__ == '__main__':
    os.popen("adb push F:\ghost\ghost-09081547.apk /data/local/tmp/") #通过adb命令将apk从pc本地拷贝到手机内存中,注意不要存入/sdcard/目录,部分手机限制访问
    package_name = 'sg.partying.ghost.android' #app应用包名
    main_setup(package_name)

 

标签:name,package,APP,耗时,测试,time,安装,setup
来源: https://www.cnblogs.com/muxiaomu/p/16689244.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有