在编写完Log类和监听类之后,终于要回到正轨上来了。我们继续开始写UIExcutor的实现类。

PS:如果你想让你的报告更加美观一些。推荐使用reportNG这个jar包。

  在项目中导入reportng-1.1.5.jar,这个jar包网上可以找到。可是具体在哪里下载的我也忘了。。。。。这里先提一下,到后面我们再来详细的说明。

还记得我们之前写过的UIExcutor的接口吗?我们在这里需要一个一个的实现接口中的方法。(一个都不能少!)

package webui.xUtils;

import java.util.Set;

import org.openqa.selenium.Alert;
import org.openqa.selenium.By;
import org.openqa.selenium.JavascriptExecutor;
import org.openqa.selenium.NoSuchElementException;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.support.ui.ExpectedConditions;
import org.openqa.selenium.support.ui.WebDriverWait;
import org.testng.Reporter; public class UIExcutorImpl implements UIExcutor{
private WebDriver driver;
static logUtil logs = new logUtil(UIExcutorImpl.class);
public UIExcutorImpl(WebDriver driver) {
this.driver = driver;
}
public WebDriver getDriver() {
return driver;
}
public void setDriver(WebDriver driver) {
this.driver = driver;
}
//这里对接口中的方法进行重写,意味着当我们执行这些方法的时候,可以将过程步骤作为log记录下来,并加入report中。
@Override
public void click(Position position) throws Exception {
WebElement ele = getElement(position);
ele.click();
logs.info("click元素:"+position.getPositionName()+"["+"By."+position.getType()+":"+position.getPath()+"] success!");
//在Report中显示相应的log
Reporter.log("click元素:"+position.getPositionName()+"["+"By."+position.getType()+":"+position.getPath()+"] success!");
} @Override
public void sendKey(Position position, String value) throws Exception {
WebElement ele = getElement(position);
ele.sendKeys(value);
logs.info("input输入:"+position.getPositionName()+"["+"By."+position.getType()+":"+position.getPath()+" value:"+value+"]");
Reporter.log("input输入:"+position.getPositionName()+"["+"By."+position.getType()+":"+position.getPath()+" value:"+value+"]");
} @Override
public String getText(Position position) throws Exception {
WebElement ele = getElement(position);
String txt = ele.getText();
return txt;
} @Override
public WebElement getElement(Position position) throws Exception {
WebElement ele = null;
String path = position.getPath();
    //这里私人指定的时间是3秒等待,用于页面元素的加载,需要根据实际情况进行设置
WebDriverWait wait = new WebDriverWait(driver, 3);
logs.info("查找元素:"+position.getPositionName()+"["+"By."+position.getType()+":"+path+"]");
Reporter.log("查找元素:"+position.getPositionName()+"["+"By."+position.getType()+":"+path+"]");
    //使用switch-case分支语句来分别对应selenium八种定位方式
switch(position.getType()) {
case xpath:
try {
wait.until(ExpectedConditions.presenceOfAllElementsLocatedBy(By.xpath(path)));
ele = driver.findElement(By.xpath(path));
}catch (Exception e) {
logs.error("findElment ByXpath:" + path + "-failed! NoSuchElement");
Reporter.log("findElment ByXpath:" + path + "-failed! NoSuchElement");
}
break;
case id:
try {
wait.until(ExpectedConditions.presenceOfAllElementsLocatedBy(By.id(path)));
ele = driver.findElement(By.id(path));
}catch (Exception e) {
logs.error("findElement ById" + path + "-failed! NoSuchELement");
Reporter.log("findElement ById" + path + "-failed! NoSuchELement");
}
break;
case className:
try {
wait.until(ExpectedConditions.presenceOfAllElementsLocatedBy(By.className(path)));
ele = driver.findElement(By.className(path));
}catch (Exception e) {
logs.error("findElement ByClassName" + path + "-failed! NoSuchElement");
Reporter.log("findElement ByClassName" + path + "-failed! NoSuchElement");
}
break;
case linkText:
try {
wait.until(ExpectedConditions.presenceOfAllElementsLocatedBy(By.linkText(path)));
ele = driver.findElement(By.linkText(path));
}catch (Exception e) {
logs.error("findElement ByLinkText" + path + "-failed! NoSuchElement");
Reporter.log("findElement ByLinkText" + path + "-failed! NoSuchElement");
}
break;
case name:
try {
wait.until(ExpectedConditions.presenceOfAllElementsLocatedBy(By.name(path)));
ele = driver.findElement(By.name(path));
}catch (Exception e) {
logs.error("findElement ByName" + path + "-failed! NoSuchElement");
Reporter.log("findElement ByName" + path + "-failed! NoSuchElement");
}
break;
case cssSelector:
try {
wait.until(ExpectedConditions.presenceOfAllElementsLocatedBy(By.cssSelector(path)));
ele = driver.findElement(By.cssSelector(path));
}catch (Exception e) {
logs.error("findElement ByCssSelector" + path + "-failed! NoSuchElement");
Reporter.log("findElement ByCssSelector" + path + "-failed! NoSuchElement");
}
case tagName:
try {
wait.until(ExpectedConditions.presenceOfAllElementsLocatedBy(By.tagName(path)));
ele = driver.findElement(By.tagName(path));
}catch (Exception e) {
logs.error("findElement ByTagName" + path + "-failed ! NoSuchElement");
Reporter.log("findElement ByTagName" + path + "-failed ! NoSuchElement");
}
case partialLinkText:
try {
wait.until(ExpectedConditions.presenceOfAllElementsLocatedBy(By.partialLinkText(path)));
ele = driver.findElement(By.partialLinkText(path));
}catch (Exception e) {
logs.error("findElement By partialLinkText" + path + "-failed ! NoSuchElement");
Reporter.log("findElement By partialLinkText" + path + "-failed ! NoSuchElement");
} default:
break;
}
return ele;
} @Override
public boolean isElementDisplayed(Position position) throws Exception {
WebElement ele = getElement(position);
boolean flag = ele.isDisplayed();
return flag;
} @Override
public void switchWindow(String winTitle) {
logs.info("切换windows窗口:" + winTitle);
Reporter.log("切换windows窗口:" + winTitle);
Set<String> handles = driver.getWindowHandles();
for (String handle : handles) {
if (handle.equals(driver.getWindowHandle())) {
continue;
} else {
driver.switchTo().window(handle);
if (winTitle.contains(driver.getTitle())) {
break;
} else {
continue;
}
}
}
} @Override
public void switchFrame(Position position) {
driver.switchTo().frame(position.getPath());
} @Override
public void waitElement(Position position , int sec) {
WebDriverWait wait = new WebDriverWait(driver, sec);
String add = position.getPath();
switch (position.getType()) {
case id:
wait.until(ExpectedConditions.presenceOfAllElementsLocatedBy(By.id(add)));
break;
case xpath:
wait.until(ExpectedConditions.presenceOfAllElementsLocatedBy(By.xpath(add)));
break;
case name:
wait.until(ExpectedConditions.presenceOfAllElementsLocatedBy(By.xpath(add)));
break;
case linkText:
wait.until(ExpectedConditions.presenceOfAllElementsLocatedBy(By.xpath(add)));
break;
case className:
wait.until(ExpectedConditions.presenceOfAllElementsLocatedBy(By.xpath(add)));
break;
case tagName:
wait.until(ExpectedConditions.presenceOfAllElementsLocatedBy(By.xpath(add)));
break;
case partialLinkText:
wait.until(ExpectedConditions.presenceOfAllElementsLocatedBy(By.xpath(add)));
break;
case cssSelector:
wait.until(ExpectedConditions.presenceOfAllElementsLocatedBy(By.xpath(add)));
break;
default:
break;
}
} @Override
public String getAlertText() {
String alertText = "";
try {
// webdriver对弹框的处理略坑,所以先等待2s再切换到弹框,否则可能无法切换
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
Alert alert = driver.switchTo().alert();
alertText = alert.getText();
alert.accept();
} catch (NoSuchElementException e) {
logs.error("no alert open,switch to alert failed");
Reporter.log("no alert open,switch to alert failed");
}
return alertText;
} @Override
//获取元素属性值(提供属性名,比如要获取什么属性(比如:value),这里就要输入什么的值)
public String getAttribute(Position position , String attributeName) throws Exception {
WebElement ele = getElement(position);
String value = ele.getAttribute(attributeName);
return value;
}
@Override
  //有些元素可以通过javaScript调用来强制点击某个元素
public void jsClick(Position position) throws Exception {
WebElement ele = getElement(position);
((JavascriptExecutor)driver).executeScript("arguments[0].click();", ele);
logs.info("JavaScript-click元素:"+position.getPositionName()+"["+"By."+position.getType()+":"+position.getPath()+"] success!");
Reporter.log("JavaScript-click元素:"+position.getPositionName()+"["+"By."+position.getType()+":"+position.getPath()+"] success!");
} }

