软件测试——自动化测试selenium常用函数

目录

元素的定位

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

cssSelector

选择器的功能:选中⻚⾯中指定的标签元素选择器的种类分为基础选择器和复合选择器,常⻅的元素定位⽅式可以通过id选择器和⼦类选择器来进⾏定位。

  • 打开开发者工具

  • 鼠标右键 copy selector

  • ctrl+f打开查找框,复制到查找框看是否是唯一定位

  • 无法唯一确定时,需要时要自己修改选择器

xpath

XML路径语⾔,不仅可以在XML⽂件中查找信息,还可以在HTML中选取节点。xpath使⽤路径表达式来选择xml⽂档中的节点。

xpath语法:

  • 获取HTML页面所有的节点
html 复制代码
//*
  • 获取HTML页面指定的节点
html 复制代码
//[指定节点]
//ul :获取HTML⻚⾯所有的ul节点
//input:获取HTML⻚⾯所有的input节点
  • 获取⼀个节点中的直接子节点
html 复制代码
/
//span/input
  • 获取⼀个节点的父节点
html 复制代码
..
//input/.. 获取input节点的⽗节点
  • 实现节点属性的匹配
html 复制代码
[@...]
//*[@id='kw'] 匹配HTML⻚⾯中id属性为kw的节点
  • 使⽤指定索引的⽅式获取对应的节点内容

    注意:xpath的索引是从1开始的。
    百度首页通过://div/ul/li[3] 定位到第三个百度热搜标签

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

注意:元素的定位⽅法必须唯⼀。建议选择selector。

问题:既然可以⼿动复制 selector/xpath的⽅式 ,为什么还有了解语法?

手动复制的selector/xpath表达式并不⼀定满⾜上⾯的唯一性的要求,有时候也需要⼿动的进行修改表达式,如:想要匹配到百度⾸⻚指定的新闻⽂本或者节点集,直接使⽤ #hotsearch-contentwrapper > li 不能满足

报错原因:浏览器版本太低与驱动管理器版本不匹配

更新后成功

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

函数

  • 在页面查找元素,返回值为Element
java 复制代码
findElement(By);
  • 在页面查找元素,返回值为List
java 复制代码
findElements(By);

操作测试对象

java 复制代码
public interface WebElement extends SearchContext, TakesScreenshot {
    void click();//点击 

    void submit();//提交 

    void sendKeys(CharSequence... keysToSend);//模拟键输入

    void clear();//清空

    String getTagName();

    default String getDomProperty(String name) {
        throw new UnsupportedOperationException("getDomProperty");
    }

    default String getDomAttribute(String name) {
        throw new UnsupportedOperationException("getDomAttribute");
    }

    String getAttribute(String name);//获取属性值

    default String getAriaRole() {
        throw new UnsupportedOperationException("getAriaRole");
    }

    default String getAccessibleName() {
        throw new UnsupportedOperationException("getAccessibleName");
    }

    boolean isSelected();

    boolean isEnabled();

    String getText();//获取文本信息

    List<WebElement> findElements(By by);

    WebElement findElement(By by);

    default SearchContext getShadowRoot() {
        throw new UnsupportedOperationException("getShadowRoot");
    }

    boolean isDisplayed();

    Point getLocation();

    Dimension getSize();

    Rectangle getRect();

    String getCssValue(String propertyName);
}
  • click 点击/提交对象
java 复制代码
 //找到百度⼀下按钮并点击
driver.findElement(By.cssSelector("#su")).click();//页面绝大多数区域都可以点击,不只是按钮,页面影藏的标签、不可见的标签不能点击
  • sendKeys("") 模拟按键输⼊
java 复制代码
driver.findElement(By.cssSelector("#kw")).sendKeys("输⼊⽂字");
  • clear() 清除文本内容
java 复制代码
driver.findElement(By.cssSelector("#kw")).sendKeys("我爱游戏");
driver.findElement(By.cssSelector("#kw")).clear();
driver.findElement(By.cssSelector("#kw")).sendKeys("我爱学习");
  • getText() 获取文本信息
java 复制代码
String bdtext = driver.findElement(By.xpath("//*[@id="title-content"]/span[1]")).getText();
System.out.println("打印的内容是:"+bdtext);

注意区分文本和属性值

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

注意:⽂本和属性值不要混淆。获取属性值需要使⽤⽅法 getAttribute("属性名称") ;

  • getTitle() 获取当前页面标题
  • getCurrentUrl() 获取当前页面URL

