安装Selenium进行web⾃动化测试

2024-09-04 17:44

本文主要是介绍安装Selenium进行web⾃动化测试,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 驱动
  • 安装驱动管理工具
  • selenium安装
  • selenium+驱动+浏览器的⼯作原理
  • 自动化测试常⽤函数
    • 1. 元素定位
      • 1.1. `find_element` 的基本用法
      • 1.2. 常见的 `find_element` 定位方式
      • 1.3. `find_element` 的使用注意事项
      • 1.4. `find_element` 的进阶用法
  • 2. 操作测试对象
  • 3. 窗口操作
    • 4. 屏幕截图
    • 5. 弹窗处理
    • 6. 等待机制
    • 7. 浏览器
    • 8.文件上传


驱动

程序想要打开web浏览器就需要安装web驱动(即WebDriver),WebDriver 以本地化⽅式驱动浏览器

安装驱动管理工具

若通过安装驱动的⽅式来启动浏览器,每次浏览器更新后对应的驱动也需要更新,为了解决这个问题,selenium中提供了驱动管理⼯具webdriver-manager,有了webdriver-manager⽆需⼿动安装浏览器驱动,即使浏览器更新也不会影响⾃动化的执⾏。

pip install webdriver-manager

WebDriver Manager是⼀个开源的命令⾏⼯具,它可以⾃动下载和安装适⽤于不同浏览器的WebDriver。通过使⽤WebDriver Manager,我们可以确保浏览器驱动版本始终与浏览器版本保持⼀致,从⽽避免因版本不匹配⽽导致的各种问题。

selenium安装

Selenium是广泛使用的模拟浏览器运行的库,它是一个用于Web应用程序测试的工具。 Selenium测试直接运行在浏览器中,就像真正的用户在操作一样,并且支持大多数现代 Web 浏览器。
通过pip安装

pip install selenium

selenium+驱动+浏览器的⼯作原理

实现web⾃动化测试需要浏览器、浏览器驱动、selenium⾃动化脚本。

  1. 通过selenium编写的⾃动化脚本代码中在ChromeDriverService中创建⼀个服务
  2. 通过创建好的服务打开webdriver,安装在本地的驱动服务IP为localhost,PORT为ChromeDriverService中创建的端⼝号,该服务地址为selenium向webdriver发送请求的服务地址。
  3. 向浏览器驱动程序发送HTTP请求,浏览器驱动程序解析请求,打开浏览器,并获得sessionid,如果再次对浏览器操作需携带此id。
  4. 打开浏览器后,所有的selenium的操作(访问地址,查找元素等)均通过创建好的服务链接到
    webdriver,然后使⽤execute发送请求。
  5. 驱动收到请求并对请求进⾏解析,转成浏览器能够解析的脚本并发送给浏览器,浏览器通过请求的内容执⾏对应动作
  6. 浏览器再把执⾏的动作结果通过浏览器驱动程序返回给测试脚本。
    在这里插入图片描述

自动化测试常⽤函数

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

1. 元素定位

在Web自动化测试中,找到页面对应的元素是执行操作的关键。常见的元素定位方式包括idclassnametagnamexpathcssSelector等。其中,cssSelectorxpath最为常用。

  • cssSelector:通过选择器来选中页面中的指定标签元素,可以使用基础选择器和复合选择器。例如,定位百度首页的搜索输入框元素可以使用#kw,定位“百度一下”按钮可以使用#su

  • xpath:使用路径表达式在HTML文档中选取节点。它支持定位HTML页面中的所有节点、指定节点、直接子节点、父节点等。
    find_element 是自动化测试中最常用的函数之一,尤其是在使用 Selenium 进行 Web 自动化测试时。它用于在页面上定位一个元素,并返回一个 WebElement 对象,以便后续对该元素进行操作。

1.1. find_element 的基本用法

find_element 通常与多种定位方式(如 By.ID, By.CLASS_NAME, By.XPATH, By.CSS_SELECTOR 等)一起使用。这些定位方式帮助开发者根据页面元素的属性(如 ID、类名、标签名、XPath 等)来查找特定的元素。

from selenium import webdriver
from selenium.webdriver.common.by import By# 初始化浏览器驱动
driver = webdriver.Chrome()# 打开一个网页
driver.get("https://www.example.com")# 使用 find_element 定位元素
element = driver.find_element(By.ID, "element_id")

在这个例子中,find_element 函数用于通过元素的 ID 来定位页面上的一个元素,并将其赋值给 element 变量。

