Android应用启动流量自动化测试

本文涉及的产品
阿里云百炼推荐规格 ADB PostgreSQL,4核16GB 100GB 1个月
简介: 之前《Tcpdump流量自动化测试上篇》、《Tcpdump流量自动化测试下篇》这两篇文章里讨论了如何通过tcpdump命令行工具来实现Android应用的流量自动化采集和分析,今天再来跟大家分享一下如何针对应用启动场景来做流量测试,有人可能会问了为什么是启动场景?因为现在工信部要求在用户没有授权网络请求前,应用不得擅自进行网络请求,特别是当跟厂商合作提供预装包的时候对此项的检查很严格。另外跟大家说明一下,我分享的文章都是亲自实践过的,基本照着方案操作不会有大问题,默认情况下我所使用的操作系统都是MacOS。

方案


今天还是会借着启动流量自动化测试脚本来顺带讲解其中涉及的Linux命令,所以头图依旧没变


网上也有很多关于流量自动化测试的文章,但很多比较陈旧,都是基于Android4.3机器做的测试,最新版本的系统在读取流量的目录上发生了一些变化,所以在此解释一下,在 Android 4.3 以前,系统是通过读取 /proc/uid_stat/{uid} 文件来获取流量数据的,但在 Android 4.3 之后,就被 /proc/net/xt_qtaguid/stats 取代了。

在开始之前需要先准备一台root过的Android手机,这里建议大家用小米或者Google的Pixel系列手机去root比较容易,根据我的经验,做移动端的性能测试常备一台root机是非常有必要的,能给你带来很多方便。


这里我们需要从命令行传入三个参数:设备ID、启动activity、采样次数。


1、首先是根据启动activity获取包名:

packagename=$(echo $2 | cut -d "/" -f1)

首先需要了解脚本“位置参数”的概念,假设一个脚本在运行时可以接受参数,那么从左到右第一个参数被记作$1,第二个参数为$2,以此类推,第n个参数为$N。所有参数记作$@或$*,参数的总个数记作$#,而脚本本身记作$0。


上面的命令意思是把第二个参数打印出来传递给cut命令,顾名思义,cut就是截取的意思,它能处理的对象是“一行”文本,可从中选取出用户所需要的部分。在有特定的分隔符时,可以指定分隔符,然后打印出以分隔符隔开的具体某一列或某几列,这里cut的用法如下:

cut -d "分隔符" -f 指定的列

2、根据应用包名获取UID:

userid=$(adb -s $deviceid shell dumpsys package $packagename | grep userId= | sed 's/ //g' | cut -c 8-12)

由于adb dumpsys命令获取到的userId前面包含空格如下图:

image.png

这里可以用到sed命令,sed(stream editor)是一种非交互式的流编辑器,通过多种转换修改流经它的文本。但是请注意,默认情况下,sed并不会改变原文件本身,而只是对流经sed命令的文本进行修改,并将修改后的结果打印到标准输出中(也就是屏幕),通过使用s参数可将查找到的匹配文本内容替换为新的文本,s/旧文本/新文本/g,这里我们是变相把空格替换掉了,后面的g代表完成所有匹配值的替换。

image.png

接着把输出传递给cut,这里可以利用cut的-c参数打印指定列的字符,我们想要的是userid的值,于是传入8-12,截取10933。


3、循环采样

这里通过一个while循环来达到采样N次的效果:

counter=$3while [[ $counter -gt 0 ]]do    command        let "counter-=1"done

这个循环体比较简单,就是判断counter计数器的值是否大于0,如果是就继续循环,每次循环计数器的值减一,let是Shell内建的整数运算命令。


4、读取 /proc/net/xt_qtaguid/stats 的数据

这里通过adb命令读取


image.png

对应的表头的列名称和意思如下:

