Selenium新玩法AutoClick
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Selenium新玩法AutoClick相关的知识,希望对你有一定的参考价值。
参考技术A 介绍在selenium的基础上进行了封装,使用更加便捷,并且持续更新中,突出亮点为:
采用链式调用,即autoclick.select().click()或者autoclick.select().send_key(value),使调用非常方便。
默认采用了隐式等待,在selenium隐式等待的基础上进行了封装,可根据自己的要求配置隐式等待时间或者使用默认等待时间。
可选择等待超时后的行为:抛出异常还是继续执行,此功能在网络延迟,页面元素不能及时加载时显得尤为重要。
目前封装的功能包括:
打开页面
初始化浏览器
退出并关闭窗口
关闭当前窗口
切换标签页
刷新
前进
后退
选择
点击
输入
截图
执行javascript脚本
使用方法(autoclick)
引入autoclick.py
from autoclick import AutoClick
使用默认配置初始化AutoClick
autoclick = AutoClick()
打开页面
autoclick.open(target_page)
选择元素
autoclick.select(by,value)
by: selenium 的默认查找方式,即find_element()的参数 value:方式所对应的值
点击 点击最近一次选择的元素
autoclick.click(jump=True)
jump:页面是否跳转 此参数作用为,如果页面跳转会自动调用autoclick.switch_window()来选择最新的窗口句柄,提高效率
点击还可以链式调用:
autoclick.select(by,value).click()
在选择后执行点击,通过链式调用提高开发效率
输入 输入与点击使用方法类似
autoclick.select(by,value).send_key(value)
执行javascript脚本
autoclick.execute(js)
刷新
autoclick.refresh()
后退
autoclick.back()
前进
autoclick.forword()
切换窗口句柄
autoclick.switch(index=0)
默认切换至最新窗口句柄,可根据需要传入index参数,最新为-1,以此类推
关闭窗口(程序不退出)
autoclick.close()
退出程序
autoclick.quit()
使用方法(autoclickjs)
autoclickjs是继承了autoclick,其主要功能是使用JS命令来执行命令,亮点是健壮性强,如果元素还未加载完,会继续尝试等待元素加载后执行命令,这尤其在执行点击和输入命令时显得尤为重要和便捷
调用例子
from autoclickjs import AutuClickJS
auto = AutuClickJS()
auto.open('https://www.xuexi.cn/')
auto.click_by_classname('text-ellipsi',1)
很简单,别的不用管,不用担心未找到元素报错程序终止,因为它会等待元素加载,继续尝试执行命令。 因为click_by_classname是通过执行document.getElementsByClassName() ,所以click_by_classname()第二个参数便是数组下标。
2021年最后一天,学点Selenium玩点新鲜~新的一年,让分布式测试有更多玩法
♥ 前 言
我们都知道 Selenium 是一款在 Web 应用测试领域使用的自动化测试工具,而 Selenium Grid 是 Selenium 中的一大组件,通过它能够实现分布式测试,能够帮助团队简单快速在不同的环境中测试他们的 Web 应用。
分布式执行测试其实并不是一个非常难以理解的概念,简单来说,就是能够同时在不同的环境中同时执行测试。通过 Selenium Grid,我们可以通过在客户端发送命令到远程端的浏览器实例,在远程端执行 WebDriver 脚本,可以在多台远程的机器上并行运行测试。
Selenium Grid 4 新特性介绍
在以往的 Selenium Grid 版本中(V1-V3)其架构都比较简单。在全新的 Selenium Grid 4 版本中其架构变得有些复杂,但也更加灵活和强大了。
特性一:Hub 和 Node 使用同一个 jar 服务
在之前,我们要配置 Selenium Grid 时需要分别启动 Hub 和 Node 节点,而在全新的 Selenium Grid 4 版本中 Hub 和 Node 都是用同一个 jar 文件,一旦服务启动之后将会同时作为 Hub 和 Node 角色。
特性二:架构优化
在之前的 Selenium 版本中,Selenium Grid 由 Hub 和 Node 组成,Hub 作为总控中心负责 Node 节点注册及转发请求,Node 节点则负责来自 Hub 的请求及执行测试脚本,具体参考我之前的文章 Selenium Grid- 让自动化分布式执行变得可能
文章链接:http://testingpai.com/article/1596527701728
在 Selenium Grid 4 版本的全新架构中划分成了组件:Router、Distributor、Node、Session Map、Session Queue、Event Bus
-
Router - 监听新会话请求
-
Distributor - 选择合适的 Node 执行测试
-
Node - 在对应主机执行测试
-
Session Map - 给 Node 节点标记 session ID
-
Session Queue - 维护所有的会话队列
-
Event Bus - 作为 Grid 各组件通讯桥梁
特性三:不同的 Gird 运行模式
在 Selenium Grid 3 及之前版本中只能使用 Hub 和 Node 工作模式,Selenium Grid 4 除了提供对经典的 Hub 和 Node 模式支持之外,还引入了另外两种全新的模式 standalone、fully distributed。
-
Standalone 模式
standalone 模式能够在一台机器上面执行完整的分布式功能,是 Selenium Grid 的最简单的模式,默认情况下,服务会在 http://localhost:4444 地址监听,我们需要通过 RemoteWebDriver 指向这个地址。
-
Classical 模式
classical 模式也可以称为 hub 和 node 模式,此项模式比较适用于中小型分布式执行要求,根据需要设置一个服务节点(hub)和多个代理节点(node)。
-
Fully Distributed 模式
对于大型的分布式要求,可以采用完全分布式模式,这是 Selenium Grid 4 中最高级的模式,这种模式下需要自己启动每个组件。
Standalone 模式使用
在 standalone 模式下,Node 和 Hub 都是运行在相同的 Selenium Grid 服务中
Step1:准备需要的环境
因为后续下载的 Selenium 组件是 jar 文件,所以需要准备 Java 的环境去运行。如果没有安装 Java 的环境,可以进入到 https://www.oracle.com/java/technologies/downloads/下载安装 JDK 并且配置环境变量,配置完成之后进入到命令行终端,输入以下命令检测:
java -version
如果 Java 环境配置成功,你会看到相关的 Java 版本信息。
Step2:下载浏览器驱动
下一步需要根据你当前的操作系统以及浏览器选择下载合适的驱动。
-
Chrome Driver 地址:https://npm.taobao.org/mirrors/chromedriver
-
Firefox Driver 地址:https://npm.taobao.org/mirrors/geckodriver
驱动下载完成后放置到某个目录下,并将目录添加到系统的环境变量中。在 Selenium Grid 服务启动时将会自动识别。如果不做此操作 Selenium Grid 将无法在在这些浏览器上执行测试。
Step3:创建 Selenium Grid
这一步我们需要下载 Selenium Server 对应地址:https://www.selenium.dev/downloads/
下载完毕之后将其放置到任意的目录中,接下来在命令行终端运行以下命令启动 Selenium Grid
java -jar selenium-server-4.1.1.jar standalone
你将会看到下面的信息输出,我们可以看到 Chrome 以及 Firefox 都被注册到了 Grid 中
D:\\Selenium Grid>java -jar selenium-server-4.1.1.jar standalone
16:59:31.406 INFO [LogManager$RootLogger.log] - Using the system default encoding
16:59:31.409 INFO [OpenTelemetryTracer.createTracer] - Using OpenTelemetry for tracing
16:59:37.876 INFO [NodeOptions.getSessionFactories] - Detected 8 available processors
16:59:38.046 INFO [NodeOptions.discoverDrivers] - Discovered 2 driver(s)
16:59:38.071 INFO [NodeOptions.report] - Adding Firefox for "browserName": "firefox" 8 times
16:59:38.072 INFO [NodeOptions.report] - Adding Chrome for "browserName": "chrome" 8 times
我们可以通过访问 http://localhost:4444/status 看到当前的状态
"value":
"ready": true,
"message": "Selenium Grid ready.",
"nodes": [
"id": "4bb7d6f7-466d-4537-87ca-1441023e0fff",
"uri": "http:\\u002f\\u002f192.168.56.1:4444",
"maxSessions": 8,
"osInfo":
"arch": "amd64",
"name": "Windows 10",
"version": "10.0"
,
"heartbeatPeriod": 60000,
"availability": "UP",
"version": "4.1.1 (revision e8fcc2cecf)",
"slots": [
"id":
"hostId": "4bb7d6f7-466d-4537-87ca-1441023e0fff",
"id": "b8a3c42e-c8fb-493c-bb3c-7b6deaa2a02a"
,
"lastStarted": "1970-01-01T00:00:00Z",
"session": null,
"stereotype":
"browserName": "firefox",
"platformName": "WIN10"
,
"id":
"hostId": "4bb7d6f7-466d-4537-87ca-1441023e0fff",
"id": "0eaffe11-62a1-4593-a94f-80151a69c24b"
,
"lastStarted": "1970-01-01T00:00:00Z",
"session": null,
"stereotype":
"browserName": "chrome",
"platformName": "WIN10"
,
"id":
"hostId": "4bb7d6f7-466d-4537-87ca-1441023e0fff",
"id": "7c7211bf-58a7-4ddb-9246-effecbf910ce"
,
"lastStarted": "1970-01-01T00:00:00Z",
"session": null,
"stereotype":
"browserName": "firefox",
"platformName": "WIN10"
,
"id":
"hostId": "4bb7d6f7-466d-4537-87ca-1441023e0fff",
"id": "437be3d5-bdf0-44aa-b401-51f7b9136b15"
,
"lastStarted": "1970-01-01T00:00:00Z",
"session": null,
"stereotype":
"browserName": "chrome",
"platformName": "WIN10"
,
"id":
"hostId": "4bb7d6f7-466d-4537-87ca-1441023e0fff",
"id": "f799da78-4ac8-4799-8d4b-50314a954c01"
,
"lastStarted": "1970-01-01T00:00:00Z",
"session": null,
"stereotype":
"browserName": "chrome",
"platformName": "WIN10"
,
"id":
"hostId": "4bb7d6f7-466d-4537-87ca-1441023e0fff",
"id": "10bd31b1-acf6-4006-af7c-47ea448a6a33"
,
"lastStarted": "1970-01-01T00:00:00Z",
"session": null,
"stereotype":
"browserName": "chrome",
"platformName": "WIN10"
,
"id":
"hostId": "4bb7d6f7-466d-4537-87ca-1441023e0fff",
"id": "31c91763-4aef-4379-910c-647266806fce"
,
"lastStarted": "1970-01-01T00:00:00Z",
"session": null,
"stereotype":
"browserName": "chrome",
"platformName": "WIN10"
,
"id":
"hostId": "4bb7d6f7-466d-4537-87ca-1441023e0fff",
"id": "20caece4-cb26-4914-8dfa-80fffd37191f"
,
"lastStarted": "1970-01-01T00:00:00Z",
"session": null,
"stereotype":
"browserName": "firefox",
"platformName": "WIN10"
,
"id":
"hostId": "4bb7d6f7-466d-4537-87ca-1441023e0fff",
"id": "53a12fa7-63a4-474d-bab4-5e6fc6976ff1"
,
"lastStarted": "1970-01-01T00:00:00Z",
"session": null,
"stereotype":
"browserName": "chrome",
"platformName": "WIN10"
,
"id":
"hostId": "4bb7d6f7-466d-4537-87ca-1441023e0fff",
"id": "7d1bb113-1050-482f-bd5d-939362270fdf"
,
"lastStarted": "1970-01-01T00:00:00Z",
"session": null,
"stereotype":
"browserName": "firefox",
"platformName": "WIN10"
,
"id":
"hostId": "4bb7d6f7-466d-4537-87ca-1441023e0fff",
"id": "c4993662-f2f1-46e6-ab6c-6eae7727dd68"
,
"lastStarted": "1970-01-01T00:00:00Z",
"session": null,
"stereotype":
"browserName": "firefox",
"platformName": "WIN10"
,
"id":
"hostId": "4bb7d6f7-466d-4537-87ca-1441023e0fff",
"id": "d9fcf1d0-cba0-4a53-bba4-934f35be8ccb"
,
"lastStarted": "1970-01-01T00:00:00Z",
"session": null,
"stereotype":
"browserName": "chrome",
"platformName": "WIN10"
,
"id":
"hostId": "4bb7d6f7-466d-4537-87ca-1441023e0fff",
"id": "8b8bdd06-4c6f-4344-812a-3429b5d013c7"
,
"lastStarted": "1970-01-01T00:00:00Z",
"session": null,
"stereotype":
"browserName": "firefox",
"platformName": "WIN10"
,
"id":
"hostId": "4bb7d6f7-466d-4537-87ca-1441023e0fff",
"id": "f7ca236a-7c1f-48ba-93e1-25745ed18493"
,
"lastStarted": "1970-01-01T00:00:00Z",
"session": null,
"stereotype":
"browserName": "chrome",
"platformName": "WIN10"
,
"id":
"hostId": "4bb7d6f7-466d-4537-87ca-1441023e0fff",
"id": "3116789e-3fab-4bcc-89fe-9c0b788bb29f"
,
"lastStarted": "1970-01-01T00:00:00Z",
"session": null,
"stereotype":
"browserName": "firefox",
"platformName": "WIN10"
,
"id":
"hostId": "4bb7d6f7-466d-4537-87ca-1441023e0fff",
"id": "3abf1ce7-cd89-48ae-a33d-252abd9a29c5"
,
"lastStarted": "1970-01-01T00:00:00Z",
"session": null,
"stereotype":
"browserName": "firefox",
"platformName": "WIN10"
]
]
我们还可以可以通过在浏览器端输入 http://localhost:4444/grid/console 来查看 Grid 控制台,也可以看到 standalone 模式下,在 node 节点中有对应的 Chrome 浏览器和 Firefox 浏览器。
Step4:使用 Selenium Grid 执行测试
在上述步骤中,我们通过最简单的 standalone 模式配置好了 hub 以及 node,下一步我们将会执行我们的自动化测试。
在编写测试脚本时,我们只需要通过 RemoteWebDriver 指向 http://localhost:4444/
@Test
public void testChrome() throws MalformedURLException
DesiredCapabilities caps = new DesiredCapabilities();
caps.setCapability(CapabilityType.BROWSER_NAME,"chrome");
WebDriver driver = new RemoteWebDriver(new URL("http://localhost:4444/"), caps);
driver.manage().window().maximize();
driver.get("http://testingpai.com/");
@Test
public void testFirefox() throws MalformedURLException
DesiredCapabilities caps = new DesiredCapabilities();
caps.setCapability(CapabilityType.BROWSER_NAME,"firefox");
WebDriver driver = new RemoteWebDriver(new URL("http://localhost:4444/"), caps);
driver.manage().window().maximize();
driver.get("http://testingpai.com/");
上述示例客户端脚本和 Grid 服务都是在本机,当然在实际应用中我们可以将 Grid 服务和脚本分别部署在两台主机上,此时脚本中指向的地址:http://localhost:4444/换成 Grid 服务所在主机的对外 IP 地址即可。
以上是关于Selenium新玩法AutoClick的主要内容,如果未能解决你的问题,请参考以下文章