《手把手教你》系列技巧篇(三十)-java+ selenium自动化测试- Actions的相关操作下篇(详解教程)

本文涉及的产品
智能开放搜索 OpenSearch行业算法版,1GB 20LCU 1个月
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
实时数仓Hologres,5000CU*H 100GB 3个月
简介: 【4月更文挑战第22天】本文介绍了在测试过程中可能会用到的两个功能:Actions类中的拖拽操作和划取字段操作。拖拽操作包括基本讲解、项目实战、代码设计和参考代码,涉及到鼠标按住元素并将其拖动到另一个元素上或指定位置。划取字段操作则介绍了如何在一段文字中随机选取一部分,包括项目实战、代码设计和参考代码。此外,文章还提到了滑动验证的实现,并提供了相关的代码示例。

1.简介

  本文主要介绍两个在测试过程中可能会用到的功能:Actions类中的拖拽操作和Actions类中的划取字段操作。例如:需要在一堆log字符中随机划取一段文字,然后右键选择摘取功能。

2.拖拽操作

  鼠标拖拽操作,顾名思义就是:就是鼠标按住将一个元素拖拽到另一个元素上。

2.1基础讲解

//鼠标拖动API,首先实例化一个对象,后边将用这个对象进行一系列操作

Actions action = new Actions(webdriver);

//source-要拖动的元素A,target-拖动元素A到达的目标元素B

action.dragAndDrop(source, target);

//source-要拖动的元素A,拖动元素移动多少,标准以元素A左上角为准,拖动元素相对元素A移到右边是x是正值,左边是负值,拖动元素相对元素A移到上边是y是负值,下边是正值,

action.dragAndDropBy(source, xOffset, yOffset);

例如:

//找到我们所要拖动的元素A和元素B

WebElement A = driver.findElement(By.xpath("//*[@id=\"ext-gen153\"]/li[1]/div"));

WebElement B=driver.findElement(By.xpath("//*[@id=\"ext-gen153\"]/li[2]/div"));

//实例化一个对象action

Actions action = new Actions(driver.getDriver());

//鼠标拖动A向左移动570,之后释放鼠标

action.dragAndDropBy(A, -570, 0).perform();

//鼠标拖动B向下移动100,向左移动570之后释放鼠标

action.dragAndDropBy(B, -570, 100).perform();

//注意:拖动元素之间最好加强制休眠时间,否则不定时出问题,也不报错

action.dragAndDrop(A, B).perform();

driver.sleep(2000);

action.dragAndDrop(B, A).perform();

//有时定位没问题,代码没问题,就是没效果,那就考虑一下拖拽在不同的浏览器的工作效果

//For firefox :

Actions builder = new Actions(driver);

builder.moveToElement(draggable).clickAndHold();

builder.moveToElement(target).click().perform();


//For chrome :

Actions builder = new Actions(driver);

builder.moveToElement(draggable).clickAndHold(draggable);

builder.moveToElement(target).release(target).perform();

2.2项目实战

  宏哥这里JqueryUI网站的一个拖拽demo实战一下。

2.3代码设计

  代码设计如下:

2.4参考代码

   参考代码如下:

package lessons;


import java.util.concurrent.TimeUnit;


import org.openqa.selenium.By;

import org.openqa.selenium.WebDriver;

import org.openqa.selenium.WebElement;

import org.openqa.selenium.chrome.ChromeDriver;

import org.openqa.selenium.interactions.Actions;


/**

* @author 北京-宏哥

*

* 《手把手教你》系列技巧篇(三十)-java+ selenium自动化测试- Actions的相关操作下篇(详解教程)

*

* 2021年9月29日

*/

public class DraggOpration {


   public static void main(String[] args) throws Exception {  

       

       System.setProperty("webdriver.chrome.driver", ".\\Tools\\chromedriver.exe");  

         

       WebDriver driver = new ChromeDriver();  

   

       driver.manage().window().maximize();  

     

       driver.manage().timeouts().implicitlyWait(8, TimeUnit.SECONDS);

         

       driver.get("http://jqueryui.com/resources/demos/droppable/default.html");  

     

       Thread.sleep(2000);

       

       // 定位能拖拽的元素

       WebElement move_ele = driver.findElement(By.id("draggable"));

       

       // 定位拖拽目标位置元素

       WebElement target_ele = driver.findElement(By.id("droppable"));

       

       Actions action = new Actions(driver);

       action.dragAndDrop(move_ele, target_ele).build().perform();

       

       // 验证拖拽成功

       if(driver.findElement(By.xpath("//*[@id='droppable']/p[text()='Dropped!']")).isDisplayed()){

           System.out.println("断言通过!");  

       }

       System.out.println(driver.findElement(By.xpath("//*[@id='droppable']/p[text()='Dropped!']")).isDisplayed());

       assert(driver.findElement(By.xpath("//*[@id='droppable']/p[text()='Dropped!']")).isDisplayed() == true);

     

   }

}

