UI自动化-(web端元素操作&浏览器操作入门)

1. 元素操作

Selenium之元素操作

Selenium是一种常用的自动化测试工具,它提供了一组丰富的API来操作浏览器和页面元素。

下面列举了selenium中几种常见的元素操作方法:
  • send_keys():用于向元素发送键盘按键。
    • send_keys()方法通常用于模拟用户在元素上输入文本或键盘按键。通过调用这个方法并传递要输入的文本,可以将文本发送到相应的元素,例如输入框、文本域等。
  • .click():用于点击元素。
    • .click()方法用于模拟鼠标点击操作。它可以用于点击按钮、链接、单选按钮、复选框等可点击的元素。
  • .clear():用于清空元素中的内容。
    • .clear()方法用于清空元素的内容。例如,它可以用于清空输入框中的文本,使其变为空白。
  • 代码示例
# 导包
import time
from selenium import webdriver
from selenium.webdriver.common.by import By

# 创建浏览器驱动对象
driver = webdriver.Chrome()

# 打开百度网站
driver.get("https://www.baidu.com")

# 通过ID定位到输入框并输入"百度一下,你就知道!"
driver.find_element(By.ID, 'kw').send_keys("百度一下,你就知道!")

# 等待2S,清除输入的内容
time.sleep(2)
driver.find_element(By.CLASS_NAME, 's_ipt').clear()

# 等待2S,通过name定位到输入框并输入"新闻"
time.sleep(2)
driver.find_element(By.NAME, 'wd').send_keys("新闻")

# 点击"百度一下"按钮:
driver.find_element(By.ID, 'su').click()

time.sleep(2)
# 退出
driver.quit()

2. 浏览器操作

2.1.1. 浏览器常用操作方法

1. maximize_window()

最大化浏览器窗口 模拟操作浏览器最大化按钮(一般 实例化浏览器驱动之后,就可以调用窗口最大化的方法把浏览器置为最大化)

2. set_window_size(width, height)

设置浏览器窗口大小 设置浏览器宽、高(像素点)

3.set_window_position(x, y)

设置浏览器窗口位置 设置浏览器位置 x,y是一个坐标点,通过此坐标点确定浏览器最左上角的位置,以此确定浏览器在屏幕上的位置。(注意x, y不能超过屏幕的分辨率大小 )

代码示例:

# 导包
import time
from selenium import webdriver

# 实例化浏览器驱动
driver = webdriver.Chrome()

# 打开百度网站
driver.get("https://www.baidu.com")

# 最大化浏览器窗口
time.sleep(3)
driver.maximize_window()

# 设置浏览器窗口大小
time.sleep(3)
driver.set_window_size(1024, 800)

# 设置浏览器窗口位置
time.sleep(3)
driver.set_window_position(200, 200)

# 执行其他浏览器操作,如打开网页、填写表单等...
time.sleep(3)

# 关闭浏览器窗口
driver.quit()

在上述代码中,使用 maximize_window() 方法最大化浏览器窗口,使用 set_window_size() 方法设置浏览器窗口的大小,以及使用 set_window_position() 方法设置浏览器窗口的位置。

注意set_window_position() 方法中的 x 和 y 值需要根据你的需求进行设置,确保它们不超过屏幕的分辨率大小。

4. back() 后退 模拟点击浏览器后退按钮

5. forward() 前进 模拟点击浏览器前进按钮

6. refresh() 刷新 模拟点击浏览器的刷新按钮

7. close() 关闭当前窗口 模拟点击浏览器关闭按钮

8.quit() 关闭浏览器驱动对象 关闭所有程序启动的窗口

代码示例:

# 导包
import time
from selenium import webdriver
from selenium.webdriver.common.by import By

# 实例化浏览器驱动
driver = webdriver.Chrome()

# 打开百度网站
driver.get("https://www.baidu.com")

# 最大化浏览器窗口
driver.maximize_window()
time.sleep(3)

# 通过name定位到输入框并输入"新闻",点击"百度一下"按钮
driver.find_element(By.NAME, 'wd').send_keys("新闻")
driver.find_element(By.ID, 'su').click()

# 调用浏览器的后退
time.sleep(3)
driver.back()

# 调用浏览器的前进
time.sleep(3)
driver.forward()

# 调用浏览器的刷新按钮
time.sleep(3)
driver.refresh()

# 调用浏览器的后退,定位到"hao123"网站并点击
time.sleep(3)
driver.back()
time.sleep(2)
driver.find_element_by_link_text("hao123").click()

# 关闭当前浏览器窗口
time.sleep(3)
driver.close()

# 退出浏览器,释放资源
time.sleep(3)
driver.quit()

上述方法分别模拟了浏览器的后退、前进、刷新和关闭按钮的操作。driver.close() 方法用于关闭当前窗口,而 driver.quit() 方法用于关闭整个浏览器驱动对象,关闭所有由该驱动对象启动的窗口。

注意确保在使用完毕后,正确调用 driver.quit() 来关闭浏览器驱动对象,以释放相关资源。

9. title 获取页面title

10. current_url 获取当前页面URL

代码示例

# 导包
import time
from selenium import webdriver
from selenium.webdriver.common.by import By

# 实例化浏览器驱动
driver = webdriver.Chrome()

# 打开百度网站
driver.get("https://www.baidu.com")

# 最大化浏览器窗口
driver.maximize_window()

# 获取页面标题(百度一下,你就知道)
title = driver.title

# 获取页面的URL地址(https://www.baidu.com/)
current_url = driver.current_url

# 等待3S
time.sleep(3)

# 退出
driver.quit()

上述代码用户获取页面的标题(title)和当前页面的 URL

3. 总结

以上操作示例是一个初步的入门指南,实际的 UI 自动化可能会涉及更复杂的场景和技术。深入学习和实践才能更好地掌握 Web 端元素操作和浏览器操作的技能。同时,也要注意遵循良好的自动化测试实践,例如测试用例设计、测试数据管理等。

  1. 选择自动化工具:市面上有多种 UI 自动化工具可供选择,如 Selenium、 Puppeteer 等。根据你的项目需求和技术栈,选择一个适合的工具。
  2. 了解 Web 元素操作:学习如何识别和操作 Web 页面中的元素,例如点击按钮、输入文本、选择选项等。这通常涉及使用工具提供的选择器来定位元素。
  3. 掌握浏览器操作:了解如何启动、关闭浏览器,以及切换窗口、加载页面等基本操作。
  4. 设置测试环境:安装所需的浏览器和相关驱动程序,并配置自动化工具以与浏览器进行集成。
  5. 编写自动化脚本:使用所选的编程语言(如 Python、Java 等)编写脚本来执行具体的操作,例如打开网站、执行用户交互、验证结果等。
  6. 处理动态元素:Web 页面中的元素可能是动态生成的,需要使用特定的技巧来处理这些动态元素,例如等待元素出现、动态定位等。
  7. 测试和调试:运行自动化脚本,并使用调试工具来检查脚本的执行情况,解决可能出现的问题。
  8. 集成持续集成:将 UI 自动化集成到持续集成/持续部署(CI/CD)管道中,以确保自动化测试在每次代码变更后都能运行。
  • 26
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值