2023年11月29日发(作者:)
Monkey log分析说明
以下主要针对在Android-Phone项目中进行Monkey log进行分析和说明,可以对bug提交
作为参考。
要求熟悉,应用的包名。也就是说那个应用包出现问题,该属于那个模块,应用包名是判
断依据。
1、 Null指针异常
空指针异常主要是有NullPointerException异常提示,在Monkey测试过程中,该信息一
般记录在 (locat中也有该信息)中。
如果Monkey命令被中断,说明有异常信息并且有对应的打印信息,可以看到如下信息,
说明几个问题:
A、该进程出现异常
B、异常信息主要是由于NullPointerException引起的,也就是出现了空指针,导致了
acore进程进入debug
C、具体的可以继续分析是由哪个函数的那一行导致的,如可以从
文件中的275行查找等。
//at ame(ScrollAnimate3
:275)
D、可能同一应用中存在多处的空指针异常,所以一旦出现空指异常后,可以分析和对比log信息,
如果不一致的话,需要把新的log信息也一同添加到bug中,如果log信息一直的话,则不需要
继续补充没有必要的log信息。
**************************************************************************
// CRASH: (pid 1339)
// Short Msg:
interException
// Long Msg: interException
// Build Label: android:FIH/msm7627_surf/msm7627_surf/F0X:1.6/DONUT/0001_0_020:e
ng/release-keys
// Build Changelist: -1
// Build Time: 1271397239
// ID:
// Tag: AndroidRuntime
// interException:
// at ame(
va:275)
// at chDraw(:605)
// at ild(:1524)
// at chDraw(:1256)
// at chDraw(:258)
// at ild(:1524)
// at chDraw(:1256)
// at (:6329)
// at (:352)
// at ild(:1526)
// at chDraw(:1256)
// at (:6329)
// at (:352)
// at indow$(:1901)
// at (:1333)
// at mTraversals(:1098)
// at Message(:1618)
// at chMessage(:99)
// at (:123)
// at (:4203)
// at Native(:-2)
// at (:521)
// at Init$(:799)
// at (:557)
// at (:-2)
** System appears to have crashed at event 7908 of 5000000 using seed 0
2、 debug异常
debug异常主要是由于应用程序本身的错误导致的异常。在Monkey测试过程中,该信
息同样记录在 (locat中也有该信息)中。一般情况下,出现的该问题,很可能在
手动测试时也可以测试到。
A、 r该进程进入debug
B、 出现的是IllegalStateException异常,该异常一般多是传递的参数非法或被多次调
用时出现的异常
C、 Bug信息提交时,详细信息中一般应该包含如下的log信息,方便开发人员分析和
定位。
************************************************************************
// CRASH: r (pid 5683)
// Short Msg: Connection is not open
// Long Msg: lStateException: Connection is not open
// Build Label: android:FIH/msm7627_surf/msm7627_surf/F0X:1.6/DONUT/0001_0_020:eng/release-keys
// Build Changelist: -1
// Build Time: 1271397239
// ID:
// Tag: AndroidRuntime
// lStateException: Connection is not open
// at Open(AndroidHttpClien
:153)
// at ketTimeout(AndroidHtt
:195)
// at tpConnection(:364)
// at sRequests(:225)
// at (:116)
** System appears to have crashed at event 34155 of 5000000 using seed 0**
3、 低内存异常
低内存异常一般情况下,主要表现在出现OutOfMemoryError异常或者提示
Out of memory,其后果同样表现为抛出OutOfMemoryError异常或者是通过
kill process 来杀掉部分进程以释放内存空间,当然如果被kill点关键的进程的话,也就
可能导致部分应用会自动的退出。出现该情况时,主要是在进行频繁的进行大量的操作
导致的,所以使用手动的方式也是可能进行重现的。
A、 该进程出现的异常
B、 出现的是异常,该异常一般多频繁的操作(即多次调用某个函数,
OutOfMemoryError
存在申请变量空间未释放)导致的
C、 Bug信息提交时,详细信息中同样应该包含如下的log信息,方便开发人员分析和
定位。
// CRASH: (pid 1581)
// Short Msg: bitmap size exceeds VM budget
// Long Msg: emoryError: bitmap size exceeds VM budget
// Build Label: android:FIH/msm7627_surf/msm7627_surf/F0X:1.6/DONUT/0001_0_020:eng/release-keys
// Build Changelist: -1
// Build Time: 1271397239
// ID:
// Tag: AndroidRuntime
// emoryError: bitmap size exceeds VM budget
// at Create(:-2)
// at Bitmap(:464)
// at Bitmap(:431)
// at ScaledBitmap(:336)
// at leBitmapBG(:2354)
// at (:2365)
// at ild(:1526)
// at chDraw(:1256)
// at (:6329)
// at ild(:1526)
// at chDraw(:1256)
// at (:6329)
// at (:352)
// at ild(:1526)
// at chDraw(:1256)
// at (:6329)
// at (:352)
// at indow$(:1901)
// at (:1333)
// at mTraversals(:1098)
// at Message(:1618)
// at chMessage(:99)
// at Init$(:799)
// at (:557)
// at (:-2)
** System appears to have crashed at event 143290 of 100000000 using seed 0#
或者出现plog信息的最后出现如下log信息也可能存在同样问题:
<3>[56351.640641] Out of memory: kill process 14177 (app_process) score 247872 or a child
<3>[56351.641121] Killed process 14177 (app_process)
4、 操作无响应异常
操作无响应的问题,主要表现在Monkey运行过程中,出现某功能无响应,提示是否“强
制关闭“或“等待“,同时会打印出相应的log信息,如下:
A、 ecorder该进程出现的无响应
可以说明
B、 出现的是TimerOut异常,该异常一般出现时一般都会又keyDispatchingTimedOut
提示
C、 目前,uPhone手机中经常出现操作无响应的几个模块包括:clock、camera、
soundrecorder、broser等,根据开发人员分析其他模块也是有可能出现操作无响应
的,测试过程中,请多注意。
D、 出现无响应异常,一般情况下很难被修复,和发送事件的频率也是有关系的,从质
量上来要求的话,要求尽可能的减少出现操作无响应的频率和时间。
// NOT RESPONDING: ecorder (pid 1931)
ANR in process: ecorder (last in ecorder)
Annotation: keyDispatchingTimedOut
CPU usage:
Load: 8.24 / 8.41 / 8.25
CPU usage from 35911ms to 83ms ago:
ecorder: 4% = 3% user + 0% kernel / faults: 997 minor 43 maj
or
mediaserver: 2% = 2% user + 0% kernel / faults: 267 minor 3 major
: 2% = 0% user + 1% kernel / faults: 563 minor 194 major
system_server: 1% = 1% user + 0% kernel / faults: 1279 minor 5 major
al: 0% = 0% user + 0% kernel / faults: 180 minor 1 major
sensorserver_ya: 0% = 0% user + 0% kernel / faults: 47 minor 1 major
mmcqd: 0% = 0% user + 0% kernel
app_process: 0% = 0% user + 0% kernel / faults: 203 minor 1 major
ice: 0% = 0% user + 0% kernel / faults: 29 minor
kswapd0: 0% = 0% user + 0% kernel
gs: 0% = 0% user + 0% kernel / faults: 266 minor
port-bridge: 0% = 0% user + 0% kernel / faults: 19 minor
rpcrouter: 0% = 0% user + 0% kernel
: 0% = 0% user + 0% kernel / faults: 135 minor 8 major
TOTAL: 13% = 8% user + 4% kernel + 0% iowait
procrank:
PID Vss Rss Pss Uss cmdline
1209 35368K 25376K 15283K 14036K system_server
1342 32788K 24596K 14899K 14136K
……
// procrank status was 0
anr traces:
// meminfo status was 0
** System appears to have crashed at event 59034 of 5000000 using seed 0
5、 其他异常
A、 Restart System异常(系统重新启动),即log信息的最后几行会看到Restart System
的打印信息,说明手机被自动的重启或断掉,有几个方面的原因
1、 运行过程中,存在异常手机被自动重启
2、 手机在运行过程中,进入设置中的恢复出场设置,导致手机重启
3、 其他原因,如果手机后盖移动等
B、 RuntimeException等异常,同样的会在中可以看到相应的打印信息,
eException该问题多出现在操作无响应之后,或者是某应用的服务无
法启动或连接时,需要具体问题具体的分析
C、 StaleDataException、readException等异常, 在中可以看到相应的打印信息,
也会有相应的信息: ataException,该信息说明android的数据
库操作出现异常, 需要具体问题具体的分析
D、 IllegalArgumentException等异常,多少情况下为说明向函数传递了一个不正确或
不合法的参数需要具体问题具体的分析
E、 其他,带补充和分析说明
说明几点:
1、 log信息的分析,希望在bug信息的简述中能够明确说明清楚出现的是什么异常,具体
的log信息要单独添加到详细信息描述中,方便相关人员定位和查看。
2、 buy的提交,对于Monkey测试出现的问题:
a、 首先要求分析log信息
b、 再次要确认该bug是否已经提交?已经提交的bug和新运行出来的问题是否一致?
c、 如果不一致的话,是否属于同一问题,如空指针异常,是的话就把该问题的log信
息一起注释到bug信息中,并添加所有的log信息
d、 如果不一致的,也不属于同一问题的话,可以提交新的bug
3、 在java编程中,一般的异常都会抛出xxx Exception的信息,可以跟进xxx进行相关的
判断和分析,具体的异常则需要具体问题具体分析。
4、 以上为个人总结,有不足的请提出,我后续会继续维护和更新


发布评论