【软件测试】自动化常用函数

文章目录

  • 元素的定位
    • cssSelector
    • xpath
    • 查找元素
  • 操作测试对象
    • 点击/提交对象——click()
    • 模拟按键输入——sendKeys(“”)
    • 清除文本内容——clear()
    • 获取文本信息——getText()
    • 获取页面标题和 URL
  • 窗口
    • 设置窗口大小
    • 切换窗口
    • 关闭窗口
  • 等待
    • 强制等待
    • 隐式等待
    • 显式等待
  • 浏览器导航

元素的定位

web ⾃动化测试的操作核⼼是能够找到⻚⾯对应的元素,然后才能对元素进⾏具体的操作。常⻅的元素定位⽅式⾮常多,如 idclassnametagnamexpathcssSelector 常⽤的主要由 cssSelectorxpath

cssSelector

选择器的功能:选中页面中指定的标签元素

选择器的种类分为基础选择器和复合选择器,常见的元素定位方式可以通过 id 选择器和子类选择器来进行定位image.png

xpath

XML 路径语⾔,不仅可以在 XML ⽂件中查找信息,还可以在 HTML 中选取节点。

xpath 使⽤路径表达式来选择 xml ⽂档中的节点

xpath 语法中:

  • 获取 HTML 页面中所有的节点: //*
  • 获取 HTML 页面指定的节点://[指定节点]
    • //ul:获取 HTML 页面所有的 ul 节点
    • //input:获取 HTML 页面所有的 input 节点
  • 获取一个节点中的直接子节点:/
    • //span/input
  • 获取一个节点的父节点:..
    • //input/..:获取 input 节点的父节点
  • 实现节点属性的匹配:[@...]
    • //[@id='kw]:匹配 HTML 页面中的 id 属性为 kw 的节点
  • 使用指定索引的方式获取对应的节点内容
    • 注意:xpath 的索引是从 1 开始的
    • 百度首页通过://div/ul/li[3],定位到第三个百度热搜标签

更便捷的⽣成 selector/xpath 的⽅式:右键选择复制"Copy selector/xpath"

注意:登录状态下和非登录状态下,自动化打开的页面不一定相同。做自动化测试一定要注意页面状态的一致性

查找元素

  1. findElement,在页面查找元素,返回值 WebElement
    查找页面元素
driver.findElement(By.cssSelector("#s-hotsearch-wrapper > div > a.hot-title > div > i:nth-child(1)")).click();  
driver.findElement((By.xpath("//*[@id=\"s-hotsearch-wrapper\"]/div/a[1]/div/i[1]"))).click();
  • 这两个查找,都是找到百度热搜

  1. findElements,在页面查找元素,返回值为 List<WebElement>
List<WebElement> elements = driver.findElements(By.cssSelector("#hotsearch-content-wrapper > li > a > span.title-content-title"));  
for(WebElement str : elements){  System.out.println(str.getText());  
}
  • 打印热搜标题image.png

操作测试对象

点击/提交对象——click()

//找到百度一下并点击
driver.finElement(By.cssSelector("#su")).click();

页面中,除了按钮可以点之外,其他绝大多数元素也能点击

  • 页面隐藏的元素不能进行操作,不然会报错image.png

模拟按键输入——sendKeys(“”)

这个方法可以在任意能输入文本的地方进行输入

driver.findElement(By.cssSelector("#kw")).sendKeys("今天天气");  
Thread.sleep(3000);  
driver.quit();

![[屏幕录制 2024-11-16 165917.mp4]]

清除文本内容——clear()

输入文本后,又想换一个新的关键词,这里就需要用到 clear()

若想在一个场景下更换多个关键词,需要将前一个关键词清楚掉;若不清除,每次 sendKeys 将完成拼接的操作

driver.findElement(By.cssSelector("#kw")).sendKeys("我爱游戏");
driver.findElement(By.cssSelector("#kw")).clear();
driver.findElement(By.cssSelector("#kw")).sendKeys("我爱学习");

获取文本信息——getText()

WebElement bdtext =  driver.findElement(By.cssSelector("#hotsearch-content-wrapper > li:nth-child(3) > a > span.title-content-title"));  
System.out.println(bdtext.getText());  

问题:是否可以通过 getText() 获取到“百度⼀下按钮”上的⽂字“百度⼀下”呢?

//获取百度一下按钮上的文本  
String text = driver.findElement(By.cssSelector("#su")).getText();  
System.out.println("百度一下上的文字为:"+text);
  • 最终得到的结果是:image.png
  • 打印的 text 是空的,因为“百度一下”是 input 标签里面的属性值,需要用 getAttribute(String) 将其拿出来,不能通过拿文本的方式将其拿出来image.png

