ExpectedConditions API
使用
public boolean isPresent(String xpath, int waitingTimeInSec) {
try {
WebDriverWait wait = new WebDriverWait(webDriver, waitingTimeInSec);
wait.until(ExpectedConditions.presenceOfAllElementsLocatedBy(By.xpath(xpath)));
} catch (NoSuchElementException e) {
return false;
}
return true;
}
文档
方法名 | 功能 |
---|---|
titleIs( String title) | 判断当前页面的title是否精确等于预期 |
titleContains( String title) | 判断当前页面的title是否包含预期字符串 |
urlToBe( String url) | 判断当前页面的url是否精确等于预期 |
urlContains( String fraction) | 判断当前页面的url是否包含预期字符串 |
urlMatches( String regex) | 字符串正则表达式 |
presenceOfElementLocated( By locator) | 判断元素是否出现,只要有一个元素出现,就通过。(代表在不代表可见)判断是否至少有 1 个元素存在于 dom 树中。举个例子,如果页面上有 n 个元素的 class 都是’column-md-3’,那么只要有 1 个元素存在,这个方法就返回 True。 |
presenceOfElementsLocated( By locator) | 判断元素是否出现,必须所有符合条件的元素都加载出来,才通过。 |
elementIfVisible(WebElement element) | 如果给定元素是可见的且具有非零大小,否则为null |
presenceOfAllElementsLocatedBy( By locator) | 判断元素是否出现。 |
visibilityOfElementLocated( By locator) | 传入类型为:locator 判断某个元素是否可见. 可见代表元素非隐藏,并且元素宽和高都不等于 |
visibilityOfAllElementsLocatedBy( By locator) | 判断某组元素是否可见 |
visibilityOfAllElements(final List elements) | 传入类型为:element 判断某个元素是否可见. 可见代表元素非隐藏,并且元素宽和高都不等于 |
textToBePresentInElement( WebElement element, String text) | 判断某个元素中的text是否包含了预期的字符串; |
textToBePresentInElement(By locator, String text) | 判断某个元素中的 text 是否 包含 了预期的字符串 |
textToBePresentInElementLocated(final By locator, final String text) | 判断某个元素中的 text 是否 包含 了预期的字符串 |
textToBePresentInElementValue( WebElement element, String text) | 判断某个元素中的 value 属性是否包含 了预期的字符串 |
textToBePresentInElementValue(final By locator, final String text) | 判断某个元素中的 value 属性是否包含 了预期的字符串 |
frameToBeAvailableAndSwitchToIt(final String frameLocator) | 断该 frame 是否可以 switch进去,如果可以的话,返回 True 并且 switch 进去,否则返回 False |
frameToBeAvailableAndSwitchToIt(final By locator) | 断该 frame 是否可以 switch进去,如果可以的话,返回 True 并且 switch 进去,否则返回 False |
invisibilityOfElementLocated(final By locator) | 某个元素中是否不存在于dom树或不可见; |
invisibilityOfElementWithText(final By locator, final String text) | 判断带有文本的元素要么不可见,要么文本不存在于元素上 |
elementToBeClickable(final By locator) | 判断某个元素中是否可见并且是enable的,这样的话才叫clickable; |
elementToBeClickable(final WebElement element) | 判断某个元素中是否可见并且是enable的,这样的话才叫clickable; |
stalenessOf(final WebElement element) | 判断一个元素是否仍在DOM中,传入WebElement对象,可以判断页面是 否刷新了。 |
refreshed(final ExpectedCondition condition) | |
elementToBeSelected(WebElement element) | 页面元素处于被选中状态 |
elementSelectionStateToBe( WebElement element, boolean selected) | 判断某个元素的选中状态是否符合预期,传入element |
elementToBeSelected(By locator) | 判断某个元素是否被选中了,一般用在下拉列表; |
elementSelectionStateToBe(final By locator, final boolean selected) | 判断某个元素的选中状态是否符合预期,传入locator |
alertIsPresent() | 判断页面上是否存在alert。 |
not(final ExpectedCondition<?> condition) | |
WebElement findElement(By by, WebDriver driver) | |
List findElements(By by, WebDriver driver) | |
isElementPresent(By.id("xxx") |
Refer
https://blog.csdn.net/kuangjuelian229/article/details/89426477
ExpectedConditions API的更多相关文章
- selenium之ExpectedConditions类
API中对于该类的介绍:Canned ExpectedConditions which are generally useful within webdriver tests.很笼统,大概意思就是在w ...
- 5.6 WebDriver API实例讲解(16-30)
16.操作单选框 被测试的网页为Demo1. Java语言版本的API实例代码: public static void operateRadio(){ driver.get("file:// ...
- Selenium 2.0 WebDriver 自动化测试 使用教程 实例教程 API快速参考
Selenium 2.0 WebDriver 自动化测试 使用教程 实例教程 API快速参考 //System.setProperty("webdriver.firefox.bin" ...
- WebDriver API 实例详解(三)
二十一.模拟鼠标右键事件 被测试网页的网址: http://www.sogou.com Java语言版本的API实例代码: package test; import org.testng.annota ...
- UI“三重天”之selenium--常用API和问题处理(三)
Selenium常用API: 前面两篇示例代码中用到了一些selenium的API方法,例如定位元素的八种方法.访问url.等待.操作浏览器.获取title.点击.清理等等. 有关于selenium的 ...
- 干货来袭-整套完整安全的API接口解决方案
在各种手机APP泛滥的现在,背后都有同样泛滥的API接口在支撑,其中鱼龙混杂,直接裸奔的WEB API大量存在,安全性令人堪优 在以前WEB API概念没有很普及的时候,都采用自已定义的接口和结构,对 ...
- 12306官方火车票Api接口
2017,现在已进入春运期间,真的是一票难求,深有体会.各种购票抢票软件应运而生,也有购买加速包提高抢票几率,可以理解为变相的黄牛.对于技术人员,虽然写一个抢票软件还是比较难的,但是还是简单看看123 ...
- 几个有趣的WEB设备API(二)
浏览器和设备之间还有很多有趣的接口, 1.屏幕朝向接口 浏览器有两种方法来监听屏幕朝向,看是横屏还是竖屏. (1)使用css媒体查询的方法 /* 竖屏 */ @media screen and (or ...
- html5 canvas常用api总结(三)--图像变换API
canvas的图像变换api,可以帮助我们更加方便的绘画出一些酷炫的效果,也可以用来制作动画.接下来将总结一下canvas的变换方法,文末有一个例子来更加深刻的了解和利用这几个api. 1.画布旋转a ...
随机推荐
- js jquery 动态添加表格
for循环将你要添加的标签写上,然后直接var talbeAdd=""for(){ tableAdd+="<tr><td>这儿写你要添加的内容&l ...
- 4.ID主键生成策略
保证唯一性(auto_increment) 一.xml方式 <?xml version="1.0"?> <!DOCTYPE hibernate-mapping P ...
- python3中OS模块
os模块 OS模块简单的来说它是一个Python的系统编程的操作模块,可以处理文件和目录这些我们日常手动需要做的操作. 可以查看OS模块的帮助文档: import os:#导入os模块 help(os ...
- 第九章、import 和from ...import
目录 第九章.import 和from ...import 一.import和 from ...import ... 二.import模块名 第九章.import 和from ...import 一. ...
- 微信小程序开发(一)创建一个小程序Hello World!
开发微信小程序并不是很难,网上有很多小程序开发资料,尤其是微信官方的<小程序开发指南>最详细. 下面是我开发小程序的历程: 第一步,请前往https://mp.weixin.qq.com/ ...
- CSS属性(pading margin)
margin: margin:5px auto;意思上下为5,左右平均居中 margin-top: 20px; 上外边距 margin-right: 3 ...
- FLUSH TABLES WITH READ LOCK 获取锁的速度
最近有一台MySQL的从库老是报延迟,观察到:FLUSH TABLES WITH READ LOCK,阻塞了4个多小时,还有另外一条SQL语句select *,从现象上来看是select * 阻塞了f ...
- Rails 用Webpack安装Bootstrap(附录webpack使用)
Rails6将默认使用webpack代替asset: 本文讲述如何自己配置. 参考: https://getbootstrap.com/docs/4.1/getting-started/webpack ...
- Windows netsh命令的使用
Windows netsh命令 netsh(也被称为网络壳层),是一个存在于自微软 Windows 20000开始的所有Windows NT系列中的命令行工具. netsh允许本地或远程配置网络设备. ...
- PHP类的设计模式
单例模式 <?php class mysingle { private static $myinstance =null; private function __construct() { } ...