2.5运行代码

1.运行代码,右键Run AS->java Application,控制台输出,如下图所示:

2.运行代码后电脑端的浏览器的动作,如下小视频所示:

3.划取字段操作

  划取字段操作就是在一段文字中随机选中一段文字,或者在标记文字。当然了,这个在一些网站的登录也需要滑块验证等。

selenium中提供了ActionChains类来处理鼠标事件。这个类中有2个方法和滑块移动过程相关。

click_and_hold():模拟按住鼠标左键在源元素上,点击并且不释放

release():松开鼠标按键

字面意思就可以理解这2个函数的作用。

3.1项目实战1

  在一段文字中,随机划取一小段文字(这个感觉比较鸡肋,貌似没有什么卵用,但是宏哥还是说一下吧)。

3.2代码设计

   代码设计如下:

3.3参考代码

  参考代码如下:

package lessons;


import java.util.concurrent.TimeUnit;


import org.openqa.selenium.By;

import org.openqa.selenium.WebDriver;

import org.openqa.selenium.WebElement;

import org.openqa.selenium.chrome.ChromeDriver;

import org.openqa.selenium.interactions.Actions;


/**

* @author 北京-宏哥

*

* 《手把手教你》系列技巧篇(三十)-java+ selenium自动化测试- Actions的相关操作下篇(详解教程)

*

* 2021年9月27日

*/

public class SlipOpration {


   public static void main(String[] args) throws InterruptedException {

       

       System.setProperty("webdriver.chrome.driver", ".\\Tools\\chromedriver.exe");  

       

       WebDriver driver = new ChromeDriver();  

   

       driver.manage().window().maximize();

       

       driver.manage().timeouts().implicitlyWait(2, TimeUnit.SECONDS);

                                       

       driver.get("https://www.baidu.com/duty/");

       

       //定位第一段文字

       WebElement Sting_Sected = driver.findElement(By.xpath("//*/p"));

       

       //定位第二段文字

       WebElement String_Second = driver.findElement(By.xpath("//*/ul[@class='privacy-ul-gap']/li[1]"));

       

       Actions action = new Actions(driver);

       action.clickAndHold(Sting_Sected).moveToElement(String_Second).perform();

       action.release();

       

   }

}

3.4运行代码

1.运行代码,右键Run AS->java Application,控制台输出,如下图所示:

2.运行代码后电脑端的浏览器的动作,如下小视频所示:

3.5项目实战2

  这里宏哥用携程旅行,手机号查单页面的一个滑动,进行项目实战。如下图所示:

3.6代码设计

  代码设计如下:

3.7参考代码

   参考代码如下:

package lessons;


import java.util.concurrent.TimeUnit;


import org.openqa.selenium.By;

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.interactions.Actions;


/**

* @author 北京-宏哥

*

* 《手把手教你》系列技巧篇(三十)-java+ selenium自动化测试- Actions的相关操作下篇(详解教程)

*

* 2021年9月30日

*/

public class Test {

   

   public static void main(String[] args) throws InterruptedException {

       

       System.setProperty("webdriver.gecko.driver", ".\\Tools\\geckodriver.exe");

       

       WebDriver driver = new FirefoxDriver();  

   

       driver.manage().window().maximize();  

     

       driver.manage().timeouts().implicitlyWait(5, TimeUnit.SECONDS);

         

       driver.get("https://passport.ctrip.com/user/member/fastOrder");

       

       Thread.sleep(2000);

       

       //定位滑块

       WebElement Sting_Sected = driver.findElement(By.xpath("//*[@class='cpt-drop-btn']"));

       

       //定位整个滑块框

       WebElement String_Second = driver.findElement(By.xpath("//*[@class='cpt-bg-bar']"));

       System.out.println(String_Second.getSize());

       Actions action = new Actions(driver);

       //action.clickAndHold(Sting_Sected).moveToElement(String_Second).perform();

       //action.release();

       action.dragAndDropBy(Sting_Sected, 279, 0).perform();

       action.release();

       

       //driver.quit();

   }    


}