窗口

切换窗口

  • 获取当前页面句柄:
java 复制代码
driver.getWindowHandle(); //返回值String
  • 获取所有页面句柄:
java 复制代码
driver.getWindowHandles();//返回值Set<Sreing>
  • 切换当前句柄为最新页面:
java 复制代码
 String curWindow = driver.getWindowHandle();
 Set<String> allWindow = driver.getWindowHandles();
 for( String w : allWindow){
 if(w!=curWindow){
 driver.switchTo().window(w);
 }
 }

窗口设置大小

java 复制代码
 //窗⼝最⼤化
 driver.manage().window().maximize();
 //窗⼝最⼩化
 driver.manage().window().minimize();
 //全屏窗⼝
 driver.manage().window().fullscreen();
 //⼿动设置窗⼝⼤⼩
 driver.manage().window().setSize(new Dimension(1024, 768));

窗口切换

java 复制代码
//获取所有句柄
//获取当前停留⻚⾯句柄
 String curWindow = driver.getWindowHandle();
 Set<String> allWindow = driver.getWindowHandles();
 for( String w : allWindow){
 if(w!=curWindow){
 driver.switchTo().window(w);
 }
 }

​ 自动化一般不会存在打开好多个标签页 不要为难自己

屏幕截图

我们的⾃动化脚本⼀般部署在机器上⾃动的去运⾏,如果出现了报错,我们是不知道的,可以通过抓拍来记录当时的错误场景

  • 屏幕截图方法需要额外导⼊包:
java 复制代码
<dependency>
 <groupId>commons-io</groupId>
 <artifactId>commons-io</artifactId>
 <version>2.6</version>
 </dependency>
java 复制代码
	//屏幕截图
    void getScreenShot(String str) throws IOException {
        // /src/test/image/
        //                  /2024-08-23/
        //                             /test01-13470.png
        //                             /test02-13470.png
        //                  /2024-0-24/
        //                             /test01-12470.png
        //                             /test01-12470.png
        //屏幕截图
        SimpleDateFormat sim1 = new SimpleDateFormat("yyyy-MM-dd");
        SimpleDateFormat sim2 = new SimpleDateFormat("HHmmss");
        String dirTime = sim1.format(System.currentTimeMillis());
        String fileTime = sim2.format(System.currentTimeMillis());
        // .src/test/image/2024-08-24/test01-13470.png
        String filename ="./src/test/image/"+ dirTime + "/"+str + "-" + fileTime + ".png";
        System.out.println(filename);
        File srcFile = ((TakesScreenshot)driver).getScreenshotAs(OutputType.FILE);
        //scrFile放到指定位置
        FileUtils.copyFile(srcFile, new File(filename));
    }
    
+ 屏幕截图⽅法需要额外导⼊包:

~~~java
<dependency>
 <groupId>commons-io</groupId>
 <artifactId>commons-io</artifactId>
 <version>2.6</version>
 </dependency>
java 复制代码
File file = ((TakesScreenshot)webDriver).getScreenshotAs(OutputType.FILE);
 FileUtils.copyFile(file,new File(filename));

关闭窗口

java 复制代码
driver.close();//关闭当前标签页
 注意:窗⼝关闭后driver要重新定义
     
driver.quit(); //关闭浏览器、释放driver对象

等待

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

第一步:在报错的代码前添加Thread. sleep(秒),设置的时间长一点

第二步:执行自动化,在自动化打开的页面里打开前端开发者工具,手动检查元素是否真的不存在

  1. 自动化打开的页面确实不存在该元素
  • 手动打开的页面和自动化打开的页面不一样(很可能是登陆和未登录状态下页面不一样)
  • 元素为动态元素
  1. 自动化打开的页面确实存在该元素
  • 代码执行的速度比页面渲染的速度要快,页面还没渲染出来,程序已经开始找到了,导致元素没有找到解决办法 ---- 添加等待

通常代码执行的速度比页面渲染的速度要快,如果避免因为渲染过慢出现的⾃动化误报的问题呢?

可以使用selenium中提供的三种等待方法:

强制等待

  • Thread.sleep()
  • 优点:使用简单,调试的时候比较有效
  • 缺点:影响运行效率,浪费大量的时间

隐式等待

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

  • implicitlyWait() 参数:Duration类中提供的毫秒、秒、分钟等方法
  • 隐式等待作用域是整个脚本的所有元素
  • 优点:智能等待,作用于全局
  • 缺点:只能查找元素、每次查找元素都要等待
