码迷,mamicode.com
首页 > 移动开发 > 详细

Appium+Robotframework实现Android应用的自动化测试-7:模拟器频繁挂掉的解决方案

时间:2015-07-07 14:53:45      阅读:141      评论:0      收藏:0      [点我收藏+]

标签:

如果测试用例比较多,则当持续运行多个测试用例后,经常会出现模拟器崩溃或者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

通过调用Process库的Run Process关键字来做到调用相关的程序。调用emulator就会启动模拟器,xxx是模拟器的名字,如下图所示:

技术分享

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!