//获取百度一下按钮上的文本  
String text = driver.findElement(By.cssSelector("#su")).getAttribute("value");  
System.out.println("百度一下上的文字为:"+text);

image.png|360

获取页面标题和 URL

String title = driver.getTitle();  
String url = driver.getCurrentUrl();  
System.out.println(title);  
System.out.println(url);

image.png|327

窗口

设置窗口大小

//设置窗口大小  
//窗口最小化  
driver.manage().window().minimize();  
Thread.sleep(2000);  
//窗口最大化  
driver.manage().window().maximize();  
Thread.sleep(2000);  
//窗口全屏  
driver.manage().window().fullscreen();  
Thread.sleep(2000);  
//自定义尺寸  
driver.manage().window().setSize(new Dimension(800,400));  
Thread.sleep(2000);

切换窗口

当创建一个驱动之后,驱动对象就会指向打开的那个页面的句柄

  • 每一个标签页都有一个自己的句柄信息
  • 如果想让 driver 指向别的标签页,就需要使其指向改变
  1. 获取所有标签页的句柄信息
  2. 当新建的窗口句柄信息与最初的标签页句柄信息不一样的话,就进行 driver 指向改变
  3. 从而达到切换窗口的效果

  • 获取当前页面句柄:driver.getWindowHandle()
  • 获取所有页面句柄:driver.getWindowHandles()