java 复制代码
 //隐式等待1000毫秒
 driver.manage().timeouts().implicitlyWait(Duration.ofMillis(1000));
 //隐式等待5秒
 driver.manage().timeouts().implicitlyWait(Duration.ofSeconds(5));

显示等待

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

java 复制代码
new WebDriverWait(driver, Duration.ofSeconds(3)).until($express)
  • $press:涉及到selenium.support.ui.ExpectedConditions包下的ExpectedConditions类
  • 返回值:boolean

ExpectedConditions预定义方法的一些示例:

  • elementToBeClickable(By locator) ‒ 用于检查元素的期望是可见的并已启用,以便可以单击。

  • textToBe(Bylocator,String str) - 检查元素。精确匹配

  • presenceOfElementLocated(Bylocator) ‒ 检查页⾯的 DOM 上是否存在元素。

  • urlToBe(java.lang.String url) ‒ 检查当前页面的 URL 是⼀个特定的 URL。

java 复制代码
WebDriverWait wait = new WebDriverWait(driver,Duration.ofSeconds(10));
2 boolean ispass = wait.until(ExpectedConditions.textToBe(By.cssSelector("#s-topleft > a:nth-child(1)"), "新闻"));
 if(ispass){
 System.out.println("测试通过");
 }else {
 System.out.println("测试失败");
 }
  • 优点:显式等待是智能等待,可以⾃定义显⽰等待的条件,操作灵活

  • 缺点:写法复杂、只做用在当前条件上

问题:显示等待和隐式等待一起使用会怎么样?

可能会导致不可预测的等待时间,谨慎使用

浏览器导航

  • 浏览器的前进、后退、刷新
java 复制代码
 driver.navigate().back();
 driver.navigate().forward();
 driver.navigate().refresh();
  • 打开网站
java 复制代码
// 更⻓的⽅法
 driver.navigate().to("https://selenium.dev");
 // 简洁的⽅法
 driver.get("https://selenium.dev");

​案例:百度首页测试https://tool.lu/标签⼊⼝

弹窗

弹窗是在⻚⾯是找不到任何元素的,这种情况怎么处理?

使⽤selenium提供的Alert接⼝

警告弹窗+确认弹窗

java 复制代码
 //切换弹窗
Alert alert = driver.switchTo.alert();
 //确认
 alert.accept()
 //取消
 alert.dismiss()

提示弹窗

java 复制代码
 Alert alert = driver.switchTo.alert();
 alert.sendKeys("hello");
 alert.accept();
 alert.dismiss();

文件上传

点击文件上传的场景下会弹窗系统窗口,进行文件的选择。selenium无法识别非web的控件,上传文件窗口为系统自带,无法识别窗口元素但是可以使用sendkeys来上传指定路径的文件,达到的效果是⼀样的

java 复制代码
WebElement ele = driver.findElement(By.cssSelector("body > div > div > 
input[type=file]"));
 ele.sendKeys("D:\\selenium2html\\selenium2html\\upload.html");

浏览器参数设置

  • 设置无头模式

  • 设置浏览器加载策略

相关推荐
王俊山IT10 分钟前
C++学习笔记----10、模块、头文件及各种主题(一)---- 模块(5)
开发语言·c++·笔记·学习
Yawesh_best1 小时前
思源笔记轻松连接本地Ollama大语言模型,开启AI写作新体验!
笔记·语言模型·ai写作
CXDNW3 小时前
【网络面试篇】HTTP(2)(笔记)——http、https、http1.1、http2.0
网络·笔记·http·面试·https·http2.0
使者大牙3 小时前
【大语言模型学习笔记】第一篇:LLM大规模语言模型介绍
笔记·学习·语言模型
ssf-yasuo3 小时前
SPIRE: Semantic Prompt-Driven Image Restoration 论文阅读笔记
论文阅读·笔记·prompt
ajsbxi3 小时前
苍穹外卖学习记录
java·笔记·后端·学习·nginx·spring·servlet
TeYiToKu3 小时前
笔记整理—linux驱动开发部分(9)framebuffer驱动框架
linux·c语言·arm开发·驱动开发·笔记·嵌入式硬件·arm
dsywws3 小时前
Linux学习笔记之时间日期和查找和解压缩指令
linux·笔记·学习
cuisidong19975 小时前
5G学习笔记三之物理层、数据链路层、RRC层协议
笔记·学习·5g
乌恩大侠5 小时前
5G周边知识笔记
笔记·5g