----------------引子----------------
app自动化测试人员经常遇见的问题,第一:手机抛的异常导致脚本循环停止!!!!!!!!第二:app抛的异常导致脚本循环停止!!!!!,那么问题来了,如何做脚本控制才能解决以上问题呢?
在执行脚本的时候,手机抛的异常我们脚本是无法控制的,意思也就是我们catch不了的,针对手机本身throw的crash我们可以在正常的脚本执行下每次循环结束后执行下手机本身的操作,如 操作home键,操作back键,点击手机本身某个坐标等等
具体思路就是在正常脚本执行中插入操作手机操作:具体脚本如下
for i in range(1000): try: restartAppTotalTime = os.popen("adb shell am start -W -S PackName/ackName/.ActivityName| findstr TotalTime >> TotalTime.log") time.sleep(5) #print restartAppTotalTime.read(); for x in range(5): StartAppTOTALPss = os.popen("adb shell dumpsys meminfo -a PackName| findstr TOTAL >> StartAppTOTALPss.log") #print StartAppTOTALPss.read(); StartAppTOTALPss = os.popen("adb shell dumpsys meminfo -a PackName | findstr Native | findstr Heap >> StartAppNativePss.log") #print StartAppTOTALPss.read(); StartAppTOTALPss = os.popen("adb shell dumpsys meminfo -a PackName| findstr Dalvik | findstr Heap >> StartAppDalvikPss.log") #print StartAppTOTALPss.read(); restartAppCpuThr = os.popen("adb shell top -d 1 -n 2 -m 1 -s cpu | findstr PackName >> AppCpuThr.log") #print restartAppCpuThr.read(); time.sleep(3) #出现异常按home键--防止手机系统本身抛的异常弹框 HomeKeyStart = os.popen("adb shell input keyevent 3") #出现异常点击返回键退出APP程序--防止手机系统本身抛的异常弹框 BackKeyStart = os.popen("adb shell input keyevent 4") time.sleep(1) BackKeyEnd = os.popen("adb shell input keyevent 4")
如果系统throw的crash是一个系统的弹框,也可以确认弹框在手机的坐标位置,然后关闭这个弹框 可以用adb shell input tap X Y
具体如何确定X和Y值可以问度娘,度娘会告诉你用那些工具譬如ps等等~~~好了,以上就是解决手机本身throw的crash。
那么如果是app本身trhow的crash那么久容易简单多了!!!!
最简单直接粗暴的办法就是force-stop!!!~~~~
或者操作手机本身!!!具体代码如下
except Exception,e: print Exception,":",e print u"在没有出现异常的情况下执行的循环次数为:"+i #出现异常点击返回键退出APP程序 BackKeyStart = os.popen("adb shell input keyevent 4") time.sleep(1) BackKeyEnd = os.popen("adb shell input keyevent 4") #出现异常按home键 HomeKeyStart = os.popen("adb shell input keyevent 3") #强制杀死进程 StopApp = os.popen("adb shell am force-stop PackName") continue
那么又一个问题来了!!!
如何记录app本身再循环执行时出现的异常次数呢?
用的是print方法向文件中写入内容
import osos.chdir("/usr/tem")char="my name is test"f = open("test.txt","w")print >>f,char