1.2. 常见的 find_element 定位方式

  • By.ID:通过元素的 ID 属性查找。

    element = driver.find_element(By.ID, "element_id")
    
  • By.CLASS_NAME:通过元素的 class 属性查找。

    element = driver.find_element(By.CLASS_NAME, "class_name")
    
  • By.XPATH:通过 XPath 表达式查找元素。

    element = driver.find_element(By.XPATH, "//tag[@attribute='value']")
    
  • By.CSS_SELECTOR:通过 CSS 选择器查找元素。

    element = driver.find_element(By.CSS_SELECTOR, ".class_name #element_id")
    

1.3. find_element 的使用注意事项

  • 元素唯一性find_element 只会返回匹配的第一个元素,如果页面上有多个符合条件的元素,只有第一个会被返回。

  • 元素未找到:如果找不到匹配的元素,find_element 会抛出 NoSuchElementException 异常。因此,在实际使用中,可以结合 try-except 语句来处理找不到元素的情况。

    try:element = driver.find_element(By.ID, "non_existent_id")
    except NoSuchElementException:print("元素未找到")
    
  • 隐式等待:为了提高元素查找的可靠性,可以在查找元素之前设置隐式等待时间,让 WebDriver 在查找元素时等待一段时间,以确保页面元素已经加载完成。

    driver.implicitly_wait(10)  # 等待最多10秒
    element = driver.find_element(By.ID, "element_id")
    

1.4. find_element 的进阶用法

除了查找单一元素之外,Selenium 还提供了 find_elements 方法,用于查找页面上符合条件的所有元素,并返回一个元素列表。这在需要对多个元素进行批量操作时非常有用。

elements = driver.find_elements(By.CLASS_NAME, "common_class")
for element in elements:print(element.text)

2. 操作测试对象

定位到元素后,接下来需要对元素进行操作,如点击、提交、输入、清除、获取文本等。

  • 点击/提交对象:通过click()方法可以点击指定元素。例如,点击百度首页的“百度一下”按钮:

    driver.find_element(By.CSS_SELECTOR, "#su").click()
    
  • 模拟按键输入:使用send_keys()方法可以模拟用户输入。例如,在百度搜索框中输入“迪丽热巴”:

    driver.find_element(By.CSS_SELECTOR, "#kw").send_keys("迪丽热巴")
    
  • 清除⽂本内容:使用clear()方法可以清除⽂本内容

driver.find_element(By.CSS_SELECTOR, "#kw").send_keys("迪丽热巴")
time.sleep(1)
driver.find_element(By.CSS_SELECTOR,"#kw").clear()
time.sleep(1)
driver.find_element(By.CSS_SELECTOR, "#kw").send_keys("古⼒娜扎")
  • 获取文本信息: text
text = driver.find_element(By.XPATH,'//*[@id="hotsearch-contentwrapper"]/li[1]/a/span[2]').text
print(f"text:{text}")
  • 获取当前页面标题和url
title = driver.title
url = driver.current_url

3. 窗口操作

在自动化测试中,经常需要处理多个浏览器窗口。通过句柄(handle)可以在不同窗口间切换。

  • 切换窗口:获取当前页面句柄和所有页面句柄后,可以循环判断并切换到最新的窗口
    curWindow = driver.current_window_handle
    allWindows = driver.window_handlesfor window in allWindows:if window != curWindow:driver.switch_to.window(window)
    
  • 窗口大小
#窗⼝最⼤化
driver.maximize_window()
#窗⼝最⼩化
driver.minimize_window()
#窗⼝全屏
driver.fullscreen_window()
#⼿动设置窗⼝⼤⼩
driver.set_window_size(1024,768)

4. 屏幕截图

driver.save_screenshot('../images/image.png')
#⾼阶版本
filename = "autotest-"+datetime.datetime.now().strftime('%Y-%m-%d-
%H%M%S')+'.png'
driver.save_screenshot('../images/'+filename)

5. 弹窗处理

在遇到页面弹窗时,可以使用Selenium提供的Alert接口进行处理。

  • 警告弹窗与确认弹窗:使用alert.accept()alert.dismiss()分别处理确认和取消操作。

    alert = driver.switchTo.alert;
    alert.accept();  // 确认
    alert.dismiss() ; //取消
    
  • 提示弹窗

alert.send_keys("hello")
alert.accept()
alert.dismiss()

6. 等待机制

由于代码执行速度通常比页面渲染速度快,为避免误报,需要引入等待机制。Selenium提供了三种等待方式:

  • 强制等待:使用time.sleep()强制等待指定时间。

优点:使⽤简单,调试的时候⽐较有效
缺点:影响运⾏效率,浪费⼤量的时间

  • 隐式等待:通过implicitly_wait()设置全局的等待时间,智能地等待元素加载。

优点:智能等待,作⽤于全局

  • 显式等待:使用WebDriverWaitExpectedConditions类自定义条件,灵活等待。

优点:显⽰等待是智能等待,可以⾃定义显⽰等待的条件,操作灵活
缺点:写法复杂

ps:不要混合隐式和显式等待,可能会导致不可预测的等待时间。

7. 浏览器

常⻅操作:
1)打开⽹站

