测试中经常出现明明有控件或者文本,但是由于界面没有载入完成或者其他原因导致assert判断的结果失败。或者两次执行,一次成功,一次失败的情况。所以需要加入这些等待某些控件或者文本载入的方法,以加强程序执行的健壮性。

sleep是固定长度时间的等待,waitFor则是等待某个控件或者文本载入后再进行下一步操作。

故两者都能用的情况下,推荐waitFor

sleep,固定时间的等待

void sleep(int time)

让测试停止若干时间以便进行下一步操作

参数:

time-停止的时间,单位是毫秒,如sleep(2000),是停止了2秒钟

返回:

waitFor,等待特定的某个控件或者文本载入后再进行下一步操作

boolean waitForActivity ( Class<extends android.app.Activity > activityClass | String name [, int timeout])

等待某个activity载入以进行下一步操作

参数:

activityClass-定位activity的class

name-定位activity的名称

timeout-失效时间,如果过了这个时间就不再等待,认为失败。单位毫秒,默认20秒

返回:

true-在失效时间前出现了activity

false-过了失效时间仍未找到

boolean waitForView ( Class<T> viewClass [, int timeout, boolean scroll])

等待某个view载入以进行下一步操作,通过view的class定位

参数:

viewClass-定位view的class

timeout-失效时间,如果过了这个时间就不再等待,认为失败。单位毫秒,默认20秒

scroll-是否允许滚动搜索,true表示支持,false表示只能在当前屏幕内查找

返回:

true-在失效时间前出现了view

false-过了失效时间仍未找到

boolean waitForView (int id [, int minimumNumberOfMatches, int timeout, boolean scroll])

等待某个view载入以进行下一步操作,通过view的id定位

参数:

id-定位view的id

minimumNumberOfMatches-最小指定多少才可以往下进行,0表示1个或者多个

timeout-失效时间,如果过了这个时间就不再等待,认为失败。单位毫秒,默认20秒

scroll-是否允许滚动搜索,true表示支持,false表示只能在当前屏幕内查找

返回:

true-在失效时间前出现了view

false-过了失效时间仍未找到

boolean waitForView ( android.view.View.view  view [, int timeout, boolean scroll])

等待某个view载入以进行下一步操作,通过view名称定位

参数:

view-定位view的名称

timeout-失效时间,如果过了这个时间就不再等待,认为失败。单位毫秒,默认20秒

scroll-是否允许滚动搜索,true表示支持,false表示只能在当前屏幕内查找

返回:

true-在失效时间前出现了view

false-过了失效时间仍未找到

boolean waitForText (String text [, int minimumNumberOfMatches, int timeout, boolean scroll, boolean onlyVisible])

等待某个文本载入以进行下一步操作

参数:

text-等待的文本

minimumNumberOfMatches-最小指定多少才可以往下进行,0表示1个或者多个

timeout-失效时间,如果过了这个时间就不再等待,认为失败。单位毫秒,默认20秒

scroll-是否允许滚动搜索,true表示支持,false表示只能在当前屏幕内查找

onlyVisible-只有可见的才会被统计

返回:

true-在失效时间前出现了view

false-过了失效时间仍未找到

boolean waitForDialogToOpen([int timeout])

等待对话框打开

参数:

timeout-失效时间,如果过了这个时间就不再等待,认为失败。单位毫秒,默认20秒

返回:

true-在失效时间前打开了dialog

false-过了失效时间仍未打开

boolean waitForDialogToClose([int timeout])

等待对话框关闭

参数:

timeout-失效时间,如果过了这个时间就不再等待,认为失败。单位毫秒,默认20秒

返回:

true-在失效时间前关闭了dialog

false-过了失效时间仍未关闭

boolean waitForWebElement (By by [, int minimumNumberOfMatches, int timeout, boolean scroll])

等待某个web控件载入以进行下一步操作

参数:

by-定位web控件的by属性

minimumNumberOfMatches-最小指定多少才可以往下进行,0表示1个或者多个

timeout-失效时间,如果过了这个时间就不再等待,认为失败。单位毫秒,默认20秒

scroll-是否允许滚动搜索,true表示支持,false表示只能在当前屏幕内查找

返回:

true-在失效时间前出现了web控件

false-过了失效时间仍未找到

boolean waitForFragmentById (int id [, int timeout])

等待Fragment载入以进行下一步操作,以id定位Fragment

参数:

id-定位Fragment的id

timeout-失效时间,如果过了这个时间就不再等待,认为失败。单位毫秒,默认20秒

返回:

true-在失效时间前出现了Fragment

false-过了失效时间仍未找到

boolean waitForFragmentByTag (String id [, int timeout])

等待Fragment载入以进行下一步操作,以tag定位Fragment

参数:

tag-定位Fragment的tag

timeout-失效时间,如果过了这个时间就不再等待,认为失败。单位毫秒,默认20秒

返回:

true-在失效时间前出现了Fragment

false-过了失效时间仍未找到

boolean waitForLogMessage (String logMessage [, int timeout])

等待日志信息载入以进行下一步操作

参数:

logMessage-等待加载的日志

timeout-失效时间,如果过了这个时间就不再等待,认为失败。单位毫秒,默认20秒

返回:

true-在失效时间前出现了logMessage

false-过了失效时间仍未找到

boolean waitForCondition (Condition condition, int timeout)

等待某种条件加载以进行下一步操作

参数:

condition-需要满足的条件

timeout-失效时间,如果过了这个时间就不再等待,认为失败。单位毫秒,默认20秒

返回:

