干货 | JavaScript脚本注入,完成Selenium 无法做到的那些事
本文节选自霍格沃兹测试学院内部教材
当 webdriver 遇到无法完成的操作时,可以使用 JavaScript 来完成,webdriver 提供了 execute_script()
方法来调用 js 代码。
执行 js 有两种场景:
-
在页面上直接执行 js
-
在某个已经定位的元素上执行 js
简介
JavaScript 是一种脚本语言,有的场景需要使用 js 脚本注入辅助我们完成 Selenium 无法做到的事情。
执行js
Selenium 可以通过 execute_script()
来执行 JavaScript 脚本。
-
driver.execute_script:同步执行 JavaScript 在当前的窗口框架下
-
js 脚本可以在浏览器的开发者工具 -> Console 中进行调试
js的返回结果
-
获取元素控件中的属性值
-
与 Selenium 结合,在代码中返回 js 结果
# 获取网页性能的响应时间,js脚本中使用return代表返回获取的结果js = "return JSON.stringify(performance.timing);"driver.execute_script(js)
arguments传参
执行 JavaScript 也可以通过传参的方式传入元素信息。
element = driver.find_element(by, locator)#arguments[0]代表所传值element的第一个参数#click()代表js中的点击动作driver.execute_script("arguments[0].click();",element)
还可以通过上面的方法点击被遮挡的元素。
例如:某个元素在实际的操作过程中被其他的元素遮挡,就可以使用 js 点击的方式。
自动化过程中的报错如下:
Other element would receive the click: <label class="custom-control-label" for="user_remember_me">...</label>
如果出现上面的错误,可以使用 js 的方式进行点击。
实战案例
以企业微信为例,使用 js 点击添加图片。
代码:
#导入依赖from selenium import webdriverfrom selenium.webdriver.common.by import By
class TestWework: def setup(self): self.driver = webdriver.Chrome() #隐式等待 self.driver.implicitly_wait(2)
def test_upload(self): #元素定位 element_add = self.driver.find_element\ (By.CSS_SELECTOR, ".js_upload_file_selector") #执行js代码 self.driver.execute_script\ ("arguments[0].click();", element_add) self.driver.find_element_by_id('js_upload_input').send_keys('D:\project\demo1\demo.png') assert len(self.driver.find_elements(By.CSS_SELECTOR,'.material_pic_list_item')) == 1
def teardown(self): self.driver.quit()
执行 JavaScript 脚本就先讲到这里啦,大家还想看什么内容的文章也可以留言告诉我们哦!
** _ _
来霍格沃兹测试开发学社,学习更多软件测试与测试开发的进阶技术,知识点涵盖web自动化测试 app自动化测试、接口自动化测试、测试框架、性能测试、安全测试、持续集成/持续交付/DevOps,测试左移、测试右移、精准测试、测试平台开发、测试管理等内容,课程技术涵盖bash、pytest、junit、selenium、appium、postman、requests、httprunner、jmeter、jenkins、docker、k8s、elk、sonarqube、jacoco、jvm-sandbox等相关技术,全面提升测试开发工程师的技术实力
QQ交流群:484590337
公众号 TestingStudio
点击获取更多信息
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了