在编写完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. html5 导航栏切换效果

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. CentOS7为docker-ce配置阿里云镜像加速器

    一.找加速地址 https://promotion.aliyun.com/ntms/act/kubernetes.html 控制台 二.添加daemon.json 文件 vim /etc/docker ...

  3. 利用eclipse导入jar包到本地仓库

    如果不也不想用mvn install xxxxxx 后面跟一大堆的东东,可以让eclipse替代完成导入,看下图 File------->Import 大功告成,可见eclipse还没有废掉,至 ...

  4. 【GStreamer开发】GStreamer基础教程05——集成GUI工具

    目标 本教程展示了如何在GStreamer集成一个GUI(比如:GTK+).最基本的原则是GStreamer处理多媒体的播放而GUI处理和用户的交互. 在这个教程里面,我们可以学到: 如何告诉GStr ...

  5. JavaFX窗体设置无边框

    public void start(Stage stage) throws Exception { longStart(); Parent root = FXMLLoader.load(getClas ...

  6. css height:100%和height:auto的区别

    css height:100%和height:auto的区别 height:auto,是指根据块内内容自动调节高度.height:100%,是指其相对父块高度而定义的高度,也就是按照离它最近且有定义高 ...

  7. php实现文件与16进制相互转换

    php实现文件与16进制相互转换 <pre><?php/** * php 文件与16进制相互转换 * Date: 2017-01-14 * Author: fdipzone * Ve ...

  8. LeetCode 21. 合并两个有序链表(Merge Two Sorted Lists)

    21. 合并两个有序链表 21. Merge Two Sorted Lists 题目描述 将两个有序链表合并为一个新的有序链表并返回.新链表是通过拼接给定的两个链表的所有节点组成的. LeetCode ...

  9. [转帖]中国x86服务器市场H1出货量大幅下滑:浪潮、戴尔和华为排名前三

    中国x86服务器市场H1出货量大幅下滑:浪潮.戴尔和华为排名前三 https://www.cnbeta.com/articles/tech/900237.htm 市场开始下滑了.. 据IDC<2 ...

  10. ant 节点和属性

    任务和javac命令是相似,它编译两种类型的java文件1)没有被编译的java文件2)曾经编译过,但是class文件版本和当前对应的java文件版本不匹配的java文件. 1)javac命令支持的参 ...