dx  :序号
iface :代表流量类型(rmnet表示2G/3G, wlan表示Wifi流量,lo表示本地流量)
acct_tag_hex :线程标记(用于区分单个应用内不同模块/线程的流量)
uid_tag_int :应用uid,据此判断是否是某应用统计的流量数据
cnt_set :应用前后标志位:1:前台, 0:后台
rx_btyes :receive bytes 接受到的字节数
rx_packets  :接收到的任务包数
tx_bytes :transmit bytes 发送的总字节数
tx_packets :发送的总包数
rx_tcp_types :接收到的tcp字节数
rx_tcp_packets :接收到的tcp包数
rx_udp_bytes :接收到的udp字节数
rx_udp_packets :接收到的udp包数
rx_other_bytes :接收到的其他类型字节数
rx_other_packets :接收到的其他类型包数
tx_tcp_bytes :发送的tcp字节数
tx_tcp_packets :发送的tcp包数
tx_udp_bytes :发送的udp字节数
tx_udp_packets :发送的udp包数
tx_other_bytes :发送的其他类型字节数
tx_other_packets :发送的其他类型包数

这里我们先获取指定UID的前台流量消耗情况:

startrx=$(adb -s $deviceid shell cat /proc/net/xt_qtaguid/stats | grep "$userid 1" | awk '{print $6}' | sed -n '1p')

这里我们需要的是第6、第8列 rx_bytes 和 tx_bytes ,通过awk可以很轻松打印出对应的列,后面的sed是用来打印指定列的第一行数据域,使用p命令可进行打印,这里使用sed命令时一定要加-n参数,表示不打印没关系的行。从之前的例子中可以看出,由于sed的工作原理是基于行的,因此每次都有大量的输出。可是这些输出中有一些是我们并不需要看到的,而只需要输出匹配的行或者处理过的行就好了。


最终的效果:

微信图片_20220518233952.jpg

下面是完整的脚本:

