一次失败的Selenium chromedriver切换

背景:为解决Firefox超时问题,尝试使用Chrome通过Selenium进行web测试。操作包括下载ChromeDriver并放到默认路径。然而遇到启动Chrome失败的问题,Selenium报错。尝试在本地运行、更新库和添加参数均未解决问题,最后通过最小测试依赖生成日志并报告给Chromium团队。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

背景

Selenium webdriver一直使用Firefox作为浏览器来跑webtest, 但是最近发现ff有时会报超时的错误,于是想到使用chromedriver来提升稳定性。本想只把.firefox() 换成 .chrome() 这么简单的事情,结果却引出很多问题。

做法

根据官方文档

  1. 下载chromedriver binary
  2. 放到Linux 默认路径
  3. 走起…
  4. 问题来了

问题

Selenium 报无法启动chrome, 报错

selenium.common.exceptions.WebDriverException: Message: chrome not reachable
  (Driver info: chromedriver=2.21.371461 (633e689b520b25f3e264a2ede6b74ccc23cb636a),platform=Linux 3.0.36-gentoo x86_64)

排错

  1. 用本机来跑, 排除Selenium Grid的因素
  2. 更新Selenium和webdriver 到最新
  3. 添加 –no-sandbox 参数
  4. 还是跪了,用最小的测试依赖来跑,并生成chromedriver log,把问题丢给google chrome 团队了
    test_chrom_min.py
from selenium import webdriver

service_log_path = 'chromedriver.log'
service_args = ['--verbose', '--no-sandbox']

driver = webdriver.Chrome('/usr/bin/chromedriver', service_args=service_args,
        service_log_path=service_log_path) 
driver.get('http://www.google.com/xhtml')
driver.quit()

后续

  1. 在Mac上可以成功跑通,估计是测试环境上的问题
  2. Reported Bug https://bugs.chromium.org/p/chromedriver/issues/detail?id=397#c43
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值