🔥 交流讨论:欢迎加入我们一起学习!
🔥 资源分享:耗时200+小时精选的「软件测试」资料包
🔥 教程推荐:火遍全网的《软件测试》教程
📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正!
elenium简介
1、什么是Selenium
Selenium
是支持 Web
浏览器自动化的一系列工具和库的综合项目。
它提供了扩展来模拟用户与浏览器的交互,用于扩展浏览器分配的分发服务器, 以及用于实现 W3C WebDriver
规范的基础结构, 该 规范 允许您为所有主要 Web
浏览器编写可互换的代码。
Selenium
的核心是 WebDriver
,这是一个编写指令集的接口,可以在许多浏览器中互换运行。
Selenium
最初是一个自动化测试工具,而爬虫中使用它主要是为了解决Requests
无法执行JavaScript
代码的问题。
三大组件
Selenium
不仅仅是一个工具或 API
, 它还包含许多工具如:
Selenium WebDriver
WebDriver
以本地化方式驱动浏览器,是一个浏览器自动化测试的 API集合。它提供了很多与浏览器自动化交互的特性,并且这些API主要是用于测试Web程序。
提供相对应的 API
来操作浏览器,比如:Chrome
、FireFox
、IE
等
Selenium WebDriver
指的是语言绑定和各个浏览器控制代码的实现。这通常被称为 WebDriver
。
Selenium WebDriver
是 W3C
推荐标准
-
WebDriver
被设计成一个简单和简洁的编程接口。 -
WebDriver
是一个简洁的面向对象 API。 -
它能有效地驱动浏览器。
Selenium IDE
是一款面向 Web
的录制与回放的自动化测试工具。这对于刚介入自动化的测试人员来说,从这个入手再好不过了。
Selenium Grid
Selenium Grid
允许通过将客户端发送的命令路由到远程浏览器实例来在远程机器上执行 WebDriver
脚本。
Grid
的目标:
-
提供一种在多台机器上并行运行测试的简单方法
-
允许在不同的浏览器版本上进行测试
-
启用跨平台测试
2、selenium的用途
*Selenium*
有很多功能, 但其核心是 Web
浏览器自动化的一个工具集, 它使用最好的技术来远程控制浏览器实例, 并模拟用户与浏览器的交互。
它允许用户模拟终端用户执行的常见活动;将文本输入到字段中,选择下拉值和复选框,并单击文档中的链接。它还提供许多其他控件,比如鼠标移动、任意 JavaScript
执行等等。
(1)Selenium
可以驱动浏览器自动执行自定义好的逻辑代码,也就是可以通过代码完全模拟成人类使用浏览器自动访问目标站点并操作,那我们也可以拿它来做爬虫。
(2)Selenium
本质上是通过驱动浏览器,完全模拟浏览器的操作,比如跳转、输入、点击、下拉等...进而拿到网页渲染之后的结果,可支持多种浏览器
3、Selenium的优缺点
(1)优点
开源免费
Selenium
是由志愿者开源贡献实现的,因此源代码免费提供给任何人使用,并且你可以通过这些源码进行修改及改进
跨平台多语言支持
Selenium
它是一个支持在多个不同的操作系统中执行,并且通过webdriver
协议(采用的w3c标准)规定了标准使得可以在任何语言都能够使用Selenium
,但目前Selenium
仅支持C#
,Ruby
,Java
,PHP
,Python
,JavaScript
等主流的编程语言,多平台目前支持windows
,Android
,mac
,Linux
。
多语言支持
跨浏览器支持
Selenium 也支持在不同的浏览器间进行测试,目前的主流浏览器都支持,目前能支持的浏览器内核有:
社区活跃出现问题能及时解决,
Selenium
起源 2004年,发展的时间接近快20年了,而且Selenium
的更新速度也非常积极与频繁,因此社区生态建设的也非常完善,且教程文档也比较齐全,现在只要你百度搜索相关Selenium
到处都是,因此Selenium
是我们测试工程师需要掌握的必不可少的工具。
支持移动端,
目前的Selenium
已经对移动端的浏览器提供了非常好的支持,用于测试H5
比Appium
要方便得多。
较为庞大的插件库,
Selenium
由于是开源的,少不了大佬们的各种魔改或者扩展开发,目前基于Selenium
开发或者扩展的工具多不下1000个,github
中随处可找到。
(2)缺点
需要编码能力才能上手,无法使用界面来进行编写自动化测试
由于目前测试倡导低代码,无代码测试,且不是任何一个测试人员都掌握的编程基础。因此如果不会编程基础的同学来讲Selenium
确实是需要一定的学习成本,由于Selenium
仅支持代码形式来做自动化测试,无法提供可视化界面来进行测试。
没有内置的图像比较及处理等方案
Selenium
本身对于图形处理能力较弱甚至并没有内置的图像处理及比较的解决方案,因此我们还需要自行去想办法解决图像相关的难题如:图形验证码,滑动块验证,Canvas
等
没有测试报告的能力
Selenium
本身不具备测试报告能力,这因此我们也需要借助其他第三方框架或者自行对测试报告做些相对应的解决方案处理。
没有官方的技术支持
由于是社区开源贡献者开发的,无法进行找到对应的官方负责团队进行提供技术支持
Selenium的安装
1、下载Selenium
模块:
pip install selenium==3.141.0
2、浏览器驱动下载
(1)Google
浏览器驱动:https://sites.google.com/a/chromium.org/chromedriver/downloads
国内访问:http://chromedriver.storage.googleapis.com/index.html
(2)firefox
浏览器驱动:https://github.com/mozilla/geckodriver/releases
(3)IE
浏览器驱动:http://selenium-release.storage.googleapis.com/index.html
(4)edge
浏览器驱动:https://developer.microsoft.com/en-us/microsoft-edge/tools/webdriver/
配置驱动环境
要想Selenium Client
能找到驱动程序有二种方式:
第一指定驱动路径(不配置PATH
环境变量):
-
from selenium import webdriver
-
browser = webdriver.Chrome(executable_path="D:\drivers\chromedriver.exe",options=options)
设置环境变量
配置Python
根目录环境,即可实现无需传递驱动程序的指定位置来启动webdriver
。
我的电脑 -> 属性 -> 高级系统设置
初识Selenium
第一个selenium脚本
我们现在可以开始创建和运行自动化测试脚本了,就从Selenium WebDriver
开始,然后创建一个Python
脚 本,用Selenium WebDriver
提供的类和方法模拟用户与 浏览器的交互。
我们会使用一个自行开发的Web应用程序,来完成我们后续的所有的实操示例。
一个简单的登录示例:
-
from selenium import webdriver
-
import time
-
# 实例化 webdriver
-
browser = webdriver.Chrome()
-
# 最大浏览器尺寸
-
browser.maximize_window()
-
# 浏览器输入url,并传送至指定的url页面
-
browser.get(url="http://127.0.0.1:8066/")
-
login_btn = browser.find_element_by_id("login-btn")
-
login_btn.click()
-
username = browser.find_element_by_id('username')
-
pwd = browser.find_element_by_id('password')
-
btu = browser.find_element_by_xpath('//*[@id="app"]/div[3]/div[2]/div[2]/button')
-
username.send_keys("13453001")
-
pwd.send_keys("123456")
-
btu.click()
-
time.sleep(10)
-
browser.quit()
使用Python
的IDLE来作为今后的练习环境,对初学者来说是一个极佳的学习体验。
该环境也称为Python
交互式环境,后续我们做项目的时候再来使用其他编辑器开发,学习,练习我们将使用交互式环境。
今天的分享就到此结束了, 如果文章对你有帮助,记得点赞,收藏,加关注。会不定期分享一些干货哦......
最后我邀请你进入我们的【软件测试学习交流群:785128166】, 大家可以一起探讨交流软件测试,共同学习软件测试技术、面试等软件测试方方面面,还会有免费直播课,收获更多测试技巧,我们一起进阶Python自动化测试/测试开发,走向高薪之路
作为一个软件测试的过来人,我想尽自己最大的努力,帮助每一个伙伴都能顺利找到工作。所以我整理了下面这份资源,现在免费分享给大家,有需要的小伙伴可以关注【公众号:程序员二黑】自提!