【腾讯TMQ】手机发烫是为何 --App电量测试定位方法

2024-04-14 04:38

本文主要是介绍【腾讯TMQ】手机发烫是为何 --App电量测试定位方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

为什么要做电量测试

随着移动互联网的快速发展,手机的实用性、娱乐性越来越强。日常使用中发现,安装了应用后,即使不怎么使用,电量也会消耗很快。但如果恢复出场设置充满电后,手机可以待机很长时间。真相只有一个:手机耗电的最终元凶是软件。

在各大应用市场中搜索“电量管理”相关应用,每个应用都有几万到几十万次的下载量。这说明,越来越多的用户开始关注应用电量问题。所以,在研发阶段,有效的检测和定位电量问题,是十分重要的工作。

如何能够有效的检测和定位应用的电量问题呢?可以从两个方面入手:一方面,从手机系统入手,了解ROM对应用电量消耗的统计原理,进而从代码层规避不必要的电量消耗。另一方面,从应用本身入手,在保证用户体验的前提下,尽可能减少不必要的操作。

下面分享下,在对应用电量优化过程中所做的专项测试工作。

业界通用的电量测试方法


小结:可以看出,目前业界现有的电量测试方法很多。除了借助于其他设备监测整机电量消耗的硬件测试方案外,android系统也提供了各种获取应用电量消耗的方法。

方法各有优势。但,都是定位于获取整体电量消耗(整机、应用)。对于开发和测试人员最关注的问题:有效定位导致应用电量消耗的具体原因,仍然无法解决。

我们需要的电量测试

在产品研发阶段,能够快速获取应用电量消耗,准确定位问题原因的测试方法,是开发和测试人员最需要的方法。所以,从2016年初开始,我们确定了电量测试工作的开展方向:

1、理清原理:Android系统电量统计原理;

2、调整策略:关注整机的硬件测试方案替换为关注APP的软件测试方案;

3、准确定位:获取更详细的数据;

4、提升效率:自动化电量测试方案建设。

Step1理清原理

在对业界现有测试工具的了解中,我们发现Android提供了对应用电量统计的系统工具“耗电排行”。
通过解包ROM源码并反编译Settings.apk,找到了Android系统对应用电量消耗统计的接口:com.android.internal.os.BatteryStatsHelper(5.0之后类名)中的方法processAppUsage。该方法中统计了系统对应用各部分的电量消耗:

统计项
计算方法
CPU
cpuSpeedStepTimes[step]/totalTimeAtSpeeds * (userTime + systemTime) * powerCpuNormal[step]
Data trans
数据传输量* getAverageDataCost()
WiFi running
wifi运行时间* power_profiler.xml中type=wifi_on的数值
WiFi scan
wifi运行时间* power_profiler.xml中type=wifi_scan的数值
GPS
GPS传感器运行时间* power_profiler.xml中type=gps_on的数值
Other Sensors
其他传感器运行时间*默认传感器的电量消耗
Camera(7.0新增)
运行时间*power_profile.xml中camera_avg属性代表的值
在解读源码的过程中,发现了一个有意思的文件power_profiler.xml。该文件中列出了手机厂商针对机型硬件定义的单位时间元器件电量消耗值。由于文件内容的差异,从而导致了,同样的应用、同样的操作场景、同样的外界环境,在不同手机上电量消耗不同。

不同手机power_profiler.xml文件

小结:通过解读源码,掌握到系统对应用电量消耗的统计方法。如果可以在测试过程中获取到组成应用整体消耗的各部分的消耗值,就可以大体定位到问题方向。

Step2调整策略

硬件测试采集的是整机的电流值,由于外接干扰因素的影响_其他应用、手机环境、网络环境、人为因素等,经常导致的测试结果是:数据波动大、无法定位原因。并且,随着手机硬件、外观的调整,越来越多的机器无法自主拆卸电池,而厂商对内置版本的电量要求却越来越严格。目前现有的硬件测试方案,无法继续满足在研发阶段对应用电量的有效保障。
既然Android系统已经提供了对单个应用的电量统计应用,我们就可以利用源码并结合实际的需求,对已有的系统工具进行二次开发,通过软件的方式完成对单个应用耗电量的测试。

