Monkey日志ANR、CRASH、空指针异常及其他异常数据分析

引言

在Android开发过程中,monkey测试是一种常用的随机测试手段,用于模拟用户的各种操作来发现应用中的稳定性问题。通过monkey测试生成的日志文件包含了丰富的信息,包括应用程序崩溃(Crash)、无响应(ANR)、空指针异常(NullPointerException)等异常情况。本文将介绍如何利用Python脚本和CMD批处理命令来解析这些日志文件,快速定位问题所在,并统计异常发生的次数。

准备工作

  1. Monkey测试执行:首先需要运行monkey测试并获取日志文件。
  2. 日志文件:确保你有一个或多个monkey测试生成的日志文件供分析使用。

步骤一:日志文件的预处理

在开始分析之前,我们通常需要对原始日志文件进行一定的预处理,比如提取关键信息到新的文件中。

使用CMD批处理命令

创建一个简单的批处理文件来复制日志文件中的关键行到新文件中:

@echo off
setlocal enabledelayedexpansionset logFile=monkey_log.txt
set outputFile=monkey_anr_crash.log> %outputFile% (for /f "tokens=*" %%a in (%logFile%) do (if "%%a" == "ANR:" (echo ANR detected.echo %%a) else if "%%a" == "CRASH:" (echo CRASH detected.echo %%a))
)

步骤二:使用Python进行详细分析

接下来,我们将使用Python来进一步分析这些关键行,以找出发生ANR、CRASH、空指针异常以及其他异常的具体位置和页面,并统计每个页面发生异常的次数。

Python脚本
import redef parse_monkey_log(log_file):anr_counts = {}crash_counts = {}null_pointer_counts = {}other_exception_counts = {}with open(log_file, 'r') as file:for line in file:# 检查是否是ANR行if 'ANR:' in line:match = re.search(r'ANR: (.*) at', line)if match:page = match.group(1)anr_counts[page] = anr_counts.get(page, 0) + 1# 检查是否是CRASH行elif 'CRASH:' in line:match = re.search(r'CRASH: (.*) at', line)if match:page = match.group(1)crash_counts[page] = crash_counts.get(page, 0) + 1# 检查是否是空指针异常elif 'NullPointerException' in line:match = re.search(r'NullPointerException.*at (.*)', line)if match:page = match.group(1)null_pointer_counts[page] = null_pointer_counts.get(page, 0) + 1# 检查其他异常elif 'Exception' in line and not 'NullPointerException' in line:match = re.search(r'Exception.*at (.*)', line)if match:page = match.group(1)other_exception_counts[page] = other_exception_counts.get(page, 0) + 1return anr_counts, crash_counts, null_pointer_counts, other_exception_counts# 主函数
if __name__ == "__main__":log_file = "monkey_anr_crash.log"anr_counts, crash_counts, null_pointer_counts, other_exception_counts = parse_monkey_log(log_file)print("ANRs found:")for page, count in anr_counts.items():print(f"{page}: {count} times")print("\nCrashes found:")for page, count in crash_counts.items():print(f"{page}: {count} times")print("\nNullPointerExceptions found:")for page, count in null_pointer_counts.items():print(f"{page}: {count} times")print("\nOther Exceptions found:")for page, count in other_exception_counts.items():print(f"{page}: {count} times")

测试

假设使用应用宝进行测试,使用一下命令连接模拟器然后运行monkey命令

adb connect 127.0.0.1:62025
adb shell monkey --throttle 500 --ignore-crashes --ignore-timeouts --ignore-security-exceptions --ignore-native-crashes --monitor-native-crashes --kill-process-after-error --pct-touch 20 --pct-motion 20 --pct-trackball 10 --pct-nav 10 --pct-majornav 10 --pct-syskeys 10 --pct-appswitch 10 --pct-anyevent 5 -p com.tencent.android.qqdownloader   6000  > /monkey_output.log

运行脚本进行解析即可知道运行结果

结论

