Selenium常用API:

前面两篇示例代码中用到了一些selenium的API方法,例如定位元素的八种方法、访问url、等待、操作浏览器、获取title、点击、清理等等。

有关于selenium的常用API在园子中有写的非常详细的文章。先贴大佬文章地址:https://www.cnblogs.com/Ming8006/p/5727542.html#c1.5。

对于几种用的比较多的地方再记录一下:

等待:

  显式等待:等待条件成立,再继续执行

  示例代码中含有显式等待: 

// Google's search is rendered dynamically with JavaScript.
// Wait for the page to load, timeout after 10 seconds
(new WebDriverWait(driver, 10)).until(new ExpectedCondition<Boolean>() {
public Boolean apply(WebDriver d) {
return d.getTitle().toLowerCase().startsWith("cheese!");
}
});

  官方文档说明:An explicit wait is code you define to wait for a certain condition to occur before proceeding further in the code. The worst case of this is Thread.sleep(), which sets the condition to an exact time period to wait. There are some convenience methods provided that help you write code that will wait only as long as required. WebDriverWait in combination with ExpectedCondition is one way this can be accomplished.【一句话概括“等待条件发生,再继续执行的代码”】 

WebDriver driver = new FirefoxDriver();
driver.get("http://somedomain/url_that_delays_loading");
WebElement myDynamicElement = (new WebDriverWait(driver, 10))
.until(ExpectedConditions.presenceOfElementLocated(By.id("myDynamicElement"))) 

  在抛出TimeoutException之前最多等待10s,或者在10s发现元素则返回。ExpectedCondition函数返回类型为true或非null对象。

  在实例中无需实例化:

WebDriverWait wait = new WebDriverWait(driver, 10);
WebElement element = wait.until(ExpectedConditions.elementToBeClickable(By.id("someid")));

  

  隐式等待:通过设定的时长等待页面元素加载完成,再执行;如果超过设定时间,则继续执行。

  官方文档示例代码:

WebDriver driver = new FirefoxDriver();
driver.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS);
driver.get("http://somedomain/url_that_delays_loading");
WebElement myDynamicElement = driver.findElement(By.id("myDynamicElement"));

  隐式等待方法关键字:implicitlyWait,直接调用即可。

  该实例等待10s,10s内元素加载完成则继续。

  

  强制等待:lang包下的Thread.sleep()方法,该方法应该也是debug用的最多的一种。

鼠标悬浮:

  在定位元素时,通常有些元素需要执行鼠标悬浮操作。

  使用action包下perform方法:  

    //鼠标悬浮