#!/bin/bash
# 设备ID
deviceid=$1
# 启动activity
activity=$2
# 采样次数
counter=$3
# 截取包名
packagename=$(echo $2 | cut -d "/" -f1) 
echo "Package name is '$packagename'"
# 截取uid
userid=$(adb -s $deviceid shell dumpsys package $packagename | grep userId= | sed 's/ //g' | cut -c 8-12)
echo "uid = $userid"
while [[ $counter -gt 0 ]]
do
# 停止应用的进程
adb -s $deviceid shell am force-stop $packagename
# 清除应用数据与缓存
adb -s $deviceid shell pm clear $packagename
startrx=$(adb -s $deviceid shell cat /proc/net/xt_qtaguid/stats | grep "$userid 1" | awk '{print $6}' | sed -n '1p')
starttx=$(adb -s $deviceid shell cat /proc/net/xt_qtaguid/stats | grep "$userid 1" | awk '{print $8}' | sed -n '1p')
echo "初始时接收的流量: $startrx bytes"
echo "初始时发送的流量: $starttx bytes"
# 启动应用
adb -s $deviceid shell am start -n $activity
# 等待10s,应用启动后可能会加载一些数据资源
sleep 10s
endrx=$(adb -s $deviceid shell cat /proc/net/xt_qtaguid/stats | grep "$userid 1" | awk '{print $6}' | sed -n '1p')
endtx=$(adb -s $deviceid shell cat /proc/net/xt_qtaguid/stats | grep "$userid 1" | awk '{print $8}' | sed -n '1p')
echo "结束时接收的流量: $endrx bytes"
echo "结束时发送的流量: $endtx bytes"
# 本次启动耗费的总流量
let "data=($endrx+$endtx)-($startrx+$starttx)"
let "count=$3-$counter+1"
echo "应用启动消耗的流量第 $count 次测试结果:$data bytes"
let "sum+=$data"
let "counter-=1"
done
let "averagedata=$sum/3"
echo "================================================="
echo "应用启动的流量消耗 (采样次数:$3):$averagedata bytes"
相关实践学习
阿里云百炼xAnalyticDB PostgreSQL构建AIGC应用
通过该实验体验在阿里云百炼中构建企业专属知识库构建及应用全流程。同时体验使用ADB-PG向量检索引擎提供专属安全存储,保障企业数据隐私安全。
AnalyticDB PostgreSQL 企业智能数据中台:一站式管理数据服务资产
企业在数据仓库之上可构建丰富的数据服务用以支持数据应用及业务场景;ADB PG推出全新企业智能数据平台,用以帮助用户一站式的管理企业数据服务资产,包括创建, 管理,探索, 监控等; 助力企业在现有平台之上快速构建起数据服务资产体系
相关文章
|
1月前
|
Java 测试技术 数据安全/隐私保护
软件测试中的自动化策略与工具应用
在软件开发的快速迭代中,自动化测试以其高效、稳定的特点成为了质量保证的重要手段。本文将深入探讨自动化测试的核心概念、常见工具的应用,以及如何设计有效的自动化测试策略,旨在为读者提供一套完整的自动化测试解决方案,帮助团队提升测试效率和软件质量。
|
8天前
|
机器学习/深度学习 人工智能 自然语言处理
CogAgent-9B:智谱 AI 开源 GLM-PC 的基座模型,专注于预测和执行 GUI 操作,可应用于自动化交互任务
CogAgent-9B 是智谱AI基于 GLM-4V-9B 训练的专用Agent任务模型,支持高分辨率图像处理和双语交互,能够预测并执行GUI操作,广泛应用于自动化任务。
48 12
CogAgent-9B:智谱 AI 开源 GLM-PC 的基座模型,专注于预测和执行 GUI 操作,可应用于自动化交互任务
|
13天前
|
存储 缓存 运维
阿里云先知安全沙龙(上海站)——后渗透阶段主机关键信息自动化狩猎的实现与应用
本文介绍了在后渗透测试中使用LSTAR工具和PowerShell脚本进行RDP状态查询、端口获取及凭据收集的过程,强调了高强度实战场景下的OPSEC需求。通过MITRE ATT&CK框架的应用,详细阐述了凭证访问、发现和收集等关键技术,确保攻击者能够隐蔽、持续且高效地渗透目标系统,最终获取核心数据或控制权。文中还展示了SharpHunter等工具的自动化实现,进一步提升了操作的安全性和效率。
|
1月前
|
运维 监控 持续交付
自动化运维在现代数据中心的应用与实践####
本文探讨了自动化运维技术在现代数据中心中的应用现状与实践案例,分析了其如何提升运维效率、降低成本并增强系统稳定性。通过具体实例,展示了自动化工具如Ansible、Puppet及Docker在环境配置、软件部署、故障恢复等方面的实际应用效果,为读者提供了一套可参考的实施框架。 ####
|
2月前
|
jenkins 测试技术 持续交付
探索自动化测试在持续集成中的应用与挑战
本文深入探讨了自动化测试在现代软件开发流程,特别是持续集成(CI)环境中的关键作用。通过分析自动化测试的优势、实施策略以及面临的主要挑战,旨在为开发团队提供实用的指导和建议。文章不仅概述了自动化测试的基本原理和最佳实践,还详细讨论了如何克服实施过程中遇到的技术难题和管理障碍,以实现更高效、更可靠的软件交付。
|
2月前
|
机器学习/深度学习 人工智能 测试技术
探索自动化测试框架在软件开发中的应用与挑战##
本文将深入探讨自动化测试框架在现代软件开发过程中的应用,分析其优势与面临的挑战。通过具体案例分析,揭示如何有效整合自动化测试以提升软件质量和开发效率。 ##
|
2月前
|
运维 监控 安全
自动化运维的利剑:Ansible在现代IT架构中的应用
在数字化浪潮中,企业对IT系统的敏捷性和可靠性要求日益提高。Ansible,一种简单但强大的自动化运维工具,正成为现代IT架构中不可或缺的一部分。它通过声明式编程语言YAM,简化了系统配置、应用部署和任务自动化的过程,显著提升了运维效率和准确性。本文将深入探讨Ansible的核心特性、应用场景以及如何有效整合进现有IT环境,为读者揭示其在自动化运维中的实用价值和未来发展潜力。
|
2月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
67 1
|
2月前
|
监控 安全 测试技术
如何在实际项目中应用Python Web开发的安全测试知识?
如何在实际项目中应用Python Web开发的安全测试知识?
36 4