通过以上的代码,对于之前的接口中的方法都进行了实现。

可以看出,我们实际上是对selenium提供的api进行了重写,加入了自己定义的内容。这是一个思路,即可以调用原生api来进行重写,实现自己的自定义内容。

那么页面元素操作的实现类完成了之后,是不是就可以开始自动化脚本的编写了呢?当然不是,我们还得考虑一个问题,就是浏览器。下次,我们会针对浏览器写一个类,进行浏览器的初始化。

基于Java+Selenium的WebUI自动化测试框架(五)------页面操作实现类的更多相关文章

  1. 基于Java+Selenium的WebUI自动化测试框架(八)-----读取元素(XML文件)

    我们继续回到自动化测试框架的主线上来,在前面的文章中,我们定义一个页面元素的主要参数有:路径,找寻方式,等待时间,名称,这个四个参数.另外,我们还需要考虑一个问题,就是网站的页面. 举个例子来说,如果 ...

  2. 基于Java+Selenium的WebUI自动化测试框架(一)---页面元素定位器

    对于自动化测试,尤其是UI的自动化测试.是很多做黑盒功能测试的同学,入门自动化测试一个最为直观的或者说最容易理解的途径之一. 对于手工测试和自动化测试的优劣,网上有很多论述,在这里不作展开讨论.但是, ...

  3. 基于Java+Selenium的WebUI自动化测试框架(十四)-----使用TestNG的Sample

    到目前为止,我们所写的东西,都是集中在如何使用Selenium和Java来定位和读取元素.那么,到底如何具体开展测试,如何实现参数化,如何实现判定呢?下面,我们来看看Java应用程序的测试框架吧. 当 ...

  4. 基于Java+Selenium的WebUI自动化测试框架(六)---浏览器初始化

    本篇我们来讨论,如何写一个浏览器初始化的类.在写之前,先思考一下,我们需要一个什么样的初始化? 先来看看使用原生的Java + selenium是怎么做的.(以firefox为例) System.se ...

  5. 基于Java+Selenium的WebUI自动化测试框架(十三)-----基础页面类BasePage(Excel)

    前面,我们讲了如何使用POI进行Excel的“按需读取”.根据前面我们写的BasePageX,我们可以很轻松的写出来基于这个“按需读取”的BasePage. package webui.xUtils; ...

  6. 基于Java+Selenium的WebUI自动化测试框架(十)-----读取Excel文件(JXL)

    之前,我们使用了读取XML文件的方式来实现页面元素的读取,并做成了基础页面类.下面,我们来进行一些扩展,通过Excel来读取页面元素. Excel的使用,大多数人应该都不陌生.那么Java读取Exce ...

  7. 基于Java+Selenium的WebUI自动化测试框架(九)-----基础页面类(BasePage)

    上篇我们写了java读取xml文件的类,实现了可以从xml文件读取元素的方式.那么,接下来我们需要考虑一个问题.我们拿了这些元素之后怎么去操作呢? 先来看看我们手工测试的时候是怎么进行的. 双击浏览器 ...

  8. 基于Java+Selenium的WebUI自动化测试框架(四)-----设置监听类

    基于上一篇的内容,这里我们开始写监听类Listener.我这里写监听类的思路是,继承TestListenerAdapter这个类,然后对其中的方法进行重写.网上也有很多资料,建议先学习一下,然后写出来 ...

  9. 基于Java+Selenium的WebUI自动化测试框架(三)------记录LOG

    在有了Position类和接口类之后,我们是不是立刻就要着手开始写实现类了呢?按照一般的顺序是这样.但是,我们这里先停一下.原因有二: 1)既然是写一个框架,我们希望总体的功能上是全面的.实现类中,我 ...