Step3准确定位

理清了系统对应用的电量统计原理后,我们发现“耗电排行工具”并没有详细输出组成应用总体电量消耗的每一部分的消耗值。所以,在解决“准确定位”的问题上,首先能够做的工作就是进一步细化数据。

“工欲善其事必先利其器”。

我们开发了以下两个工具,支持获取更详细的数据。

【工具一:PowerStat2.0】

该工具是对系统“耗电排行工具”的二次开发。使用系统计算公式和API进行计算。
相比较原工具,完善以下几个特性:

1、数据展示:除了展示组成应用总体电量消耗的每一部分的消耗值,同时显示使用时长、次数及数据传输量信息;

2、传感器细分;

3、展示power_profiler.xml;

4、提供定时测试功能。
1492673540677546.png

【工具二:CPUMonitor】

通过日常监控和用户反馈发现,导致应用电量消耗升高的最常见问题是CPU问题:

华为手机用户反馈电量问题

日常监控电量异常升高问题

依据操作系统的概念—进程是由一个或多个线程组成,可以将“准确定位”问题进一步细化到获取线程的CPU时间片消耗。

为了能够在电量测试的同时进行CPU时间片数据的采集,并尽可能减少其他消耗的引入,我们开发了一个手机端的数据采集工具:CPUMonitor。原理如下:

工具具备以下几个特性:

1、广播作为工具驱动方式,方便应用于自动化脚本控制;

2、数据源取自系统:权威、详细;

3、多样的采集模式:频繁模式(freq)、触发模式(lazy)。

优势:

1、安装使用无权限要求;

2、可与电量测试同时进行;

3、数据取自系统保证准确性;

4、触发模式保证了最小性能消耗。

小结:目前,工具已经应用于多个移动端应用的电量测试中。除了可以高效定位电量问题外,还可以在功能开发前预估电量消耗,从产品层协助策略制定。通过自研工具的开发,有效的将原有的硬件测试方案替换成关注应用电量消耗的软件测试方案。自研工具获取的数据,全部来自于系统提供的接口,保证了数据的准确有效性。

Step4 提升效率

通过测试工具的开发,在一次电量测试过程中,已经能收集到帮助定位问题的足够详细的测试数据。所以,我们下一步需要思考的就是,如何能够更加高效更加精准的获取测试数据?
原有的电量测试流程:

存在的问题:

1、人工操作:设备连接、环境清理、应用安装、工具设置、初始数据采集;

2、人工操作:设备断开、场景操作执行、计时;

3、人工操作:设备连接、数据采集&保存。

人工干预每个环节导致:数据准确性低、执行效率低。

各环节的优化方案:

数据采集:脚本驱动+测试工具 替代 手动执行命令行;

操作执行:自动化脚本 替代 手工操作;

流程控制:PC控制 替代 人工控制。

优化后的电量测试流程:

解决需人工连接设备的问题:将传统的USB线中间增加硬件控制模块后,可由PC端的脚本控制硬件的断开连接。

解决USB连接断开后场景操作的执行问题:传统的解决方案:将自动化脚本放到手机端执行。

存在的问题:手机必须要有root权限。

解决的方案:adb无线控制,下发指令。

小结:通过全流程的自动化处理,减少人工干预,除了提高数据的准确性外,有效的提升了测试效率。以1小时待机电量测试为例,原测试流程和自动化测试流程相比较:

我们的收益

总结下我们在电量测试方面所做的工作:

1、通过对Android系统电量统计原理的分析,清晰的掌握到组成APP整体电量消耗的每一部分的消耗值,从而可以直接定位导致电量问题的大体方向。

2、通过测试工具的开发,获取到更加详细的功耗数据,从而可以直接定位到具体代码逻辑。