true-在失效时间前出现了满足condition的条件

false-过了失效时间仍未找到

注:Condition是一个interface,里面只有一个方法isSatisfied () ,用于多条件的等待

【转载:http://blog.csdn.net/tt75281920/article/details/26947017】

Robotium API -- 等待执行的方法sleep、waitFor的更多相关文章

  1. ASP.NET Web API 控制器执行过程(一)

    ASP.NET Web API 控制器执行过程(一) 前言 前面两篇讲解了控制器的创建过程,只是从框架源码的角度去简单的了解,在控制器创建过后所执行的过程也是尤为重要的,本篇就来简单的说明一下控制器在 ...

  2. Web jquery表格组件 JQGrid 的使用 - 4.JQGrid参数、ColModel API、事件及方法

    系列索引 Web jquery表格组件 JQGrid 的使用 - 从入门到精通 开篇及索引 Web jquery表格组件 JQGrid 的使用 - 4.JQGrid参数.ColModel API.事件 ...

  3. Android常用控件及对应Robotium API

    最近发现Android控件不熟悉,看Robotium的API都费劲. 常用Android控件: 控件类型 描述 相关类 Button 按钮,可以被用户按下或点击,以执行⼀个动作 Button Text ...

  4. 使用ASP.NET Web Api构建基于REST风格的服务实战系列教程【五】——在Web Api中实现Http方法(Put,Post,Delete)

    系列导航地址http://www.cnblogs.com/fzrain/p/3490137.html 前言 在Web Api中,我们对资源的CRUD操作都是通过相应的Http方法来实现——Post(新 ...

  5. 微信JS-SDK“分享信息设置”API及数字签名生成方法(NodeJS版本)

    原文:微信JS-SDK"分享信息设置"API及数字签名生成方法(NodeJS版本) 先上测试地址以示成功: 用微信打开下面地址测试 http://game.4gshu.com/de ...

  6. Web Api中实现Http方法(Put,Post,Delete)

    在Web Api中实现Http方法(Put,Post,Delete) 系列导航地址http://www.cnblogs.com/fzrain/p/3490137.html 前言 在Web Api中,我 ...

  7. 如何同时完成多个ajax之后再执行某个方法 ? 使用$.when().done();

    jQuery中的$.when()方法比较复杂,这里不作全面讲解,只写一个同时完成多个ajax请求后执行操作的方法. 有时候我们需要等待多个ajax执行完以后,再执行某个操作. 写法如下: $.when ...

  8. 多线程--wait()和notify(),Thread中的等待和唤醒方法

    package com.thread.test; public class SimpleMN { final static Object object = new Object(); public s ...

  9. 基于DOMContentLoaded实现文档加载完成后执行的方法

    我们有时可能需要一些在页面加载完成之后执行的方法,其实js原生就提供了onload方法,所以我们最简单的办法就是直接给onload赋值一个函数,在页面加载完成之后就会自动执行 widnow.onloa ...

随机推荐

  1. (转)PHP正则表达式的快速学习方法

    1.入门简介 简单的说,正则表达式是一种可以用于模式匹配和替换的强有力的工具.我们可以在几乎所有的基于UNIX系统的工具中找到正则表达式的身影,例如,vi编辑器,Perl或PHP脚本语言,以及awk或 ...

  2. Active控件有关问题

    ActiveX 控件是允许网站提供视频等内容的网站. 当你浏览 Web 时,它们允许你使用工具栏.股票代号.视频和其它内容. 但是,这些程序有时可能出现问题,或者向你提供不需要的内容. 在某些情况下, ...

  3. 键盘数字对应的ASCII码(keycode码)

    keycode 1 = 鼠标左键keycode 2 = 鼠标右键keycode 3 = Cancelkeycode 4 = 鼠标中键keycode 8 = BackSpace keycode 9 = ...

  4. java记事本

    新知识点 1.撤销 textArea添加一个实现监听接口的类(添加了之后可以一直监视着添加的删除的情况,以便来撤销 textArea.getDocument().addUndoableEditList ...

  5. mysql启动不了:ERROR 2002 (HY000): Can’t connect to local MySQL server through socket

    ps aux |grep mysql kill所有列出的进程,然后重启 service mysql start 原因有可能是mysqld没启动:service mysqld start. 持续出现此问 ...

  6. 使用xshell出现乱码

    用xshell链接Linux出现乱码: 解决方法: 先查看Linux支持的字符类型是否为如下类型 如果是,则找到菜单中的文件选项,并在选项中找到属性: 单击属性选项,找到终端,将编码设置为UTF-8: ...

  7. 如何写angularJS模块

    angularJS中提供模块的概念,供我们把代码封装在模块单元中,使用模块能给我们带来的好处 保持全局命名空间的清洁 易于在不同应用间复用代码 demo.html <!doctype html& ...

  8. 《asp.net mvc3 高级编程》第四章 模型

    一,建立简单的Model 在Models文件夹上右击鼠标,选择“添加”,“类”,如下图所示: 建立三类相关联的类代码如下: public class Album { public virtual in ...

  9. js中的 window.location、document.location、document.URL 对像的区别(转载)

    原文:http://www.cr173.com/html/18417_1.html 当我们需要对html网页进行转向的时候或是读取当前网页的时候可以用到下面三个对像: window.location. ...

  10. [HTML5 Canvas学习] 基础知识

    HTML5 canvas元素通过脚本语言(通常是Javascript) 绘制图形, 它仅仅是一个绘图环境,需要通过getContext('2d')方法获得绘图环境对象,使用绘图环境对象在canvas元 ...