driver.findElement(By.cssSelector("#s-hotsearch-wrapper > div > a.hot-title > div")).click();  
String curHandle = driver.getWindowHandle();  
Set<String> allHandles = driver.getWindowHandles();  
for(String handle : allHandles){  if(handle != curHandle){  //切换 driver 的句柄指向  driver.switchTo().window(handle);  }  
}
  • 根据 driver 获取所有页面的句柄,但指向只有一个

注意:执行了 driver.close() 之前需要切换到未被关闭的窗口

  • 自动化一般不会存在要打开好多个标签页,跳转到任意标签页的操作
  • 可以直接使用 driver.get(URL) 进行跳转

关闭窗口

//关闭当前标签页
driver.close();//关闭浏览器,释放driver对象
driver.quit();
  • 若 driver 指向标签页 1,那么即使你关闭了标签页 1,没有改变 driver 指向,就无法关闭标签页 2,除非将 driver 的指向改变

close() 用到的场景比较少,只会在以下场景下去使用

  • 测试打开的新的标签页之后还要继续返回到前一个标签页中进行测试

等待

假如写自动化代码出现了 NoSuchElement 错误

  • 第一步:在报错的代码前添加 Thread.sleep(秒),设置的时间长一点
  • 第二步:执行自动化,在自动化打开的页面里打开前端开发者工具,手动检查元素是否真的不一样
    1. 自动化打开的页面确实不存在该元素

      • 手动打开的页面和自动化打开的页面不一样(很有可能是登录和未登录状态下的页面不一样)
      • 元素为动态元素(解决办法:先定位动态元素的前一级标签,再增加要定位的元素标签)
    2. 自动化打开的页面确实存在该元素

      • 代码执行的速度比页面渲染的速度要快。页面还没渲染出来,程序就已经开始找了,导致元素没有找到(解决办法:添加等待)

强制等待

以阻塞线程的方式,达到等待的效果

Thread.sleep();
  • 优点:写法简单,好理解,直接阻塞程序
  • 缺点:极大的增加了自动化的执行时间

100 条测试用例,每个用例添加强制等待平均时间 3 s

  • 总:1000 * 3 = 3000s = 50min
  • 理想的情况下:2 - 3min

隐式等待

隐式等待是一种智能等待,他可以规定在查找元素时,在指定时间内不断查找元素。如果找到则代码继续执行,知道超时没找到元素才会报错。

你的女朋友转校了,让你等她三年。但第二年的时候,她回来了

  • 你坚持要等完三年再和她在一起(强制等待
  • 她回来后,你就和她在一起了(隐式等待
  • implicitlyWait() 参数:Duration 类中提供的毫秒、秒、分钟等方法
//隐式等待3秒
driver.manage().timeouts().implicitlyWait(Duration.ofSeconds(3));//隐式等待3000毫秒
driver.manage().timeouts().implicitlyWait(Duration.ofMillis(3000));
  • 3s 内找到元素,继续执行
  • 3s 内没有找到元素,报错 NoSuchElement
  • 以轮询的方式来查找这个元素,一直在询问找到没有
  • 优点:智能等待,作用全局

隐式等待作⽤域是整个脚本的所有元素。即只要 driver 对象没有被释放掉(driver.quit()),隐式等待就⼀直⽣效。

显式等待

显式等待也是一种智能等待,在指定超时时间范围内只要满足操作的条件就会继续执行后续代码

new WebDriverWait(driver, Duration.ofSeconds(3).until($express))
  • $press:涉及到 selenium.support.ui.ExpectedCondition 包下的 ExprxtedCondition
  • 返回值:boolean
WebDriverWait wait = new WebDriverWait(driver,Duration.ofSeconds(3));  
wait.until(ExpectedConditions.elementToBeClickable(By.cssSelector("#su")));  
//先保证元素存在且可以点击后  
driver.findElement(By.cssSelector("#su")).click();
  • 优点:显式等待是智能等待,可以自定义显式等待的条件,操作灵活
  • 缺点:写法复杂

ExpectedConditions 预定义的一些示例:

  • elementToBeClickable(By location):用于检查元素的期望是可见的并已启用,以便可以单击它
  • textToBe(By locator, String str):检查元素(精确匹配)
  • presenceOfElementLocated(By locator):检查页面的 DOM 上是否存在元素
  • urlToBe(java.lang.String url):检查当前页面的 URL 是一个特定的 URL

浏览器导航

  • 打开网站
//更长的方法
driver.navigate().to("https://www.bytedance.com");//简单的方法
driver.get("https://www.bytedance.com");
  • 浏览器的前进、后退、刷新
//后退
driver.navigate().back();  
//前进
driver.navigate().forward();  
//刷新
driver.navigate().refresh();

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/475653.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Mybatis-Plus 多租户插件属性自动赋值

文章目录 1、Mybatis-Plus 多租户插件1.1、属性介绍1.2、使用多租户插件mavenymlThreadLocalUtil实现 定义,注入租户处理器插件测试domianservice & ServiceImplmapper 测试mapper.xml 方式 1.3、不使用多租户插件 2、实体对象的属性自动赋值使用1. 定义实体类2. 实现 Meta…

【WPF】Prism学习(六)

Prism Dependency Injection 1.依赖注入&#xff08;Dependency Injection&#xff09; 1.1. Prism与依赖注入的关系&#xff1a; Prism框架一直围绕依赖注入构建&#xff0c;这有助于构建可维护和可测试的应用程序&#xff0c;并减少或消除对静态和循环引用的依赖。 1.2. P…

【H2O2|全栈】MySQL的云端部署

目录 前言 开篇语 准备工作 MySQL移除 为什么需要移除&#xff1f; 移除操作 Yum仓库 yum简介 rpm安装 yum库安装 MySQL安装 使用yum安装 开机自启动 检查运行状态 MySQL配置 初始密码 ​编辑登录 修改root密码 退出MySQL 字符集配置 重启数据库 结束语 …

【Tealscale + Headscale + 自建服务器】异地组网笔记

文章目录 效果为什么要用 Headscale云服务器安装 Headscale配置 config.yaml创建反向代理搭建管理 UI授权管理 UI添加互联设备参考 效果 首先是连接情况&#xff0c;双端都连接上自建的 Headscale&#xff0c; 手机使用移动流量&#xff0c;测试一下 ping 值 再试试进入游戏 可…

【C++】栈、队列、双端队列与优先级队列

目录 一、stack&#xff08;栈&#xff09; 二、queue&#xff08;队列&#xff09; 三、deque&#xff08;双端队列&#xff09; &#xff08;一&#xff09;概念 &#xff08;二&#xff09;为什么能作为 stack 和 queue 的容器 &#xff08;三&#xff09;缺点 四、p…

02 —— Webpack 修改入口和出口

概念 | webpack 中文文档 | webpack中文文档 | webpack中文网 修改入口 webpack.config.js &#xff08;放在项目根目录下&#xff09; module.exports {//entry设置入口起点的文件路径entry: ./path/to/my/entry/file.js, }; 修改出口 webpack.config.js const path r…

实验室管理现代化:Spring Boot技术方案

4系统概要设计 4.1概述 本系统采用B/S结构(Browser/Server,浏览器/服务器结构)和基于Web服务两种模式&#xff0c;是一个适用于Internet环境下的模型结构。只要用户能连上Internet,便可以在任何时间、任何地点使用。系统工作原理图如图4-1所示&#xff1a; 图4-1系统工作原理…

深入探讨 Puppeteer 如何使用 X 和 Y 坐标实现鼠标移动

背景介绍 现代爬虫技术中&#xff0c;模拟人类行为已成为绕过反爬虫系统的关键策略之一。无论是模拟用户点击、滚动&#xff0c;还是鼠标的轨迹移动&#xff0c;都可以为爬虫脚本带来更高的“伪装性”。在众多的自动化工具中&#xff0c;Puppeteer作为一个无头浏览器控制库&am…

【软考】系统架构设计师-计算机系统基础(4):计算机网络

计算机网络功能&#xff1a;数据通信、资源共享、管理集中化、分布式处理、负载均衡 5G高峰速率&#xff1a;10Gbit/s 广域网&#xff08;因特网&#xff09;/城域网/局域网&#xff08;以太网&#xff09; 总线型&#xff1a;利用率低&#xff0c;易冲突&#xff0c;干扰大…

【HOT100第五天】搜索二维矩阵 II,相交链表,反转链表,回文链表

240.搜索二维矩阵 II 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性&#xff1a; 每行的元素从左到右升序排列。每列的元素从上到下升序排列。 先动手写写最简单方法&#xff0c;二重循环。 class Solution { public:bool searchMa…

从技术到产品:第三方美颜API助力实时直播平台的开发详解

众所周知&#xff0c;开发一套完整的美颜功能不仅耗时耗力&#xff0c;还需要大量的算法调优与硬件优化。为此&#xff0c;第三方美颜API成为越来越多开发者的优先选择。本篇文章&#xff0c;小编将从技术到产品&#xff0c;深入探讨第三方美颜API如何助力直播平台的快速开发。…

《深入理解 Spring MVC 工作流程》

一、Spring MVC 架构概述 Spring MVC 是一个基于 Java 的轻量级 Web 应用框架&#xff0c;它遵循了经典的 MVC&#xff08;Model-View-Controller&#xff09;设计模式&#xff0c;将请求、响应和业务逻辑分离&#xff0c;从而构建出灵活可维护的 Web 应用程序。 在 Spring MV…

大数据新视界 -- 大数据大厂之 Impala 性能优化:融合人工智能预测的资源预分配秘籍(上)(29 / 30)

&#x1f496;&#x1f496;&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎你们来到 青云交的博客&#xff01;能与你们在此邂逅&#xff0c;我满心欢喜&#xff0c;深感无比荣幸。在这个瞬息万变的时代&#xff0c;我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…

【MySQL-3】表的约束

目录 1. 整体学习的思维导图 2. 非空约束 3. default约束 4. No Null和default约束 5. 列描述 comment 6. Zerofill 7. 主键 primary key 复合主键 8. 自增长 auto_increment 9. 唯一键 10. 外键 11. 实现综合案例 1. 整体学习的思维导图 2. 非空约束 正如该标题一…

【Linux】Namespace

一、概念 Linux Namespace 是 Linux 内核提供的一种特性&#xff0c;用于对系统资源进行隔离。通过 Namespace&#xff0c;不同的进程组可以拥有独立的系统资源视图&#xff0c;即使它们在同一台物理机器上运行。这种隔离机制使得容器技术成为可能&#xff0c;因为它允许在单个…

在MATLAB中实现自适应滤波算法

自适应滤波算法是一种根据信号特性自动调整滤波参数的数字信号处理方法&#xff0c;其可以有效处理噪声干扰和信号畸变问题。在许多实时数据处理系统中&#xff0c;自适应滤波算法得到了广泛应用。在MATLAB中&#xff0c;可以使用多种方法实现自适应滤波算法。本文将介绍自适应…

Python学习------第十天

数据容器-----元组 定义格式&#xff0c;特点&#xff0c;相关操作 元组一旦定义&#xff0c;就无法修改 元组内只有一个数据&#xff0c;后面必须加逗号 """ #元组 (1,"hello",True) #定义元组 t1 (1,"hello") t2 () t3 tuple() prin…

软件测试—— Selenium 常用函数(一)

前一篇文章&#xff1a;软件测试 —— 自动化基础-CSDN博客 目录 前言 一、窗口 1.屏幕截图 2.切换窗口 3.窗口设置大小 4.关闭窗口 二、等待 1.等待意义 2.强制等待 3.隐式等待 4.显式等待 总结 前言 在前一篇文章中&#xff0c;我们介绍了自动化的一些基础知识&a…

Rust 力扣 - 746. 使用最小花费爬楼梯

文章目录 题目描述题解思路题解代码题目链接 题目描述 题解思路 我们使用a&#xff0c;b分别记录n - 2层向上爬的最小花费&#xff0c;n - 1层向上爬的最小花费 到达楼梯顶第N层&#xff0c;只能从N - 1层或者N - 2层向上爬 所以爬到第N层的最小花费 第N - 1层向上爬和第N - …

VRT: 关于视频修复的模型

VRT: 关于视频修复的模型 1. 视频修复的背景与重要性背景介绍&#xff1a;重要性&#xff1a; 2. VRT的重要性和研究背景VRT的背景&#xff1a;VRT的重要性&#xff1a; 3. 视频修复概述3.1 定义与目标3.2 与单图像修复的区别3.3 对时间信息利用的需求 4. VRT模型详解4.1 整体框…