3.8运行代码

1.运行代码,右键Run AS->java Application,控制台输出,如下图所示:

2.运行代码后电脑端的浏览器的动作,如下小视频所示:

4.小结

4.1重中之重

拖动元素有一个最重要的前提是,你定位的xpath等一定要准确,否则,到时候会出现各种拖动错乱的问题:

1.拖动元素如果用到action.dragAndDropBy(k2, -570, 100).perform();比如,如果我们想把A元素(可能为图标)拖动到B区域可能用到这个方法,但是把A拖动到B区域之后,如果我们又想把此时的A拖动到其它地方,但是此时A没有id,class,只有一些看似没用的x,y,w,h,注意:这里一定要注意这里的这四个值,因为当我们刚开始调用action.dragAndDropBy(k2, -570, 100).perform();时,此时拖动完之后,那么绝对此时的x或者y或者w或者h一定是唯一值,那么我们抓住这个要点就可以定位了

2.定位参考:

WebElement A=driver.findElement(By.xpath("//*[contains(@x,'50')]"));

//"任务跨1"节点

WebElement B=driver.findElement(By.xpath("//*[contains(@y,'150')]"));

4.2总结

1.注意拖动之后属性的唯一性

2.dragAndDrop

// 鼠标拖拽动作,将 source 元素拖放到 (xOffset, yOffset) 位置,其中 xOffset 为横坐标,yOffset 为纵坐标。

action.dragAndDrop(source,xOffset,yOffset);

/*在这个拖拽的过程中,已经使用到了鼠标的组合动作,首先是鼠标点击并按住 (click-and-hold) source 元素,然后执行鼠标移动动作 (mouse move),
移动到 target 元素位置或者是 (xOffset, yOffset) 位置,再执行鼠标的释放动作 (mouse release)。所以上面的方法也可以拆分成以下的几个执行动作来完成:*/

action.clickAndHold(source).moveToElement(target).perform();

action.release();

4.3selenium 绕过检测机制

细心地小伙伴可能发现最后的滑动验证宏哥,用了火狐浏览器,没有用Chrome浏览器。那是因为宏哥的Chrome浏览器是最新的,目前还没有找到selenium绕过Chrome检测机制的办法(据说代理可以实现,但是宏哥这里没有亲自动手验证,毕竟文章不是讲解爬虫的不能偏离主题)。低版本的Chrome可以参考这篇文章进行绕过:https://stackoverflow.com/questions/53039551/selenium-webdriver-modifying-navigator-webdriver-flag-to-prevent-selenium-detec/56635123#56635123

4.4测试网站

测试链接:https://bot.sannysoft.com/

正常浏览结果:

如果用Chrome浏览器,就会出现selenium检查机制,如下图所示:

宏哥然后在这个页面用网址监测一下,没有绕过Chrome的selenium反爬虫检测机制,如下图所示:

  好了,时间不早了,今天就分享和讲解到这里。



每天学习一点,今后必成大神-

往期推荐(由于跳转参数丢失了,所有建议选中要访问的右键,在新标签页中打开链接即可访问):

Appium自动化系列,耗时80天打造的从搭建环境到实际应用精品教程测试

Python接口自动化测试教程,熬夜87天整理出这一份上万字的超全学习指南

Python+Selenium自动化系列,通宵700天从无到有搭建一个自动化测试框架

Java+Selenium自动化系列,仿照Python趁热打铁呕心沥血317天搭建价值好几K的自动化测试框架

Jmeter工具从基础->进阶->高级,费时2年多整理出这一份全网超详细的入门到精通教程

Fiddler工具从基础->进阶->高级,费时100多天吐血整理出这一份全网超详细的入门到精通教程

Pycharm工具基础使用教程

