修的了电脑 敲得了代码
     写得了前端 稳得住后端

selenium无法获取元素text文本案例分析

我司使用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")
未经允许不得转载:流云溪|码农 » selenium无法获取元素text文本案例分析