IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> selenium报错:element is not attached to the page document -> 正文阅读

[开发测试]selenium报错:element is not attached to the page document

在这里插入图片描述

def testpatentDetail_40(self, patentDetialPage, db, driver):
    patentDetialPage.click_menu3()
    totalpage = patentDetialPage.get_totalpage()
    for i in range(0, int(totalpage)):
        patentDetialPage.click_pagenum(i + 1)
        # driver.implicitly_wait(30)
        # time.sleep(1)
        for n in range(0, patentDetialPage.get_discusslistlen()):
            sql = 'sqlstr'
            con = db.getOne(db.executeSql(sql))
            # 评论人头像
            if con[8] is None:
                pytest.assume(patentDetialPage.get_discussimg(n) == '')
            else:
                pytest.assume(patentDetialPage.get_discussimg(n) == str(con[8]))
			# 评论人+评论内容
            content = str(con[7]) + ':' + con[5]
            pytest.assume(patentDetialPage.get_discusscontent(n).replace(" ", "") == content.replace(" ", ""))
			# 评论时间
            newdate = str(con[6]).rpartition(':')[0]
            pytest.assume(patentDetialPage.get_discusstime(n) == str(newdate))

遍历翻页功能测试时,出现报错:
Message: element is not attached to the page document

官方给出解释如下:
The element has been deleted entirely.
The element is no longer attached to the DOM.

检查发现点击翻页会调用ajax请求,在请求未完成时,评论列表元素过期,无法获取到元素

最开始想着加个等待时间WebDriverWait就好了(封装方法里都包含显示等待),看来是我太天真,最后想明白了其实在操作点击页码之后,ajax没有立即加载完成,所以此时元素还是存在的,但ajax响应后,元素就过期了,原因是点击页码操作首先响应ajax请求,ajax请求响应成功后元素过期,下面三个请求响应元素再次出现。
在这里插入图片描述
然后试着强等 time.sleep(1),发现不报错了,不过这种方式不稳定,万一网络不好或者服务器压力过大,等一秒也不够啊,那等30秒,每次都等30秒么?那也不现实,那就没有其他方法类似于WebDriverWait么?

于是我换种方式,能不能获取浏览器所有请求呢,通过各种百度,找到了Selenium拦截页面Ajax请求及响应数据的方法(参考:https://www.likeinlove.com/info/104.html)

修改代码如下,妥妥的解决了,哈哈:

# conftest.py
@pytest.fixture(scope="session", name="server")
def ser():
    server = Server(os.getcwd() + r'\browsermob-proxy-2.1.4\bin\browsermob-proxy.bat')
    server.start()
    yield server
    server.stop()

@pytest.fixture(scope="session", name="proxy")
def proxy(server):
    proxy = server.create_proxy()
    return proxy

# 可视化打开浏览器
@pytest.fixture(scope="session", name="driver")
def browser(proxy):
    chrome_options = Options()
    chrome_options.add_argument(f'--proxy-server={proxy.proxy}')
    chrome_options.add_argument('--ignore-certificate-errors')  # 忽略不安全证书提示
    driver = webdriver.Chrome(chrome_options=chrome_options)
    driver.maximize_window()
    yield driver
    # quit是退出浏览器
    driver.quit()
def testpatentDetail_40(self, patentDetialPage, db, proxy):
    proxy.new_har(options={'captureHeaders': True, 'captureContent': True})
    patentDetialPage.open('https://')
    patentDetialPage.click_menu3()
    totalpage = patentDetialPage.get_totalpage()
    for i in range(0, int(totalpage)):
        patentDetialPage.click_pagenum(i + 1)
        att = 1
        while 1:
            if att == 1:
                result = proxy.har
                for entry in result['log']['entries']:
                    url = entry['request']['url']
                    if "https://" in url:
                        response = entry['response']  # 响应对象
                        content = response['content']  # 响应内容对象
                        text = content['text']  # 响应内容
                        if text is not None:
                            att = 0
                            break
                        else:
                            time.sleep(0.1)
                        break
                    else:
                        time.sleep(0.1)
            else:
                break
        for n in range(0, patentDetialPage.get_discusslistlen()):
            sql = 'sqlstr'
            con = db.getOne(db.executeSql(sql))
            # 评论人头像
            if con[8] is None:
                pytest.assume(patentDetialPage.get_discussimg(n) == '')
            else:
                pytest.assume(patentDetialPage.get_discussimg(n) == str(con[8]))
			# 评论人+评论内容
            content = str(con[7]) + ':' + con[5]
            pytest.assume(patentDetialPage.get_discusscontent(n).replace(" ", "") == content.replace(" ", ""))
			# 评论时间
            newdate = str(con[6]).rpartition(':')[0]
            pytest.assume(patentDetialPage.get_discusstime(n) == str(newdate))
  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2022-02-22 20:54:14  更:2022-02-22 20:56:35 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/18 2:58:20-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码