随机推荐

  1. 【原生JS插件】LoadingBar页面顶部加载进度条

    先展示一下已经实现的效果: 预览地址:http://dtdxrk.github.io/js-plug/LoadingBar/index.html 看到手机上的浏览器内置了页面的加载进度条,想用在pc上 ...

  2. 03点睛Spring4.1-scope

    转载:https://www.iteye.com/blog/wiselyman-2210377 3.1 scope scope描述spring容器是怎么样新建类的实例的(bean); 在spring中 ...

  3. PHPStudy后门事件分析

    PHP环境集成程序包phpStudy被公告疑似遭遇供应链攻击,程序包自带PHP的php_xmlrpc.dll模块隐藏有后门.经过分析除了有反向连接木马之外,还可以正向执行任意php代码. 影响版本 P ...

  4. Ubuntu 新装服务器部署流程

    1.设定时区 rm -f /etc/localtime cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime 2.配置apt-get源 sed -i ...

  5. socket编程(二)

    TCP下粘包问题 两种情况下会发生粘包. 1.发送端需要等缓冲区满才发送出去,造成粘包(发送数据时间间隔很短,数据了很小,会合到一起,产生粘包) 发送方:AB #其实放在缓存里没发送 发送方:B #其 ...

  6. nlp算法

    人工智能算法大体上来说可以分类两类:基于统计的机器学习算法(Machine Learning)和深度学习算法(Deep Learning) 总的来说,在sklearn中机器学习算法大概的分类如下: 1 ...

  7. [转帖]libev与libuv的区别

    libev与libuv的区别 https://www.cnblogs.com/charlesblc/p/6341280.html 参考: http://blog.csdn.net/w616589292 ...

  8. java通过jasper文件生成jpg图片

    iReport资料紧俏,整理好就赶紧传上来: 工具类:JpgExport public class JpgExportUtil { public static String Export(Map< ...

  9. Mybatis笔记4

    mybatis中多对多的步骤 示例:用户和角色,一个用户可以有多个角色,一个角色可以赋予多个用户 步骤: 建立两张表:用户表,角色表,让用户表和角色表具有多对多的关系,需要使用中间表,中间表中包含两张 ...

  10. 彻底关闭networkmanager

    chkconfig NetworkManager offsystemctl stop NetworkManagersystemctl disable NetworkManager