public void hover(String xpath) {
Actions action = new Actions(driver);
try {
action.moveToElement(driver.findElement(By.xpath(xpath))).perform();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

文件上传:

  文件上传可直接使用sendkeys传入需要上传文件的本地路径即可。

  切记:使用该方法,定位到的元素该标签必须是input类型、type=file属性,满足该条件即可用到该方法。  

driver.findElement(By.xpath(xpath)).sendKeys(filePath);

  filepath为本地文件路径及文件名。

截图:

  通常执行自动化测试脚本并非一帆风顺,或者发现流程上的一些错误等等,这个时候便需要增加一些截图,执行完成之后人为进行检查。

  官方文档给出了示例代码:  

import java.net.URL;

import org.openqa.selenium.OutputType;
import org.openqa.selenium.TakesScreenshot;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.remote.Augmenter;
import org.openqa.selenium.remote.DesiredCapabilities;
import org.openqa.selenium.remote.RemoteWebDriver; public class Testing { public void myTest() throws Exception {
WebDriver driver = new RemoteWebDriver(
new URL("http://localhost:4444/wd/hub"),
DesiredCapabilities.firefox()); driver.get("http://www.google.com"); // RemoteWebDriver does not implement the TakesScreenshot class
// if the driver does have the Capabilities to take a screenshot
// then Augmenter will add the TakesScreenshot methods to the instance
WebDriver augmentedDriver = new Augmenter().augment(driver);
File screenshot = ((TakesScreenshot)augmentedDriver).
getScreenshotAs(OutputType.FILE);
}
}

  可以看的出该处用到的是augment,中间的注释指的是如果驱动程序确实有能力进行截屏,然后Augmenter会将TaksCyEnScript方法添加到实例中。

调用JS:

  有时候需要利用JS来执行赋值、点击操作等。

  使用的是JavascriptExecutor,copy一下上方链接那位大佬的示例代码。 

    private static void runJSTest1(WebDriver driver) throws InterruptedException {
String js ="alert(\"hello,this is a alert!\")";
((org.openqa.selenium.JavascriptExecutor) driver).executeScript(js);
Thread.sleep(2000);
} private static void runJSTest2(WebDriver driver)
throws InterruptedException {
driver.get("https://www.baidu.com/");
String js ="arguments[0].click();";
driver.findElement(By.id("kw")).sendKeys("JAVA");
WebElement searchButton = driver.findElement(By.id("su"));
((org.openqa.selenium.JavascriptExecutor) driver).executeScript(js,searchButton);
Thread.sleep(2000);
}

浏览器滚动:

  一样使用的是JavascriptExecutor。  

JavascriptExecutor js = (JavascriptExecutor)driver;
String jscmd = "window.scrollTo(0," + height + ")";
js.executeScript(jscmd);

进入iframe子页面:

  通常一些元素会在iframe的标签下,那么便需要进入iframe再进行定位:  

WebElement frame = driver.findElement(By.xpath());
driver.switchTo().frame();

下拉框:

  针对下拉框selenium使用select。  

Select userselect = new Select(driver.findElement(By.xpath()));
userselect.selectByVisibleText();

切换浏览器窗口:

  webdriver中包含getWindowHandles方法。通过窗口标题去判断切换浏览器的窗口  

    public void switchWindow(String target) {
//创建 一个字符串便于之后存放句柄
String s = null;
//获取当前界面中的句柄
Set<String> handles = driver.getWindowHandles();
//循环尝试,找到目标浏览器的句柄
for(String t :handles) {
//遍历每一个句柄,判断窗口的标题是否含有预期字符
System.out.println(t);
if (driver.switchTo().window(t).getTitle().equals(target)) {
s = t;
}
}
//切换到目标句柄的界面中
try {
driver.switchTo().window(s);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

加载cookie:

//addcookie方法
driver.manage.addcookie()
//使用option读取用户文件,本地路径
ChromeOptions o = new ChromeOptions();
o.addArguments(“本地路径”)

后续~~~~

  

  

  

UI“三重天”之selenium--常用API和问题处理(三)的更多相关文章

  1. Selenium Web 自动化 - Selenium常用API

    Selenium Web 自动化 - Selenium常用API 2016-08-01 目录 1 对浏览器操作  1.1 用webdriver打开一个浏览器  1.2 最大化浏览器&关闭浏览器 ...

  2. Selenium常用API详解介绍

    转至元数据结尾   由 黄从建创建, 最后修改于一月 21, 2019 转至元数据起始   一.selenium元素定位 1.selenium定位方法 2.定位方法的用法 二.控制浏览器操作 1.控制 ...

  3. 详解介绍Selenium常用API的使用--Java语言(完整版)

    参考:http://www.testclass.net/selenium_java/ 一共分为二十个部分:环境安装之Java.环境安装之IntelliJ IDEA.环境安装之selenium.sele ...

  4. java selenium常用API(WebElement、iFrame、select、alert、浏览器窗口、事件、js) 一

     WebElement相关方法 1.点击操作 WebElement button = driver.findElement(By.id("login")); button.clic ...

  5. java selenium常用API汇总

    (WebElement.iFrame.select.alert.浏览器窗口.事件.js)     一 WebElement相关方法 1.点击操作 WebElement button = driver. ...

  6. Selenium2(java)selenium常用API 四

    WebElement相关方法 1.点击操作 WebElement button = driver.findElement(By.id("login")); button.click ...

  7. Selenium常用API用法示例集----下拉框、文本域及富文本框、弹窗、JS、frame、文件上传和下载

    元素识别方法.一组元素定位.鼠标操作.多窗口处理.下拉框.文本域及富文本框.弹窗.JS.frame.文件上传和下载 元素识别方法: driver.find_element_by_id() driver ...

  8. UI“三重天”之Selenium(一)

    关注一下UI自动化,记一记笔记. UI自动化的优缺点: 关于UI自动化的优缺点想来大家都有了解,优点:解放人力(并不是完全解放),用机器(涵盖工具.脚本等)代替人工完成测试工作,将测试用例转化为脚本实 ...

  9. Selenium常用API的使用java语言之19-调用JavaScript代码

    虽然WebDriver提供了操作浏览器的前进和后退方法,但对于浏览器滚动条并没有提供相应的操作方法.在这种情况下,就可以借助JavaScript来控制浏览器的滚动条.WebDriver提供了execu ...

随机推荐

  1. Shell脚本之无限循环的两种方法

    for #!/bin/bash ;i<;)) do let "j=j+1" echo "-------------j is $j ----------------- ...

  2. 前端引用公共html模块方案

    最近临时一个负责公司官网的妹纸请假,于是临时接手了下官网的项目,官网都是静态页面,算是很简单的,但发现页面挺多,而每个页面总有部分是和其他页面一模一样的,比如页头.页尾等,这样就导致一个地方的修改要在 ...

  3. c#LINQ表达树

    如果你已经用过LINQ, 你应该知道函数方式,以及包含的丰富的类库, 如果你仍不了解, 那根据下面的链接去熟悉一下 the LINQ tutorial,  lambda. 表达树提供了丰富的包含参数的 ...

  4. 99. Recover Binary Search Tree -- 找到二叉排序树中交换过位置的两个节点

    Two elements of a binary search tree (BST) are swapped by mistake. Recover the tree without changing ...

  5. 微信小程序scroll-view横向滚动

    官方文档给的代码复制下来发现无法滚动,没反应,使用css设置浮动属性也无效 官方没有给出css代码,横向需要设置两个css属性才行: white-space: nowrap; ----规定段落中的文本 ...

  6. python批量给云主机配置安全组

    python批量给云主机配置安全组 用公有云的思路去思考去实现一个安全稳定.可伸缩和经济的业务构架,云运维是有别与传统运维的,比如说了解公有云的都知道安全组的概念,安全组跟防火墙功能很相似,那我的机器 ...

  7. C语言对表达式的求值顺序不是明确规定的

    讨论区看到的 WA来自那些递归下降求解的代码. 第一种情况,使用|| 和 &&: 例如s为所给串 int getval() { switch(s[c_s++]) { case 'p': ...

  8. ipvsadm命令介绍

    为了更好的让大家理解这份命令手册,将手册里面用到的几个术语先简单的介绍一下: 1,virtual-service-address:是指虚拟服务器的ip 地址 2,real-service-addres ...

  9. ES选主策略

    ES版本5.6.3 1.整个流程的开始,实在node启动后触发的,Node.java中start()方法,通过调用ZenDiscovery.java中的doStart()方法,之后会调用startIn ...

  10. (转)ZooKeeper-3.3.4集群安装配置

    转载于 千与 的 http://blog.csdn.net/shirdrn/article/details/7183503 ZooKeeper是一个分布式开源框架,提供了协调分布式应用的基本服务,它向 ...