相关文章
|
1月前
|
Web App开发 前端开发 JavaScript
探索Python科学计算的边界:利用Selenium进行Web应用性能测试与优化
【10月更文挑战第6天】随着互联网技术的发展,Web应用程序已经成为人们日常生活和工作中不可或缺的一部分。这些应用不仅需要提供丰富的功能,还必须具备良好的性能表现以保证用户体验。性能测试是确保Web应用能够快速响应用户请求并处理大量并发访问的关键步骤之一。本文将探讨如何使用Python结合Selenium来进行Web应用的性能测试,并通过实际代码示例展示如何识别瓶颈及优化应用。
97 5
|
1月前
|
Java 测试技术 C#
自动化测试之美:从Selenium到Appium
【10月更文挑战第3天】在软件开发的海洋中,自动化测试如同一艘航船,引领着质量保证的方向。本文将带你领略自动化测试的魅力,从Web端的Selenium到移动端的Appium,我们将一探究竟,看看这些工具如何帮助我们高效地进行软件测试。你将了解到,自动化测试不仅仅是技术的展示,更是一种提升开发效率和产品质量的智慧选择。让我们一起启航,探索自动化测试的世界!
|
14天前
|
Java 测试技术 Maven
Java一分钟之-PowerMock:静态方法与私有方法测试
通过本文的详细介绍,您可以使用PowerMock轻松地测试Java代码中的静态方法和私有方法。PowerMock通过扩展Mockito,提供了强大的功能,帮助开发者在复杂的测试场景中保持高效和准确的单元测试。希望本文对您的Java单元测试有所帮助。
29 2
|
22天前
|
Java 程序员 测试技术
Java|让 JUnit4 测试类自动注入 logger 和被测 Service
本文介绍如何通过自定义 IDEA 的 JUnit4 Test Class 模板,实现生成测试类时自动注入 logger 和被测 Service。
21 5
|
1月前
|
Java 流计算
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
37 1
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
|
27天前
|
存储 人工智能 Java
将 Spring AI 与 LLM 结合使用以生成 Java 测试
AIDocumentLibraryChat 项目通过 GitHub URL 为指定的 Java 类生成测试代码,支持 granite-code 和 deepseek-coder-v2 模型。项目包括控制器、服务和配置,能处理源代码解析、依赖加载及测试代码生成,旨在评估 LLM 对开发测试的支持能力。
36 1
|
1月前
|
JavaScript 前端开发 测试技术
精通Selenium:从基础到高级的网页自动化测试策略
【10月更文挑战第6天】随着Web应用变得越来越复杂,手动进行功能和兼容性测试变得既耗时又容易出错。自动化测试因此成为了现代软件开发不可或缺的一部分。Selenium是一个强大的工具集,它支持多种编程语言(包括Python),允许开发者编写脚本来模拟用户与Web页面的交互。本文将带领读者从Selenium的基础知识出发,逐步深入到高级的应用场景,通过丰富的代码示例来展示如何高效地进行网页自动化测试。
237 5
|
1月前
|
Web App开发 IDE 测试技术
自动化测试的利器:Selenium 框架深度解析
【10月更文挑战第2天】在软件开发的海洋中,自动化测试犹如一艘救生艇,让质量保证的过程更加高效与精准。本文将深入探索Selenium这一强大的自动化测试框架,从其架构到实际应用,带领读者领略自动化测试的魅力和力量。通过直观的示例和清晰的步骤,我们将一起学习如何利用Selenium来提升软件测试的效率和覆盖率。
|
13天前
|
Web App开发 设计模式 JavaScript
自动化测试之美:如何利用Selenium实现Web应用的高效测试
【10月更文挑战第29天】在软件开发的世界中,测试是确保产品质量的关键步骤。本文将带你了解如何使用Selenium这一强大的自动化测试工具,提高Web应用测试的效率和准确性。通过实际案例,我们将探索Selenium的核心功能及其在现代软件开发中的应用,旨在帮助读者掌握自动化测试的精髓,从而提升软件测试工作的整体效能。
11 0
|
1月前
|
Web App开发 缓存 Linux
高效Selenium测试技巧:轻松控制已开启的浏览器
【10月更文挑战第13天】在进行Selenium测试时,通常会启动新浏览器实例,但有时需要控制已开启的浏览器,以节省时间并更真实地模拟用户行为。这可通过设置Chrome为可远程控制并使用`Remote WebDriver`连接实现。需在启动Chrome时添加`--remote-debugging-port`参数,并通过Python脚本中的`webdriver.Remote`连接至指定端口。此外,还可利用会话ID(Session ID)重新连接浏览器,提高测试灵活性。需要注意浏览器版本兼容性及元素定位稳定性等问题,确保测试准确性和一致性。
244 1