`
zTreeAPI
  • 浏览: 346386 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

和我一起学 Selenium WebDriver(7)——基础篇

阅读更多

    昨天我们已经可以轻松移动鼠标了,距离拖拽只有一步之遥。 其实这就是一层窗户纸,捅破它就搞定了,之前做的操作可以说都是单步操作:移动鼠标、点击页面元素、弹出窗口等等;而拖拽操作就不行了,他需要一连串连贯的动作配合起来:mousedown、mousemove、mouseup,缺了哪个都不行,顺序不对也不行。

 

【1、如何进行拖拽】

    这时候我们就需要用到 org.openqa.selenium.interactions.Actions 这个类了,它专门用来做动作组合的。 Actions 中有若干方法,可以让你很容易的生成 鼠标、按键的操作集合。

    例如: clickAndHold + moveToElement + release 就可以组合成一套拖拽的操作;

    详细内容还请查看 Selenium 的 javadoc:http://selenium.googlecode.com/svn/trunk/docs/api/java/index.html


    生成操作组合后,利用 build 方法可以得到一个有效的 Action 对象;最后使用 perform 方法执行就可以了。


    和昨天测试鼠标移动的情况类似,还是 FireFox 问题最大, IE8有小问题, Chrome 测试最正常。


FireFox:使用 moveToElement 方法时,效果同昨天使用 MoveToOffsetAction 情况类似,xOffset、yOffset值无论如何设置,在页面上得到的都是 指定的 页面元素;

    另外,如果在不使用 moveToElement的时候就使用moveByOffset 很容易报错:org.openqa.selenium.interactions.MoveTargetOutOfBoundsException: Element cannot be scrolled into view: (WARNING: The server did not provide any stacktrace information)


IE8: 使用 moveToElement 方法时,如果用到了 xOffset、yOffset 参数,你会发现在 IE8中 计算的情况 和 Chrome 上不太一样,貌似范围会更大一些,因此导致如果设置为0, 0 时,就不是你预期的结果了


测试代码我分成了3个部分:

  • 观察反复拖拽测试 1

   可以专门用来观察 moveToElement 在不同浏览器下的情况


  • 观察反复拖拽测试 2

   可以专门用来观察 moveByOffset 在不同浏览器下的情况,FireFox 会报错


  • 观察系列操作测试

   可以专门用来观察 多种组合操作 在 不同浏览器下的情况


    总之,对于鼠标移动和拖拽的测试还是直接在 Chrome 下进行就可以了吧;ie的只能略微参考;剩下的还是自己手动来吧。。。。

    如果想在 IE 上正常测试,建议采用moveToElement(WebElement)+ moveByOffset(xOffset, yOffset); 避免直接使用 moveToElement(WebElement, xOffset, yOffset),同时还是要严格注意 xOffset 和 yOffset 的设置;这个需要根据自己的实际情况来调试了。


    学习了这些内容以后,对于 测试 zTree 这类前端 js 插件来说就足够了,剩下的就努力干活儿吧。 貌似我是真用不上 Selenium 的 webdriver 了。。。


以下是测试代码:

package lesson07;

import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.Test;
import org.openqa.selenium.HasInputDevices;
import org.openqa.selenium.JavascriptExecutor;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.chrome.ChromeDriver;
import org.openqa.selenium.firefox.FirefoxDriver;
import org.openqa.selenium.ie.InternetExplorerDriver;
import org.openqa.selenium.interactions.Action;
import org.openqa.selenium.interactions.Actions;
import org.openqa.selenium.interactions.MoveMouseAction;
import org.openqa.selenium.interactions.MoveToOffsetAction;
import org.openqa.selenium.internal.Locatable;
import org.openqa.selenium.support.ui.ExpectedCondition;
import org.openqa.selenium.support.ui.WebDriverWait;

import util.Common;

public class ExampleForDrag  {
	
    static WebDriver driver;
    
    @BeforeClass
    public static void init() {
    	System.out.println("init...");
    	//用 Chrome
//    	System.setProperty(
//				"webdriver.chrome.driver",
//				"E:\\BaiduWangPan\\百度网盘\\javascript\\Selenium WebDriver\\chromedriver_win_23.0.1240.0\\chromedriver.exe");
//    	driver = new ChromeDriver();
    	
    	//用 IE
//    	driver = new InternetExplorerDriver();
    	
    	//用 FireFox
    	System.setProperty("webdriver.firefox.bin", "D:\\Program Files\\Mozilla Firefox\\firefox.exe");
    	// 创建一个 FireFox 的浏览器实例
    	driver = new FirefoxDriver();
    }
	
    @Test
    public void test() {
    	// 让浏览器访问 zTree Demo
    	driver.get("http://www.ztree.me/v3/demo/cn/exedit/drag.html");
    	
    	// 等待 zTree 初始化完毕,Timeout 设置10秒
    	try {
    		(new WebDriverWait(driver, 10, 500)).until(new ExpectedCondition<Boolean>() {
    			public Boolean apply(WebDriver d) {
    				WebElement element = (WebElement) ((JavascriptExecutor)driver).executeScript("return $('#treeDemo li').get(0);");
    				return element != null;
    			}
    		});
    		
    	} catch(Exception e) {
    		e.printStackTrace();
    	}
    	
    	//找到第一个根节点的子节点
    	((JavascriptExecutor)driver).executeScript("window.zTreeObj = $.fn.zTree.getZTreeObj('treeDemo');"
    			+ "window.zTreeNodeSrc = window.zTreeObj.getNodes()[0].children[0];");
    	
    	//获取 需要拖拽的节点对象 
    	WebElement elementSrc = (WebElement) ((JavascriptExecutor)driver).executeScript("return $('#' + window.zTreeNodeSrc.tId + '_a').get(0)");
    	//获取 目标节点对象 
    	WebElement elementTarget = (WebElement) ((JavascriptExecutor)driver).executeScript("window.zTreeNodeTarget = window.zTreeNodeSrc.getNextNode().children[0]; return $('#' + window.zTreeNodeTarget.tId + '_a').get(0)");
    	Actions actions = new Actions(driver);
    	Action action;

    	//观察反复拖拽测试 1
//    	actions.clickAndHold(elementSrc);
//    	for (int i=0; i<500; i++) {
//    		actions.moveToElement(elementTarget, i%100-50, i%50-20);
//    	}
//    	actions.release();
//    	action = actions.build();
//    	action.perform();
//    	
//    	Common.waitFor(10, driver);

    	//观察反复拖拽测试 2
//    	actions.clickAndHold(elementSrc).moveToElement(elementTarget);
//    	int x = 0, y = 0, dx=2, dy=2;
//    	for (int i=0; i<500; i++) {
//    		x+=2; y+=2;
//    		if (x > 50) {
//    			dx = -x;
//    			x = 0;
//    		} else {
//    			dx = 2;
//    		}
//    		if (y > 150) {
//    			dy = -y;
//    			y = 0;
//    		} else {
//    			dy = 2;
//    		}
//    		actions.moveByOffset(dx, dy);
//    	}
//    	actions.release();
//    	action = actions.build();
//    	action.perform();
//    	Common.waitFor(10, driver);
    	
    	//观察系列操作测试
    	System.out.println("移动成为目标节点的 前一个节点");
    	actions.clickAndHold(elementSrc).moveToElement(elementTarget, 60, 1).release();
    	action = actions.build();
    	action.perform();
    	
    	// 等待 10 秒
    	Common.waitFor(10, driver);
    	
    	System.out.println("移动成为目标节点的后一个节点");
    	actions.clickAndHold(elementSrc).moveToElement(elementTarget, 60, 38).release();
    	action = actions.build();
    	action.perform();
    	
    	// 等待 10秒
    	Common.waitFor(10, driver);
    	
    	System.out.println("移动成为目标节点的子节点");
    	actions.clickAndHold(elementSrc).moveToElement(elementTarget).release();
    	action = actions.build();
    	action.perform();
    	
    	// 等待 10秒
    	Common.waitFor(10, driver);

    	System.out.println("移动成为目标节点下一个节点的子节点");
    	actions.clickAndHold(elementSrc).moveToElement(elementTarget).moveByOffset(0, 20).release();
    	action = actions.build();
    	action.perform();
    	
    	// 等待 10秒
    	Common.waitFor(10, driver);
    	
    }
    
    @AfterClass
    public static void destory() {
    	System.out.println("destory...");
    	//关闭浏览器
    	driver.quit();
    }
}
 
分享到:
评论
2 楼 zTreeAPI 2013-06-06  
OMG,自己复制吧,我可没有 word 版的
1 楼 oxygen001 2013-06-05  
大哥,能不能给一个Word版的给我啊?我的邮箱是 zdan163@163.com,谢谢

相关推荐

    Selenium WebDriver实战宝典(吴晓华)

    全书共分为四个部分:第1部分基础篇主要讲解自动化测试相关的基础理论、WebDriver 环境安装、单元测试工具的使用方法以及 WebDrvier的入门使用实例,第2部分实战应用篇基于丰富的实战案例讲解页面元素的定位方法以及...

    selenium_webdriver(python)第一版.pdf

    这篇文档特别适合已经具备Python基础知识,并希望通过Python和Selenium进行自动化测试的初学者。作者虽自称在Selenium自动化方面是初学者,但通过自身的学习经验,为读者提供了宝贵的学习路径。 文档首先介绍了...

    基于Selenium WebDriver的B_S架构软件的自动化测试研究.pdf

    最后,文章还展示了Selenium WebDriver的基本代码结构,例如使用Java语言的示例代码,包括初始化WebDriver对象、设置隐式等待时间以及测试前的准备(例如初始化WebDriver和基础URL)等。这些代码片段对理解和实现...

    Selenium WebDriver Project on Eclipse

    在本篇指南中,我们将详细介绍如何在Eclipse IDE中设置并配置一个基于Maven的Selenium WebDriver项目。 #### 二、准备工作 在开始之前,请确保您已经安装了以下软件: 1. **Eclipse IDE**:推荐版本为 Oxygen 或更...

    selenium-webdriver从入门到提高

    本书的特点是包含了多种编程语言的实践篇幅,例如Python篇、Ruby篇和Java篇,这表明Selenium-WebDriver支持多种编程语言,让不同语言背景的开发者都能有效地利用这个工具进行Web应用的自动化测试。通过这种方式,...

    web自动化测试selenium+webdriver环境配置

    在本篇文章中,我们将详细介绍如何配置Selenium与WebDriver的环境,以便开始进行Web自动化测试。 首先,我们需要安装Java Development Kit (JDK)。因为Selenium主要使用Java编写,所以确保你的系统上已经安装了JDK...

    配置Selenium工具(Java IE)

    JDK是编写Java程序的基础,也是Selenium WebDriver的运行环境。你可以从Oracle官方网站下载并按照指示进行安装。 其次,我们需要下载Selenium WebDriver的IE驱动程序。这个驱动程序使得Selenium能够与IE浏览器进行...

    selenium-libs.rar

    《Selenium库详解——以libs为例》 在IT领域,自动化测试是提升效率、确保产品质量的重要手段,而Selenium作为一款强大的Web应用程序自动化测试工具,备受业界青睐。本篇文章将聚焦于"Selenium-libs.rar"这个压缩包...

    selenium2 的学习材料

    虽然描述中没有直接提供详细信息,但通常一篇关于Selenium2的学习材料博客可能包含以下内容:基础概念介绍、安装步骤、基本用法、API详解、实战示例以及如何与其他工具(如JUnit或TestNG)集成。博主可能还会分享...

    python零基础学习篇数据爬虫技巧-6第六章 浏览器测试框架:Selenium.zip

    在Python的世界里,数据爬虫是一项重要的技能,用于自动化地从网页中提取大量信息。Selenium是一个强大的浏览器自动化测试框架,...这份文档资料将详细讲解Selenium的使用方法,帮助你从零基础开始掌握这个强大的工具。

    python自动化测试-web-selenium

    本篇文章将深入探讨如何使用Python与Selenium进行自动化测试,并涉及到HTML基础知识和Web服务器的搭建。 首先,我们需要理解Selenium的工作原理。Selenium通过WebDriver接口与不同的浏览器进行通信,WebDriver是...

    Selenium八种定位元素

    本文介绍了使用XPath表达式中的`starts-with`、`contains`、`descendant`、`ancestor`和`text()`函数以及Selenium WebDriver提供的其他七种常见定位方式来定位网页元素的方法。不同的定位策略适用于不同的情况,理解...

    selenium安装使用说明

    这篇详细的指南将带你一步步了解 Selenium 的安装过程,并通过实例讲解其基本用法。 **一、Selenium 的功能** 1. **跨浏览器测试**:Selenium 支持多种浏览器,如 Chrome、Firefox、Edge 和 Safari,可以在不同的...

    Python+selenium自动化测试源码分享,讲解详细

    总之,Python结合Selenium的自动化测试是一个涉及编程基础、网页交互、测试设计和报告生成等多个方面的综合实践。通过学习和应用这些知识点,不仅可以提高测试效率,还能提升软件的质量和稳定性。希望这个源码分享能...

    selenium testing

    - **基础篇**:介绍 Selenium 和 Python 的基本概念,包括安装配置、环境搭建等。 - **实践篇**:通过具体案例演示如何使用 Python 编写测试脚本,涵盖常见的 Web 页面元素操作。 - **进阶篇**:深入探讨高级测试...

    Selenium2环境搭建(java篇)

    这个文件包含了Selenium的服务器,可以用来运行WebDriver和远程控制测试。如果你只打算使用本地WebDriver,那么`libs`下的jar包已经足够。 3. **Java Project配置**:在Eclipse中创建一个新的Java项目,将`libs`...

    Selenium自动化测试入门到精通项目实战 Java篇

    你是否渴望学习selenium webdriver + Java以及最新的框架和技术进行web自动化测试? 你是否感兴趣学习Selenium如何用在你现有的项目里的? 这门课带你从Selenium搭建环境开始讲起,然后学习selenium,TestNG, ...

    python+selenium的用法

    ### Python+Selenium的基本用法详解 #### 一、概述 Selenium是一个强大的自动化测试工具,广泛应用于Web应用程序的测试之中。...希望这篇文档能帮助大家更好地理解和掌握Python+Selenium的基础用法。

    selenium2-python自动化测试

    总之,这篇文档不仅详细介绍了Python和selenium2结合进行自动化测试的知识点,还通过作者的学习和实践经验,提供了一种学习和应用这些知识的方法论。通过阅读这篇文档,读者可以对如何使用selenium2和Python进行Web...

Global site tag (gtag.js) - Google Analytics