背景
作为以浏览器为基础的测试工具Selenium,在平台支持以及功能上是十分强大的。可惜国内资源很少,而官方资源也是简约,除了一个老旧的文档和干瘪的API,没有更多可用的信息。这对于一个非专业人士来说是十分致命的,遇到关卡需要查阅无数资料,测试无数次才能成功。这里记录一下Selenium有关断点测试的问题。
何为断点测试(见谅,自己造的词)?在测试代码生成阶段,为了调试代码,时常需要多次运行代码,查看效果。而遇到的情况是什么呢,selenium在代码测试完后,虽然测试用的浏览器并为关闭,但是想要继续使用该测试浏览器已经不行了。查阅相关资料,原来python 代码在运行结束后自动关闭了运行浏览器命令的service. ( 看评论说selenium #C 版本不会出现这一情况)。
有人会说了,重启这个service不就行了吗。我开始也是这样想的,但是翻看了API,以及各种查阅资料也没有看见相关的介绍。那如何重用浏览器实例呢?直接使用python selenium3的API是不行的,需要用到Selenium RC.
Selenium 历史简介
这里稍微介绍一下Selenium的历史。Selenium 1 也被称为Selenium Legecy 或者 Selenium RC, 通过控制服务器(Remote Control Server)向浏览器注入JS的方式,操作浏览器进行自动化测试,这是selenium最初的形式。Selenium 2 将Selenium RC 和 Webdriver 进行了合并,Webdriver 的优势在于提供浏览器原生API,弥补了Selenum 1通过JS方式的不足之处。 由于Webdriver是 google 团队进行管理的,后续Selenium的更新逐渐将重心移动到Webserver上,Selenium 3的API中已经不支持Selenium 1 的方式了。
断点测试的应用
对于断点测试来说,需要使用Selenium RC 的 Remote Server, 但是测试用的API还是使用Webdriver的API,在测试代码完成,完成production 代码的时候,将Selenum RC部分完全转换到 Webdriver上就可以了。
实际操作
按照JAVA JRE环境(java 8 及以上)
下载运行Selenium Server
-
终端运行
java -jar selenium-server-standalone-3.9.0.jar
到这一步,Selenium Server已经跑起来了, 下面运行selenium代码
from selenium.webdriver.chrome.webdriverimport RemoteWebDriver
from selenium.webdriver.common.desired_capabilitiesimport DesiredCapabilities
/# Create a desired capabilities object as a starting point.
capabilities = DesiredCapabilities.CHROME.copy()
capabilities['platform'] ="MAC OS X"
capabilities['version'] ="64.0.3282.119"
driver=RemoteWebDriver(command_executor='http://127.0.0.1:4444/wd/hub',desired_capabilities=capabilities,keep_alive=True)
<some other functions for Work_1>
第一次运行上面的代码,Selenium 会生成一个Session,控制浏览器。
当你的测试代码完成第一部分时,你打算继续第一部份的代码,进行下一步测试,同时使用刚才使用过的浏览器实例(网页还停留在第一部分代码结束时的样子)。
可以浏览器登录 http://127.0.0.1:4444/wd/hub,如图所示:
这里发现 session_id = "b07a4187b91d0e7e48de44c3c6000559"
你要继续第一部分代码Work_1, 代码如下:
from selenium.webdriver.chrome.webdriverimport RemoteWebDriver
from selenium.webdriver.common.desired_capabilitiesimport DesiredCapabilities
# Create a desired capabilities object as a starting point.
capabilities = DesiredCapabilities.CHROME.copy()
capabilities['platform'] ="MAC OS X"
capabilities['version'] ="64.0.3282.119"
driver = RemoteWebDriver(command_executor='http://127.0.0.1:4444/wd/hub',desired_capabilities=capabilities,keep_alive=True)
driver.quit()
driver.session_id ='b07a4187b91d0e7e48de44c3c6000559'
<some other functions for Work_2>
这样你后续的代码仍然可以使用前面使用过的浏览器。
最后所有测试代码块完成后,将 Work_1、Work_2、Work_3、Work_4进行合并,同时将RemoteWebDriver 进行替换,就完成了最终的测试代码了。
提示
session_id 的获取,可以通过直接print(driver.session_id)得到。
代码第二部分的driver.quit(),用处在于,实例RemoteWebDriver的时候,会立即生成一个新的浏览器实例,用driver.quit()将刚生成的浏览器关闭掉。(详情可以通过不使用driver.quit()进行查看)。