第3章 Selenium及浏览器 驱动的安装配置 Selenium是一款用于Web应用程序UI自动化测试的首选工具。本书第1章已经详细介绍过Selenium在运行自动化测试用例时的优势。与接口自动化相比,它更贴近真实用户使用场景,在UI层自动化测试上具有不可替代的作用。 本章主要内容分为两部分,Selenium的下载与安装及主流浏览器驱动的下载与调试。这是Web篇环境准备的最后一部分内容。 3.1Selenium的下载及安装 获取Selenium的最新特性,首选方式还是在Selenium官网下载相关文档进行新特性的了解与使用。Selenium官网网址是https://www.seleniumhp.dev,如图3.1所示。 图3.1Selenium官网首页 从Selenium官网可以看到目前Selenium体系的三大组成部分Selenium WebDriver、Selenium IDE和Selenium Grid,如图3.2所示。 图3.2Selenium体系的组成 本章需要安装配置的是Selenium WebDriver组件,基于Web自动化测试的后续学习也是围绕着这一部分展开的。Selenium IDE在早期是以FireFox窗口插件形式出现的。其主要功能是配合FireFox及Chrome浏览器完成脚本录制与回放操作,以及简单用例的管理与断言的实现。本书不再进行Selenium IDE相关功能的展示与讲解。Selenium Grid属于Selenium脚本运行时的一个多机并发架构实现,属于Selenium在使用过程中实现较为复杂的部分,相关安装配置与使用会在本书最后一章进行讲解。 3.1.1Selenium在线安装 Selenium最常用的安装方式为在线安装。第2章Python配置过程中已将Scripts目录配置进系统环境变量,在此基础上就可以进行在线安装了。 1. 安装 打开命令提示行工具,输入pip install selenium命令,按下回车键进行安装,如图3.3所示。 图3.3Selenium在线安装 少数情况下会出现安装失败提示。通常操作系统是Windows 10的时候有可能出现这种情况。这是因为Windows 10对pip命令的支持出现异常,此时用pip3命令进行安装就可以了。方法和上面所示pip的使用方法一样。 2. 验证 安装成功后输入python命令,按下回车键进入Python命令模式,输入import selenium,按下回车键进行验证,如图3.4所示。 图3.4Selenium验证 如果没有任何提示,就说明import导入Selenium包成功了,在线安装完成。 3. 指定版本安装 这种操作在实际工作环境中比较少见。常见的情况是在已经配置好的脚本框架中用到了某个版本的某些属性方法,而这些属性方法在新版本中被移除了,脚本修改起来又比较有难度,这时会考虑将Selenium进行降级安装。这种情况只涉及降级,因为在写一个脚本时不太可能用到未来Selenium版本的功能。在命令提示符窗口中输入pip install selenium==<指定版本号>后回车进行降级安装,如图3.5所示。 图3.5Selenium降级安装 3.1.2Selenium离线安装 还有一种更不常见的情况,就是所有在线安装方式都无法完成Selenium的安装。这种情况通常也出自Windows 10操作系统下,这时就需要使用离线安装模式了。如果你的Selenium已经安装成功,可以跳过此节。 首先需要在Selenium官网找到离线文件的下载位置。如果查找不方便,则可以输入https://pypi.org/project/selenium/#files直接定位到离线文件的位置,如图3.6所示。 图3.6Selenium离线文件下载 在页面中选择selenium3.141.0.tar.gz文件进行保存,然后解压文件。打开命令提示符窗口,进入解压后的目录。输入pip setup.py install命令按下回车键进行安装,如图3.7所示。 图3.7Selenium离线安装 图3.7所示结果为命令方式离线安装后的结果。安装完成后,使用3.1.1节的方法验证安装的正确性。 3.2基于FireFox浏览器的驱动配置 Selenium最早是作为FireFox浏览器的一个插件出现的,早期版本中的很多功能只能在FireFox浏览器中实现。例如早期的脚本录制插件Selenium IDE,最初只支持在FireFox下安装和使用。随着UI自动化测试在Web端的普及,Selenium对其他浏览器的功能支持也日趋完善。 3.2.1GeckoDriver驱动配置的下载与配置 基于FireFox浏览器的GeckoDriver驱动与浏览器的版本向上兼容性较差。随着浏览器版本的升级,常常会出现驱动失效的现象,因此需要有一个能够及时查找最新驱动的地方。 推荐一个好用的资源类网站,阿里云开发者社区中的镜像站。访问网址https://npm.taobao.org/mirrors,如图3.8所示。 图3.8NPM镜像站 在此处可以找到最新的FireFox浏览器和Chrome浏览器驱动文件,也可以到官网进行下载。单击图3.8中的geckodriver,进入驱动下载页,如图3.9所示。 图3.9GeckoDriver下载页面 找到最新的驱动版本,进入版本子目录,选择适合自己操作系统的版本进行下载。这里笔者选择了geckodriverv0.26.0win64.zip进行下载。下载完成后将文件解压并放入Python安装主目录的Scripts文件夹下即可。 3.2.2调用FireFox驱动测试 配置完成后,编写一段代码对配置驱动进行验证。此处验证有两个目的: 一是验证浏览器与驱动版本是否匹配; 二是验证Selenium安装是否正确。如果没有特殊情况,则后面几节的驱动验证不再进行说明,代码如下: #第3章/FirefoxDriverTest.py #引入selenium包 from selenium import webdriver #声明驱动对象并打开FireFox浏览器 driver = webdriver.Firefox() #打开百度首页 driver.get('http://www.baidu.com/') sleep(2) #暂停两秒 #关闭驱动及FireFox浏览器 driver.quit() 3.3基于Chrome浏览器的驱动配置 Chrome是一款由谷歌公司开发的网页浏览器。虽然现在国内不支持Google搜索引擎和它配套的应用商店功能,但作为浏览器本身的优点,其运行速度快、加载页面内容迅速,至今仍是Web架构软件运行浏览器的首选。 3.3.1ChromeDriver驱动配置的下载与配置 Chrome浏览器和FireFox浏览器相仿,版本更新比较频繁。ChromeDriver的优点是对浏览器版本兼容性比较好,一般不会存在版本兼容问题,从而导致无法调用浏览器的情况。ChromeDriver驱动下载的网址见3.2.2节中的阿里云开发者社区镜像站,如图3.10所示。 图3.10ChromeDriver下载页面 页面中的版本在后期是与浏览器版本一一对应的,驱动更新速度快,通常会与浏览器同步升级。读者可以在这里找到与你所用Chrome浏览器版本相近的驱动进行下载。下载完成后解压并放至Python主目录下的Scripts目录下即可。 3.3.2调用Chrome驱动测试 调用Chrome驱动浏览器,代码如下: #第3章/ChromeDriverTest.py #引入selenium包 from selenium import webdriver #声明驱动对象并打开Chrome浏览器 driver = webdriver.Chrome() #打开百度首页 driver.get('http://www.baidu.com/') sleep(2) #暂停两秒 #关闭驱动及Chrome浏览器 driver.quit() 3.4基于IE浏览器的驱动配置 IE是一款在Web软件领域使用最久的浏览器。微软将在2020年1月结束对IE 10的支持,IE 11将会成为IE浏览器的最后一次更新。大多数网站在开发过程中会对IE浏览器的兼容性进行测试。IE浏览器的Trident内核至今仍被很多国内主流浏览器所支持,因此对IE浏览器的UI层测试,在最近几年内仍将持续进行。 3.4.1IEDriverServer驱动配置的下载与配置 目前微软官网已不提供IEDriverServer的下载,前面推荐的镜像站里也没有相关驱动。这里分享一个资源链接http://seleniumrelease.storage.googleapis.com/index.html,如图3.11所示。在这个资源网站中可以找到支持Selenium的各种IEDriverServer版本,可根据实际情况选择相关驱动版本。 图3.11IEDriverServer下载页面 3.4.2调用IE驱动测试 调用IE驱动浏览器,代码如下: #第3章/IEDriverTest.py #引入selenium包 from selenium import webdriver #声明驱动对象并打开IE浏览器 driver = webdriver.Ie() #打开百度首页 driver.get('http://www.baidu.com/') sleep(2) #暂停两秒 #关闭驱动及IE浏览器 driver.quit() 图3.12Internet选项 在运行这段代码的时候,有时会报Unexpected error launching Internet Explorer. Protected Mode settings are not the same for all zones错误,翻译成中文就是“启动Internet Explorer时出现意外错误。所有区域的保护模式设置不同”。这个错误和3.4.1节配置的驱动没有什么关联,主要是IE浏览器设置的问题。打开IE浏览器→工具菜单→Internet选项→安全选项卡,如图3.12所示。 将安全选项卡中所标注的四项的“启动保护模式”全部设置为失选或全选状态。这里要求4个选项必须统一。选择完成后,单击“确定”按钮保存更改。再次运行测试代码,就可以正常调用及运行IE浏览器并打开百度首页了。 3.5第一个Web自动化测试脚本 至此,Web篇所用到的环境配置就全部完成了。接下来需要设计一个操作较为复杂的脚本实例来验证环境的正确性,在正式开始对Selenium进行讲解之前来感受一下用例自动化的过程。前面调试了三款主流浏览器驱动,在后续章节里,将以Chrome浏览器为主进行相关知识的讲解。有特殊情况需要换驱动操作的会进行特别说明。 下面根据自动化测试脚本的流程设计一段代码。代码中所涉及细节在后面章节会进行讲解,此处只针对流程本身进行讲解。在正式开始学习自动化测试知识前,先进行一次感性接触。 1. 手工用例准备 所有的自动化测试用例最早都来源于手工用例。多数情况下,UI自动化测试用来做回归,因此可以直接把手工用例中的正向用例部分直接转换成自动化测试脚本。本次被测网站使用百度新闻网页进行验证。 【例3.1】百度新闻搜索测试。 步骤1: (1) 打开百度新闻首页。 (2) 在打开的页面上单击热点新闻。 (3) 关闭热点新闻页面。 (4) 在百度新闻搜索框中输入新闻内容,单击“搜索”按钮。 步骤2: 热点新闻在新页面打开,内容与标题一致。 在这个最基本的手工测试用例中只对步骤2做预期判断。 2. 自动化脚本 自动化测试脚本实现过程如下: (1) 调用驱动,打开Chrome浏览器。 (2) 输入网址,打开百度新闻网站。 (3) 单击热点新闻第一条,对弹出热点新闻做结果判断。 (4) 关闭热点新闻页面。 (5) 在百度新闻搜索框中输入关键字进行搜索。 (6) 对最终搜索内容做结果判断。 将上述内容用Python脚本实现,代码如下: #第3章/TestBaiDuNews.py from selenium import webdriver from time import sleep driver = webdriver.Chrome() driver.get('http://news.baidu.com/') #单击当天热点新闻 sleep(1) driver.find_element_by_xpath('//*[@id="pane-news"]/div/ul/li[1]/strong/a[1]').click() #切换句柄 search_Windows = driver.current_window_handle all_handles = driver.window_handles for handle in all_handles: if handle != search_Windows: driver.switch_to.window(handle) #结果判断,''内根据当时热点新闻关键字进行修改 assert '' in driver.title #关闭当前页 sleep(1) driver.close() #切换句柄 for handle in all_handles: if handle == search_Windows: driver.switch_to.window(handle) #关键字搜索 sleep(1) driver.find_element_by_xpath('//*[@id="ww"]').send_keys('吴哥窟') sleep(1) driver.find_element_by_xpath('//*[@id="s_btn_wr"]').click() sleep(2) #搜索结果判断 assert '吴哥窟' in driver.page_source driver.quit() 3. 运行结果 代码TestBaiDuNews.py中加入了大量等待时间,方便读者查看每一步操作的结果。此处就不放置运行结果图了,热点新闻每天都会有所变化。