【UI自动化测试】6_web自动化测试 _浏览器操作

文章目录

  • 一、浏览器操作
    • [1.1 浏览器操作](#1.1 浏览器操作)
    • [1.2 示例代码](#1.2 示例代码)
  • 二、浏览器操作-案例
    • [2.1 示例1-最大化、位置、大小、前进后退](#2.1 示例1-最大化、位置、大小、前进后退)
    • [2.2 示例2-refresh、close、quit、title、current_rul](#2.2 示例2-refresh、close、quit、title、current_rul)

一、浏览器操作

1、问题:

  • 脚本启动浏览器窗口大小默认不是全屏?
  • 如何刷新页面?

答:通过调用Selenium的API来实现浏览器的操作

1.1 浏览器操作

python 复制代码
# 设置浏览器显示范围
driver.maximize_window() 				窗口最大化 --> 模拟浏览器最大化按钮
driver.set_window_size(width, height) 	设置窗口大小 --> 设置浏览器宽、 高(像素点)
driver.set_window_position(x, y) 		设置窗口位置 --> 设置浏览器位置


# 浏览器显示页面操作
driver.back() 				后退 --> 模拟浏览器后退按钮(浏览器不能开新窗口)
driver.forward() 			前进 --> 模拟浏览器前进按钮
driver.refresh()            刷新 --> 模拟浏览器F5刷新

当前窗口:创建驱动时第一个打开的窗口,对于当前窗口的元素一般都可以直接定位和操作,如果弹出新的窗口,对于新的窗口元素是不能直接进行操作,需要学习后续的窗口切换。

python 复制代码
# 浏览器关闭操作
driver.close()               关闭当前窗口 --> 模拟点击浏览器关闭按钮
driver.quit() 	             关闭浏览器 --> 关闭所有程序启动的窗口


# 获取浏览器信息
driver.title                 获取标题(判断窗口的唯一标识。利用title切换不同的窗口)
driver.current_url           获取当前页面URL

1.2 示例代码

python 复制代码
# 最大化浏览器
driver.maximize_window()

# 刷新,应用场景:cookie使用到
driver.refresh()

# 后退
driver.back()

# 前进
driver.forward()

# 设置浏览器大小
driver.set_window_size(300,300)

# 设置浏览器位置
driver.set_window_position(300,200)

# 关闭浏览器单个窗口
driver.close()

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


# 应用场景:一般为判断上步操作是否执行成功
# 获取title,driver.title没有括号
title = driver.title
# 获取当前页面url,driver.current_url没有括号
url = driver.current_url

二、浏览器操作-案例

2.1 示例1-最大化、位置、大小、前进后退

python 复制代码
# 导包
from selenium import webdriver
from time import sleep

# 获取浏览器驱动对象
driver = webdriver.Chrome()
# 打开url
url = r"https://news.baidu.com/"
driver.get(url)

# 将浏览器 最大化
driver.maximize_window()
# 暂停2秒
sleep(2)
# 设置固定大小 300,200
driver.set_window_size(300, 200)
# 暂停2秒
sleep(2)
# 移动浏览器窗口位置 x:320,y:150
driver.set_window_position(320, 150)
# 暂停2秒
sleep(2)
# 最大化
driver.maximize_window()
# 点击 访问百度新闻中的润物无声文章  注意:要演示后退功能,必须先执行打开新的网站
driver.find_element_by_partial_link_text("润物无声").click()  # 不能开新窗口,不然后退无效
# 暂停2秒
sleep(2)
# 执行后退 --->
driver.back()
# 暂停2秒
sleep(2)
# 执行前进 -->百度新闻 注意:前进必须放到后退操后执行。
driver.forward()
# 暂停 2
sleep(2)
# 关闭驱动对象
driver.quit()

2.2 示例2-refresh、close、quit、title、current_rul

python 复制代码
# 导包
from selenium import webdriver
from time import sleep

# 获取浏览器驱动对象
driver = webdriver.Chrome()
# 将浏览器 最大化
driver.maximize_window()
# 打开url
url = r"https://news.baidu.com/"
driver.get(url)

#  目的:刷新完成--清空
driver.find_element_by_css_selector("#ww").send_keys("我爱你")
# 暂停2秒
sleep(2)
# 刷新
driver.refresh()
# 获取title
title = driver.title
print("当前页面title为:", title)
# 获取当前url
current_rul = driver.current_url
print("当前页面url地址为:", current_rul)

# 点击 润物无声网页 打开新窗口
driver.find_element_by_partial_link_text("润物无声").click()
# 暂停 3秒
sleep(3)
# 关闭主窗口,窗口默认打开页面的窗口
driver.close()
# 暂停 2
sleep(2)
# 关闭驱动对象
driver.quit()

当前页面title为: 百度新闻------海量中文资讯平台

当前页面url地址为: https://news.baidu.com/

相关推荐
Можно21 小时前
深入理解 ES6 Proxy:与 Object.defineProperty 的全面对比
前端·javascript·vue.js
Birdy_x21 小时前
接口自动化项目实战(1):requests请求封装
开发语言·前端·python
天天向上10241 天前
vue el-table实现拖拽排序
前端·javascript·vue.js
柳杉1 天前
Three.js × Blender:从建模到 Web 3D 的完整工作流深度解析
前端·javascript·数据可视化
reembarkation1 天前
vue3中使用howler播放音频列表
前端·vue.js·音视频
手握风云-1 天前
基于 Java 的网页聊天室(三)
服务器·前端·数据库
weixin199701080161 天前
《识货商品详情页前端性能优化实战》
前端·性能优化
Forever7_1 天前
重磅!Vue3 手势工具正式发布!免费使用!
前端·前端框架·前端工程化
用户806138166591 天前
发布为一个 npm 包
前端·javascript
树上有只程序猿1 天前
低代码何时能出个“秦始皇”一统天下?我是真学不动啦!
前端·后端·低代码