标签:
如果测试用例比较多,则当持续运行多个测试用例后,经常会出现模拟器崩溃或者Appium无法连接到该模拟器的情况出现。
经过分析,本人认为这应该是模拟器或者Appium的缺陷造成的,目前并没有直接的解决方案。
不过可以曲线救国,我的解决方案是:在开始测试时启动模拟器,在测试结束后关闭模拟器,这样虽然需要更多的时间,但这个问题确实不再出现了,时间有的是,可以让其在夜间自动启动执行就可以了。
在Settings中加入Process库,这个库是Robotframework自带的,写明即可。
*** Settings *** Library AppiumLibrary Library Process
启动和关闭模拟器的脚本如下:
StartEmulator Run Process emulator @xxx Sleep 180s EndEmulator Run Process tskill emulator-arm Run Process tskill adb
Sleep 180s的目的是等待模拟器完成启动过程,这个三分钟足够了。
调用tskill后杀死指定名称的进程,不多解释了。
这里再介绍下Suite Setup,Suite Teardown以及Test Setup和Test Teardown ,它们分别是两组关键字:Suite Setup表示在一组测试用例执行前执行,Suite Teardown表示在一组测试用例执行后再执行;Test Setup表示在每个测试用例执行前执行,Test Teardown表示在每个测试用例执行后再执行。一组测试用例写在同一个文件中。
在具体的测试脚本的文件的Settings中有如下脚本:
*** Settings *** Suite Setup StartEmulator Suite Teardown EndEmulator
版权声明:本文为博主原创文章,未经博主允许不得转载。
Appium+Robotframework实现Android应用的自动化测试-7:模拟器频繁挂掉的解决方案
标签:
原文地址:http://blog.csdn.net/wd168/article/details/46787855