driver.get("https://tool.lu/")

2)浏览器的前进、后退、刷新

driver.forward()
driver.back()
driver.refresh()

为了满足不同的测试需求,可以通过设置浏览器参数来调整测试环境。

  • 无头模式:在没有界面的环境中运行浏览器测试。
options = webdriver.ChromeOptions()
options.add_argument("-headless")
driver = 
webdriver.Chrome(service=ChromeService(ChromeDriverManager().install()),options
=options)
  • 页面加载策略:调整页面加载方式,提高测试效率。例如,使用eager策略仅等待DOM加载完成,而其他资源可以继续加载。
options.page_load_strategy = '加载⽅式'

⻚⾯加载⽅式主要有三种类型:

策略说明
normal默认值, 等待所有资源下载
eagerDOM 访问已准备就绪, 但诸如图像的其他资源可能仍在加载
none完全不会阻塞WebDriver
options = webdriver.ChromeOptions()
options.page_load_strategy = 'eager'
driver = 
webdriver.Chrome(service=ChromeService(ChromeDriverManager().install()),options
=options)

8.文件上传

点击⽂件上传的场景下会弹窗系统窗⼝,进⾏⽂件的选择。
selenium⽆法识别⾮web的控件,上传⽂件窗⼝为系统⾃带,⽆法识别窗⼝元素,但是可以使⽤sendkeys来上传指定路径的⽂件,达到的效果是⼀样的。

driver.get("file: ")
ele = driver.find_element(By.CSS_SELECTOR,"body > div > div > input[type=file]")
ele.send_keys("  ")

这篇关于安装Selenium进行web⾃动化测试的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1136595

相关文章

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

使用Python进行文件读写操作的基本方法

《使用Python进行文件读写操作的基本方法》今天的内容来介绍Python中进行文件读写操作的方法,这在学习Python时是必不可少的技术点,希望可以帮助到正在学习python的小伙伴,以下是Pyth... 目录一、文件读取:二、文件写入:三、文件追加:四、文件读写的二进制模式:五、使用 json 模块读写

Spring常见错误之Web嵌套对象校验失效解决办法

《Spring常见错误之Web嵌套对象校验失效解决办法》:本文主要介绍Spring常见错误之Web嵌套对象校验失效解决的相关资料,通过在Phone对象上添加@Valid注解,问题得以解决,需要的朋... 目录问题复现案例解析问题修正总结  问题复现当开发一个学籍管理系统时,我们会提供了一个 API 接口去

龙蜥操作系统Anolis OS-23.x安装配置图解教程(保姆级)

《龙蜥操作系统AnolisOS-23.x安装配置图解教程(保姆级)》:本文主要介绍了安装和配置AnolisOS23.2系统,包括分区、软件选择、设置root密码、网络配置、主机名设置和禁用SELinux的步骤,详细内容请阅读本文,希望能对你有所帮助... ‌AnolisOS‌是由阿里云推出的开源操作系统,旨

使用zabbix进行监控网络设备流量

《使用zabbix进行监控网络设备流量》这篇文章主要为大家详细介绍了如何使用zabbix进行监控网络设备流量,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录安装zabbix配置ENSP环境配置zabbix实行监控交换机测试一台liunx服务器,这里使用的为Ubuntu22.04(

Ubuntu系统怎么安装Warp? 新一代AI 终端神器安装使用方法

《Ubuntu系统怎么安装Warp?新一代AI终端神器安装使用方法》Warp是一款使用Rust开发的现代化AI终端工具,该怎么再Ubuntu系统中安装使用呢?下面我们就来看看详细教程... Warp Terminal 是一款使用 Rust 开发的现代化「AI 终端」工具。最初它只支持 MACOS,但在 20

mysql-8.0.30压缩包版安装和配置MySQL环境过程

《mysql-8.0.30压缩包版安装和配置MySQL环境过程》该文章介绍了如何在Windows系统中下载、安装和配置MySQL数据库,包括下载地址、解压文件、创建和配置my.ini文件、设置环境变量... 目录压缩包安装配置下载配置环境变量下载和初始化总结压缩包安装配置下载下载地址:https://d