网站首页 > 技术文章 正文
我司使用python+selenium框架来开展UI自动化测试,有一次在调测某个用例时遇到一个让我很困惑的问题,折腾了好打一阵才找到原因,赶紧记录下省得忘记。
用例中需要获取元素的文本内容并检查结果,我是采用直接使用元素的text属性获取的,就像下面这样
# xpath是事先定义的变量,值为定位的元素的真实xpath,expect_string也是
assert driver.find_element_by_xpath(xpath).text == expect_string
我在本机上调测结果正常通过,但是提交到代码库后通过CI/CD平台jenkins拉起自动化时每次这里都会报错,报错信息显示text属性获取的是空值,一开始怀疑是不是页面元素还没准备好,尝试添加等待仍然无法解决。
多次尝试都没解决,只能从jenkins方式拉起和本地调测的不同点着手了,jenkins方式拉起自动化是没有启动浏览器界面的,而本地调测时可以正常启动浏览器界面,于是就使用下面的方法进行元素是否可见的测试,果不其然,本地调测时结果返回True,而jenkins方式拉起返回的是False。
driver.find_element_by_xpath(xpath).is_displayed()
网上搜到一个结果,说selenium webdriver只会与可见元素交互,元素隐藏时返回的都是空字符串,问题原因找到了。
解决办法:
把通过text属性获取文本改成通过get_attribute()方法获取元素的文本信息,针对隐藏元素获取innertText属性可以正确提取出文本内容,问题顺利解决。
assert driver.find_element_by_xpath(xpath).get_attribute("innerText")
猜你喜欢
- 2024-11-14 Playwright自动化测试工具之元素定位实战
- 2024-11-14 利器 | AppCrawler 自动遍历测试实践(二):定制化配置
- 2024-11-14 java组件HuTool相关工具类的使用二
- 2024-11-14 手把手教你爬取热门小说《诡秘之主》
- 2024-11-14 Python爬虫之xpath用法全解析(py xpath)
- 2024-11-14 怎么用xpath写drissionpage?或者用相对位置?
- 2024-11-14 通过python+Xpath实现抓取某网站推荐的歌曲
- 2024-11-14 Python自动化工具(python写自动化工具)
- 2024-11-14 web自动化测试——xpath常用案例(web自动化测试平台)
- 2024-11-14 手把手教你如何用Python爬取网站文本信息
- 最近发表
- 标签列表
-
- cmd/c (57)
- c++中::是什么意思 (57)
- sqlset (59)
- ps可以打开pdf格式吗 (58)
- phprequire_once (61)
- localstorage.removeitem (74)
- routermode (59)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- log.warn (60)
- cannotinstantiatethetype (62)
- js数组插入 (83)
- resttemplateokhttp (59)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- reader.onload (61)
- outofmemoryerror是什么意思 (64)
- flask文件上传 (63)
- eacces (67)
- 查看mysql是否启动 (70)
- java是值传递还是引用传递 (58)
- 无效的列索引 (74)