通过上述步骤,我们可以有效地从大量的monkey日志文件中提取ANR、CRASH、空指针异常以及其他异常的信息,并进一步定位到具体的页面和位置。这种方法可以显著提高问题定位的速度和准确性,并且统计了每个页面发生异常的次数,有助于进一步分析和优化应用的稳定性。

后记

如果您希望进一步扩展这个脚本的功能,例如增加错误统计或者图形化展示结果,可以考虑使用更高级的数据处理库如Pandas和可视化库如Matplotlib。

请注意,这个例子假设您的日志文件中已经包含了类似于“ANR: MainActivity at”、“CRASH: SplashActivity at”、“NullPointerException at ActivityName”等格式。根据实际日志文件的内容,您可能需要调整正则表达式来匹配特定的模式。

通过这样的流程,您可以高效地处理monkey测试产生的日志文件,并快速识别出需要关注的问题点。这将有助于提升应用的质量和用户体验。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/53352.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【LabVIEW学习篇 - 18】:人机界面交互设计02

文章目录 错误处理函数简单错误处理器通用错误处理器清楚错误合并错误错误代码至错误簇转换查找第一个错误 鼠标指针 错误处理函数 在LabVIEW中,是通过错误输入簇和错误输出簇来传递错误信息,可以将底层错误信息传递到上层VI。设计人员需要对不同程度的…

2024 数学建模高教社杯 国赛(C题)| 农作物的种植策略 | 建模秘籍文章代码思路大全

铛铛!小秘籍来咯! 小秘籍团队独辟蹊径,运用等多目标规划等强大工具,构建了这一题的详细解答哦! 为大家量身打造创新解决方案。小秘籍团队,始终引领着建模问题求解的风潮。 抓紧小秘籍,我们出发…

过滤器(Filter)和拦截器(Interceptor)

在Web开发中,过滤器(Filter)和拦截器(Interceptor)都是重要的组件,它们都可以对HTTP请求进行预处理、后处理以及一些额外的操作。然而,它们之间在多个方面存在明显的区别 1. 运行位置 过滤器&…

在python项目的docker镜像里使用pdm管理依赖

前言 在 DjangoStarter 项目中,我已经使用 pdm 作为默认的包管理器,不再直接使用 pip 所以部署的时候 dockerfile 和 docker-compose 配置也得修改一下。 dockerfile 首先修改一下 dockerfile ARG PYTHON_BASE3.11FROM python:$PYTHON_BASE# 设置 pytho…

高并发内存池(一):项目介绍与定长内存池的实现

