APP非功能测试

Posted 折翼の翅膀

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了APP非功能测试相关的知识,希望对你有一定的参考价值。

1、移动APP启动时间测试

问题:如何获取启动时间?

答:通过adb的logcat来获取Activity启动时间。用户体验时间=Activity启动时间+启动中异步UI绘制的时间。

启动时间的测试主要涉及2种场景(启动方式):热启动和冷启动。

  • 冷启动:手机系统中没有该APP的进程,也就是首次启动。点击APP图标,启动应用的时候没有该应用的进程存在。
  • 热启动:手机系统中有该APP的进程,即APP从后台切换到前台。点击APP图标,启动应用的时候后台已经有该应用的进程存在了。

APP启动时间测试方法:

1、adb命令,如adb logcat、adb shell am start、adb shell screen-record。

1.1 以com.android.browser这个包名为例,adb shell am start执行命令如下:

adb shell
am start -W -n com.android.browser/.BrowserActivity(回车后观察模拟器)

-W :启动完成之后,返回启动耗时。
-n:后面跟的是需要启动的APP的包名和lauchActivity。 

1.2 以com.android.browser这个包名为例,adb logcat执行命令如下:

1、先kill掉该应用,执行命令:adb logcat > d:	estresult.txt
2、启动应用,待加载完成后ctril+c停止,使用find过滤启动时间,testresult_2.txt是最终我们想要的启动时间,相加其中的时间。
3find “Displayed”d:	estresult.txt >d:	estresult_1.txt
4find “com.android.browser”d:	estresult.txt >d:	estresult_2.txt

1.3 以com.android.browser这个包名为例,adb shell screen-record执行命令如下:

1、把待测手机连上计算机,执行录制命令:adb shell screenrecord /sdcard/demo.mp4>启动app>按ctrl+c结束
2、adb pull screenrecord /sdcard/demo.mp4 d:
ecord命令导出视频到D盘的record文件夹下
3、使用视频软件打开该视频并进行播放分析(如KMPlayer)
4、视频中ICON变亮作为开始时间,将APP完全启动后的时间作为终止时间。用户体验时间=终止时间-开始时间

2、代码里打点(埋点),代码里插入时间并打印Log.e。

3、高速相机、秒表

4、三方工具或云测平台

2、移动APP流量测试

流量:指能够连接网络的设备在网络上所产生的数据流量。

一般对于APP测试的流量,主要关注的是用户层面的流量,需要考虑2种场景:活动状态、静默状态。

  • 活动状态:用户对APP操作而直接导致的流量消耗。
  • 静默状态:用户没操作APP,APP处于后台状态时流量的消耗。

对于Android系统下流量的测试方法:

1、通过Tcpdump抓包,然后利用wireshark分析。

2、查看linux流量统计文件

3、利用类似DDMS的工具查看流量

4、利用Android API来统计,通过Android API的TrafficStats类来统计,该类提供了很多不同方法来获取不同角度的流量数据。

5、三方工具或者云测平台。

使用比较多的linux流量统计文件为例,以test.apk这个应用为例,查看这个应用的流量:

1、通过ps | grep com.android test命令获取pid。

2、通过 cat /proc/{pid}/status 命令获取uid,其中{pid}替换为第一步获取的pid值。

3、通过cat /proc/uid_stat/{uid}/tcp_snd命令获取发送的流量(单位bytes),其中{uid}替换为第二步的值。

4、通过cat /proc/uid_stat/{uid}/tcp_rcv命令获取接收的流量(单位bytes),其中{uid}替换为第二步的值。 

3、移动APP CPU测试

测试一款APP在各种场景下CPU的占用率情况也是比较重要的指标,CPU占用率较高会影响使用流畅度。

一般APP在手机上的CPU占用率主要考虑2种场景:

  • 活动状态:用户对APP操作而直接导致的流量消耗。
  • 静默状态:用户没操作APP,APP处于后台状态时流量的消耗。

对于APP CPU测试方法如下:

1、三方工具,如腾讯GT、网易Emmagee、阿里易测、手机自带监控等。

2、dumpsys命令。如adb shell dumpsys cpuinfo | grep {PackageName}.

3、top命令。如adb shell top | grep {PackageName}.

4、移动APP电量测试

电量测试其实是评估消耗电量快慢的一种方式。

电量测试的测试场景主要有:

  • 待机:包括无网络待机、Wi-Fi待机、3G待机等。
  • 静默状态:打开APP之后并不操作,让后台运行。
  • 活动状态:不断地进行某些场景的操作,除了常规操作外,还应该包括看视频、灭屏下载、唤醒等。

对于APP 电量测试方法:

1、通过硬件进行测试。比如,耗电量测试仪、腾讯自己制作的电量宝。

2、通过adb shell dumpsys batterystats命令。

3、三方工具或者云测平台。

5、移动APP测试工具和云测平台

1、腾讯GT: http://gt.qq.com ,即可对APP进行快速性能测试(CPU、内存、流量、电量、帧率/流畅度等)、开发日志的查看、Crash日志查看、网络数据包的抓取、APP内部参数的调试、真机代码耗时统计等。

2、Emmagee:http://github.com/NetEase/Emmagee, 监控制定被测应用在使用过程中占用机器的CPU、内存、流量资源的使用情况并记录下来,同时可以通过excel来做出统计图的形式。

3、EasyTest易测:在手机端完成实时性能数据的监控、弱网环境的模拟、手机抓包、Monkey测试等。

6、移动APP内存测试

内存泄露是什么?

内存泄漏:进程中某些对象已经没有使用价值了,但是他们却可以直接或间接地被引用从而导致无法被GC回收。当积累超过Dalvik堆大小时就会发生内存泄露。

内存泄露常见的分析方法:

1、在adb shell 下运行命令dumpsys meminfo [应用包名],可以观察到内存的使用情况。一般观察PSS Total和Heap Size Total.其中Dalvik就是Java堆,它不能超过最大限制,查看最大限制可以用命令getprop |grep heapgrowthlimit.

2、DDMS和MAT.DDMS可动态查看某进程占用内存的情况,而MAT可以对dump出来hprof进行分析。

3、Android Studio和MAT.适合有源码的情况。

4、日志和必要的监控。

内存泄露步骤如下:

1、运行被测APP并持续操作

2、在DDMS中的VM heap标签页里查看消耗。其中有一个按钮Cause GC,方便观察内存的回收情况。如果多次进行发现内存还是在不断增大,可回收的越来越少,那就有可能存在内存泄露。也可以通过data object中的Total Size来进行判断。

3、当发送内存泄露或者持续增长的时候可以通过DDMS的Dump hrof file功能捕获内存快照。

4、通过命令hprof-conf [inputfile][outputfile]转化为标准的hprof文件

5、使用MAT打开标准的hprof文件并进行分析。

6、如果MAT分析不出什么来,可以通过dumpsys meminfo 观察Native Heap的Pss Total和Heap Alloc,如果他们一直在增长,可能是Native层出现了问题,需要去排查JNI、SO库相关的代码。

以上是关于APP非功能测试的主要内容,如果未能解决你的问题,请参考以下文章

如何在 Activity(非 AppCompatActivity)中打开片段?

我的片段无法转换为 android.support.v4.app.Fragment

Android App 在片段中创建 ListView 引用时关闭

如何使用模块化代码片段中的LeakCanary检测内存泄漏?

javascript UV Index Monitor App订阅PubNub并显示UV索引值。博文的代码片段。在这里查看项目:https:// githu

APP非功能测试