1.创建类LogEventListener.java, 如下:

package com.demo;

import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.support.events.WebDriverEventListener; /**
* 用一个类扩展web driver自带的事件监听器,可以实现许多有趣的功能。
* 比如自动log
* a customer event listener
*/
public class LogEventListener implements WebDriverEventListener { public void beforeNavigateTo(String url, WebDriver driver) {
System.out.println("转向前URL: '" + url + "'");
} public void afterNavigateTo(String url, WebDriver driver) {
System.out.println("转向后URL:'" + url + "'");
} public void beforeChangeValueOf(WebElement element, WebDriver driver) {
System.out.println("Value of the:" + element.toString()
+ " before any changes made");
} public void afterChangeValueOf(WebElement element, WebDriver driver) {
System.out.println("Element value changed to: " + element.toString());
} public void beforeClickOn(WebElement element, WebDriver driver) {
System.out.println("试图单击对象: " + element.toString());
} public void afterClickOn(WebElement element, WebDriver driver) {
System.out.println("单击对象: " + element.toString());
} public void beforeNavigateBack(WebDriver driver) {
System.out.println("Navigating back to previous page");
} public void afterNavigateBack(WebDriver driver) {
System.out.println("Navigated back to previous page");
} public void beforeNavigateForward(WebDriver driver) {
System.out.println("Navigating forward to next page");
} public void afterNavigateForward(WebDriver driver) {
System.out.println("Navigated forward to next page");
} public void onException(Throwable error, WebDriver driver) {
System.out.println("Exception occured: " + error);
} public void beforeFindBy(By by, WebElement element, WebDriver driver) {
System.out.println("试图寻找对象 : " + by.toString());
} public void afterFindBy(By by, WebElement element, WebDriver driver) {
System.out.println("找到对象 : " + by.toString());
} /*
* non overridden methods of WebListener class
*/
public void beforeScript(String script, WebDriver driver) {
} public void afterScript(String script, WebDriver driver) {
} @Override
public void afterChangeValueOf(WebElement arg0, WebDriver arg1, CharSequence[] arg2) {
// TODO Auto-generated method stub } @Override
public void afterNavigateRefresh(WebDriver arg0) {
// TODO Auto-generated method stub } @Override
public void beforeChangeValueOf(WebElement arg0, WebDriver arg1, CharSequence[] arg2) {
// TODO Auto-generated method stub } @Override
public void beforeNavigateRefresh(WebDriver arg0) {
// TODO Auto-generated method stub } }

2.在创建WebEventListener监听类,如下:

package com.demo;

import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.support.events.AbstractWebDriverEventListener; public class WebEventListener extends AbstractWebDriverEventListener { public void beforeNavigateTo(String url, WebDriver driver) {
System.out.println("打开前url: '" + url + "'");
} public void afterNavigateTo(String url, WebDriver driver) {
System.out.println("打开url:'" + url + "'");
} public void beforeClickOn(WebElement element, WebDriver driver) {
System.out.println("试图单击对象: " + element.toString());
} public void afterClickOn(WebElement element, WebDriver driver) {
System.out.println("单击对象: " + element.toString());
} public void onException(Throwable error, WebDriver driver) {
System.out.println("Error occurred: " + error);
}
}

3.使用监听,如下:

package com.demo;

import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxDriver;
import org.openqa.selenium.support.events.EventFiringWebDriver;
import org.openqa.selenium.support.ui.ExpectedConditions;
import org.openqa.selenium.support.ui.WebDriverWait;
import org.testng.Assert;
import org.testng.annotations.AfterClass;
import org.testng.annotations.BeforeClass;
import org.testng.annotations.Test; public class ListenerTest { private WebDriver driver;
private EventFiringWebDriver e_driver;
private WebEventListener eventListener;
private WebDriverWait wait;
private String appURL = "http://www.google.com";
public int waitTime = 10;
private String headerText = "One account. All of Google.";
private String errMessage = "The email and password you entered don't match."; @BeforeClass()
public void setUp() { driver = new FirefoxDriver();
wait = new WebDriverWait(driver, waitTime); e_driver = new EventFiringWebDriver(driver); eventListener = new WebEventListener();
e_driver.register(eventListener); e_driver.manage().window().maximize();
e_driver.get(appURL);
} @Test
public void testEventsONE() {
System.out.println("***** Executing Test ONE ***** ");
e_driver.findElement(By.linkText("Gmail")).click();
String pageHeaderText = e_driver.findElement(By.tagName("h1")).getText();
Assert.assertTrue(pageHeaderText.equalsIgnoreCase(headerText));
} @Test
public void testEventsTWO() {
System.out.println("***** Executing Test Two ***** ");
e_driver.findElement(By.id("Email")).sendKeys("username");
e_driver.findElement(By.id("next")).click(); wait.until(ExpectedConditions.visibilityOfElementLocated(By.id("Passwd")));
e_driver.findElement(By.id("Passwd")).sendKeys("password");
e_driver.findElement(By.id("signIn")).click(); String pageHeaderText = e_driver.findElement(By.id("errormsg_0_Passwd")).getText();
Assert.assertTrue(pageHeaderText.equalsIgnoreCase(errMessage));
} @AfterClass()
public void tearDown() {
if (e_driver != null) {
e_driver.quit();
}
} }

运行查看控制台打印的信息

使用selenium监听每一步操作的更多相关文章

  1. Android View转为图片保存为本地文件,异步监听回调操作结果;

    把手机上的一个View或ViewGroup转为Bitmap,再把Bitmap保存为.png格式的图片: 由于View转Bitmap.和Bitmap转图片都是耗时操作,(生成一个1M的图片大约500ms ...

  2. 实时监听 mysql 操作,Linux 版

    效果 场景:某数据库新增了某条记录,服务器可以监听到变化的数据与操作,如 增加一条记录: id = 1009,name=''test,number = 11 服务器监听结果: 实现过程 测试过程:数据 ...

  3. Jquery系列:checkbox 获取值、选中、设置值、事件监听等操作

    <div id="divId" class="divTable"> <div class="tableBody"> ...

  4. C#WinForm窗体监听/拦截操作动作

    C#中的事件也是通过封装系统消息来实现的,如果你在WndProc函数中不处理该消息 那么,它会被交给系统来处理该消息,系统便会通过代理来实现鼠标单击的处理函数,因此你可以通过 WndProc函数来拦截 ...

  5. NSOperation操作依赖和监听

    1.操作依赖 NSOperation之间可以设置依赖来保证执行顺序 比如一定要让操作A执行完后,才能执行操作B,可以这么写 [operationB addDependency:operationA]; ...

  6. Java中用得比较顺手的事件监听

    第一次听说监听是三年前,做一个webGIS的项目,当时对Listener的印象就是个"监视器",监视着界面的一举一动,一有动静就触发对应的响应. 一.概述 通过对界面的某一或某些操 ...

  7. SD卡的监听

    摘要:在一般应用中,如果需要对占用空间比较大的文件操作,需要监听SD卡的状态,Android中对SD卡的监听状态操作步骤如下: 一.创建一个类继承于BroadcastReceiver public c ...

  8. Android的事件处理机制详解(二)-----基于监听的事件处理机制

    基于监听的事件处理机制 前言: 我们开发的app更多的时候是需要与用户的交互----即对用户的操作进行响应 这就涉及到了android的事件处理机制; android给我们提供了两套功能强大的处理机制 ...

  9. Servlet的监听

    Servlet监听 在<Servlet和Jsp>中我们使用了ServletConfig获取Servlet的初始配置,用ServletContext来获取整个Web应用的初始配置,但如果需要 ...

随机推荐

  1. DP上课覆盖知识点,POJ(1513)

    题目链接:http://poj.org/problem?id=1513 解题报告: 思路: 知识点从第二个开始扫,递推表达式是:minlec[i]=min(minlec[k])+1,并且要保证,tim ...

  2. linux命令之awk命令

    awk是一种编程语言,用于在linux/unix下对文本和数据进行处理.数据可以来自标准输入(stdin).一个或多个文件,或其它命令的输出.它支持用户自定义函数和动态正则表达式等先进功能,是linu ...

  3. IIS7.5如何限制某UserAgent 禁止访问

    参见Blocking Bots Based on User-Agenthttp://moz.com/ugc/blocking-bots-based-on-useragent http://server ...

  4. Spring boot 项目导出可执行jar

    配置文件中添加插件 <plugin> <groupId>org.springframework.boot</groupId> <artifactId>s ...

  5. R 多线程和多节点并行计算

    一:R本身是单线程的,如何让其多线程跑起来,提高运算速度? 用Parallel和foreach包玩转并行计算 看完上面这篇文章就会了.说白了,要加载parallel包,再改写一下自己的代码就ok了. ...

  6. Shell编程学习之Shell编程基础(一)

    这篇随笔将要介绍关于Shell编程的基本知识,这些将会在假设你已经熟悉了Linux系统和命令行的基本知识. 构建基本脚本 你应该了解或熟悉使用Shell命令行了,但是只是使用Shell命令行的命令,有 ...

  7. 实际案例告诉你为什么Oracle不建议使用varchar2来存时间数据

    问题现象2015年9月客户系统中一条高逻辑读的SQL语句,在业务高峰期执行频率较高,导致系统逻辑读居高不下,同时带高了系统CPU,SQL语句主体部分如下 SELECT /* ^^*/ COUNT(DI ...

  8. iOS新浪微博OAuth2.0认证代码

    #import "ViewController.h" #import "AFNetworking.h" @interface ViewController () ...

  9. 微信公众号支付java版本

    回调函数 @RequestMapping("/toPay") public String toPay(HttpServletRequest request, HttpServlet ...

  10. React路由-进阶篇

    路由进阶 1.多级路由,和之前的思想一样,在子路由里面继续写Route,继续挂载组件,就可以实现多级路由 比如这样:class Food extends Component{ render() { r ...