3、通过电量测试的自动化建设,有效提升测试效率,除了缩短测试时长、减少人力投入外,还提高了测试数据的准确性。

电量测试方案应用于移动终端产品,除了能快速检测定位电量问题外,还可以协助开发及产品评估新增功能带来的额外消耗。

通过一年多的工作,我们总结出一套理论与实践相结合的电量优化检测方法:

理论:在了解系统对应用电量统计原理的过程中,发现对wake lock消耗的计算在方法processAppUsage()中是没有进行条件判断的。也就是说,如果在亮屏时,代码逻辑中仍然注册了wake lock(测试的wake lock是没有任何意义的),在对应用进行电量统计时,就会计算上这部分的消耗:

在写代码时,可以注意下,在进行wake lock注册时,首先要判断手机的状态。

实践:在对多个应用进行电量测试的过程中,发现不同产品根据产品特性不同,除了共性导致电量异常的问题外,还会存在产品特性相关的操作场景。

我们抛开产品,抽离出共性问题,整理成下面这个表格:
在用例设计部分,我们将待机列为需要关注的场景,是因为用户对待机时应用的电量消耗更为敏感。而在这个场景下,经常会出现由于代码逻辑问题、产品策略问题导致应用电量消耗异常。在操作过程中的电量消耗,是用户预知的消耗。但如果使用不当,也会造成异常消耗。

【TMQ新书专栏】https://weidian.com/?userid=984448577

了解更多测试相关干货 ,关注我们的微信公众号——腾讯移动品质中心TMQ:
这里写图片描述

这篇关于【腾讯TMQ】手机发烫是为何 --App电量测试定位方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/902094

相关文章

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

浅谈主机加固,六种有效的主机加固方法

在数字化时代,数据的价值不言而喻,但随之而来的安全威胁也日益严峻。从勒索病毒到内部泄露,企业的数据安全面临着前所未有的挑战。为了应对这些挑战,一种全新的主机加固解决方案应运而生。 MCK主机加固解决方案,采用先进的安全容器中间件技术,构建起一套内核级的纵深立体防护体系。这一体系突破了传统安全防护的局限,即使在管理员权限被恶意利用的情况下,也能确保服务器的安全稳定运行。 普适主机加固措施:

webm怎么转换成mp4?这几种方法超多人在用!

webm怎么转换成mp4?WebM作为一种新兴的视频编码格式,近年来逐渐进入大众视野,其背后承载着诸多优势,但同时也伴随着不容忽视的局限性,首要挑战在于其兼容性边界,尽管WebM已广泛适应于众多网站与软件平台,但在特定应用环境或老旧设备上,其兼容难题依旧凸显,为用户体验带来不便,再者,WebM格式的非普适性也体现在编辑流程上,由于它并非行业内的通用标准,编辑过程中可能会遭遇格式不兼容的障碍,导致操

【测试】输入正确用户名和密码,点击登录没有响应的可能性原因

目录 一、前端问题 1. 界面交互问题 2. 输入数据校验问题 二、网络问题 1. 网络连接中断 2. 代理设置问题 三、后端问题 1. 服务器故障 2. 数据库问题 3. 权限问题: 四、其他问题 1. 缓存问题 2. 第三方服务问题 3. 配置问题 一、前端问题 1. 界面交互问题 登录按钮的点击事件未正确绑定,导致点击后无法触发登录操作。 页面可能存在

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

【北交大信息所AI-Max2】使用方法

BJTU信息所集群AI_MAX2使用方法 使用的前提是预约到相应的算力卡,拥有登录权限的账号密码,一般为导师组共用一个。 有浏览器、ssh工具就可以。 1.新建集群Terminal 浏览器登陆10.126.62.75 (如果是1集群把75改成66) 交互式开发 执行器选Terminal 密码随便设一个(需记住) 工作空间:私有数据、全部文件 加速器选GeForce_RTX_2080_Ti