目录​​​​​​​ 项目介绍 池化技术 内存池 内存碎片 malloc工作原理 定长内存池 申请内存 释放内存 定位new VirtualAlloc函数 封装VirtualAlloc 定长内存池的最终代码 项目介绍 项目原型:goole的开源项目tcmalloc(Thread-Caching Mal…

9.5 面试题

1、多继承下,地址转换问题: 在 C 中,如果类 C 是多继承自 A 和 B,在执行强制类型转换时,地址值是否发生改变,取决于内存布局和继承方式。具体来说: 1. 标准布局下(无虚继承&#x…

CIOE中国光博会&电巢科技即将联办“智能消费电子创新发展论坛”

在科技浪潮汹涌澎湃的当下,从通信领域的高速光传输,到消费电子中的高清显示与先进成像技术,光电技术的应用范围不断拓展且日益深化。而AIGC 凭借其丰富的内容供给与个性化反馈能力,正为新一代消费电子及智能穿戴产品开辟崭新的发展…

前端请求的路径baseURL怎么来的 ?nodejs解决cors问题的一种方法

背景:后端使用node.js搭建,用的是express 前端请求的路径baseURL怎么来的 ? 前后端都在同一台电脑上运行,后端的域名就是localhost,如果使用的是http协议,后端监听的端口号为3000,那么前端请求…

#include <iostream>介绍

在C编程中&#xff0c;#include <iostream> 是一个非常重要的预处理指令&#xff0c;用于引入输入输出流库。以下是对 #include <iostream> 的详细介绍&#xff1a; 1. 作用 #include <iostream> 指令的主要作用是使程序能够使用标准输入输出流的功能。它包…

S3C2440开发板:时钟,PWM定时器控制蜂鸣器发声

时钟 时钟和电源管理模块由三部分组成&#xff1a;时钟控制&#xff0c;USB 控制和电源控制。 S3C2440A 中的时钟控制逻辑可以产生必须的时钟信号&#xff0c;包括 CPU 的 FCLK&#xff0c;AHB 总线外设的 HCLK 以及 APB 总线外设的 PCLK。S3C2440A 包含两个锁相环&#xff08…

VBA进行excel坐标转换

在Excel里利用坐标绘图时&#xff0c;可以比较容易想到采用数据透视表&#xff0c;但是数据透视表生成的图不可更改&#xff0c;因此本案例采用VBA进行坐标变换而不改变原始值来转换图像&#xff0c;即实现图像的左右翻转和上下翻转&#xff0c;如下图所示&#xff0c;选择map的…

redis的持久化RDB和AOF

redis的持久化有RDB和AOF两种方式。RDB(Redis Database)是redis在指定间隔将当前时间点的内存数据快照保存成一个二级制rdb文件。AOF(Append Only File)是将每一条写指令写入到特定日志文件&#xff0c;然后当服务重启时通过回放这些指令来恢复原来的数据集。redis可以同时开启…

fastadmin 文件上传腾讯云

1-安装腾讯云SDK composer require qcloud/cos-sdk-v5 2-腾讯云配置 <?phpnamespace app\common\controller;use Qcloud\Cos\Client; use think\Controller; use think\Db;class Tencent extends Controller {/*** 上传文件* param $config* param $key* return array*/p…

Linux下快速判断当前终端使用的是bash or csh

在Linux下设置环境变量的时候&#xff0c;可能你也遇到过export: Command not found一类的错误。这是因为当前终端使用的不是bash&#xff0c;如何快速判断当前终端使用的是哪种类型的shell呢&#xff1f; echo $0判断shell类型 最简单的方法就是在终端输入echo $0&#xff0…

每日一题,零基础入门FPGA——工程师在线精讲来咯

传送门&#xff1a;zzfpga.com/StudentPlatform/Train/StudentArticleDetails?id149

M3U8工作原理以及key解密视频流详解

文章目录 前言一、M3U8是什么&#xff1f;二、HLS—M3U8的工作原理1.分段视频流2.生成播放列表3.客户端请求和解析4.片段下载和播放 三、.m3u8文件内部是什么样的&#xff1f;四、简单介绍下AES-128算法五、拿到KEY后如何去解密&#xff1f;1.手动解密.ts文件2.前人栽树&#x…

深度学习速通系列:Bert模型vs大型语言模型(LLM)

什么情况用Bert模型&#xff0c;什么情况用LLaMA、ChatGLM类大模型&#xff1f; 选择使用Bert模型、LLaMA模型或ChatGLM模型等大型语言模型&#xff08;LLM&#xff09;时&#xff0c;应根据具体的应用场景、任务需求、资源限制和预期目标来决定。以下是更详细的指导原则: Be…

WPF 利用视觉树获取指定名称对象、指定类型对象、以及判断是否有验证错误

1.利用视觉树获取指定名称对象 /// <summary> /// Finds a Child of a given item in the visual tree. /// </summary> /// <param name"parent">A direct parent of the queried item.</param> /// <typeparam name"T">T…

spring security 如何解决跨域的

一、什么是 CORS CORS(Cross-Origin Resource Sharing) 是由 W3C制定的一种跨域资源共享技术标准&#xff0c;其目就是为了解决前端的跨域请求。在JavaEE 开发中&#xff0c;最常见的前端跨域请求解决方案是早期的JSONP&#xff0c;但是JSONP 只支持 GET 请求&#xff0c;这是一…

深度学习从入门到精通——基于unet++算法实现细胞分割

模型定义 import torch from torch import nn__all__ [UNet, NestedUNet]class VGGBlock(nn.Module):def __init__(self, in_channels, middle_channels, out_channels):super().__init__()self.relu nn.ReLU(inplaceTrue)self.conv1 nn.Conv2d(in_channels, middle_channe…