web-dev-qa-db-fra.com

Selenium chromedriver 2.25 TimeoutException ne peut pas déterminer le statut de chargement

J'utilise python3 sur mac os et j'ai mis à jour chrome, chromedriver et Selenium vers la dernière version. Je reçois une TimeoutException, le navigateur s’ouvre correctement mais il se fige.

>>> from Selenium import webdriver
>>> driver = webdriver.Chrome()
# opens browser with blank page
>>> driver.get('http://example.com')
# gets first page OK and then driver literally flashes once
>>> driver.get('http://stackoverflow.com')
>>>
# Cursor loading forever... until TimeoutException

Cette erreur est levée:

Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/usr/local/lib/python3.5/site-packages/Selenium/webdriver/remote/webdriver.py", line 248, in get
    self.execute(Command.GET, {'url': url})
  File "/usr/local/lib/python3.5/site-packages/Selenium/webdriver/remote/webdriver.py", line 236, in execute
    self.error_handler.check_response(response)
  File "/usr/local/lib/python3.5/site-packages/Selenium/webdriver/remote/errorhandler.py", line 192, in check_response
    raise exception_class(message, screen, stacktrace)
Selenium.common.exceptions.TimeoutException: Message: timeout: cannot determine loading status
from timeout: Timed out receiving message from renderer: -0.003
  (Session info: chrome=54.0.2840.71)
  (Driver info: chromedriver=2.25.426935 (820a95b0b81d33e42712f9198c215f703412e1a1),platform=Mac OS X 10.12.0 x86_64)

J'utilise: Python 3.5.2, Chrome 54.0, chromedriver 2.25, Selenium 3.0.1

J'ai essayé d'autres versions de chromedriver sans succès, et je n'ai trouvé aucune solution à ce problème en ligne. Merci.

MODIFIER:

Toujours avoir l'erreur ci-dessus + une nouvelle erreur:

Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/usr/local/lib/python3.5/site-packages/Selenium/webdriver/chrome/webdriver.py", line 69, in __init__
    desired_capabilities=desired_capabilities)
  File "/usr/local/lib/python3.5/site-packages/Selenium/webdriver/remote/webdriver.py", line 92, in __init__
    self.start_session(desired_capabilities, browser_profile)
  File "/usr/local/lib/python3.5/site-packages/Selenium/webdriver/remote/webdriver.py", line 179, in start_session
    response = self.execute(Command.NEW_SESSION, capabilities)
  File "/usr/local/lib/python3.5/site-packages/Selenium/webdriver/remote/webdriver.py", line 236, in execute
    self.error_handler.check_response(response)
  File "/usr/local/lib/python3.5/site-packages/Selenium/webdriver/remote/errorhandler.py", line 192, in check_response
    raise exception_class(message, screen, stacktrace)
Selenium.common.exceptions.WebDriverException: Message: session not created exception
from unknown error: bad inspector message: {"method":"Page.loadEventFired","params":{"timestamp":14220,088073}}
  (Session info: chrome=54.0.2840.71)
  (Driver info: chromedriver=2.25.426935 (820a95b0b81d33e42712f9198c215f703412e1a1),platform=Mac OS X 10.12.0 x86_64)
14
RMM

Selenium.common.exceptions.TimeoutException: Message: timeout: impossible de déterminer le statut de chargement depuis expiration du délai: délai de réception du message du moteur de rendu: -0,003

Issue817: Il semble que ce problème ait été consigné en tant que bogue pour Selenium .

Quelqu'un a répondu à ce problème en utilisant l'option --dns-prefetch-disable de chrome.

from Selenium.webdriver import Chrome
from Selenium.webdriver.chrome.options import Options

chrome_options = Options()
chrome_options.add_argument('--dns-prefetch-disable')
driver = Chrome(chrome_options=chrome_options)

Si le problème persiste suivre ce fil peut être qu'il résout votre problème

11
Saurabh Gaur

Ensemble

env LANG = en_US.UTF-8 ./chromedriver

à partir de: https://bugs.chromium.org/p/chromedriver/issues/detail?id=1552

0
Romain Jouin