web-dev-qa-db-fra.com

WebDriverError: déconnecté: impossible de se connecter au rendu

Meta -

OS: OSX 10.12.6 (16G29)

~./node_modules/chromedriver/bin/chromedriver  -v
ChromeDriver 2.32.498537 (cb2f855cbc7b82e20387eaf9a43f6b99b6105061)

~ $ echo $Java_HOME
/Library/Java/JavaVirtualMachines/jdk1.7/Contents/Home

~ $ node -v
v6.11.2

Navigateur:

Version Chrome 62.0.3202.62 (version officielle) (64 bits)

Version du navigateur:

62.0.3202.62 (version officielle) (64 bits)

Comportement prévisible -

Une session Chrome doit commencer et le script doit s'exécuter jusqu'à la fin.

Comportement réel -

Le navigateur est lancé mais le script se bloque immédiatement.

Code:

> [email protected] Selenium-local /Users/Georgios/Development/rocket-internet/ucb-client
> node test/automation-tests/testcases/happy-path/Local_Guest_Cash.js

/Users/Georgios/Development/rocket-internet/ucb-client/node_modules/Selenium-webdriver/lib/promise.js:2634
        throw error;
        ^

WebDriverError: disconnected: unable to connect to renderer
  (Session info: chrome=62.0.3202.62)
  (Driver info: chromedriver=2.32.498537 (cb2f855cbc7b82e20387eaf9a43f6b99b6105061),platform=Mac OS X 10.12.6 x86_64)
    at WebDriverError (/Users/Georgios/Development/rocket-internet/ucb-client/node_modules/Selenium-webdriver/lib/error.js:27:5)
    at Object.checkLegacyResponse (/Users/Georgios/Development/rocket-internet/ucb-client/node_modules/Selenium-webdriver/lib/error.js:529:15)
    at parseHttpResponse (/Users/Georgios/Development/rocket-internet/ucb-client/node_modules/Selenium-webdriver/lib/http.js:509:13)
    at doSend.then.response (/Users/Georgios/Development/rocket-internet/ucb-client/node_modules/Selenium-webdriver/lib/http.js:441:30)
    at process._tickCallback (internal/process/next_tick.js:109:7)
From: Task: WebDriver.manage().window().setSize(1280, 720)
    at thenableWebDriverProxy.schedule (/Users/Georgios/Development/rocket-internet/ucb-client/node_modules/Selenium-webdriver/lib/webdriver.js:807:17)
    at Window.setSize (/Users/Georgios/Development/rocket-internet/ucb-client/node_modules/Selenium-webdriver/lib/webdriver.js:1677:25)
    at Object.<anonymous> (/Users/Georgios/Development/rocket-internet/ucb-client/test/automation-tests/testcases/happy-path/Local_Guest_Cash.js:8:26)
    at Module._compile (module.js:570:32)
    at Object.Module._extensions..js (module.js:579:10)
    at Module.load (module.js:487:32)
    at tryModuleLoad (module.js:446:12)
    at Function.Module._load (module.js:438:3)
    at Module.runMain (module.js:604:10)
    at run (bootstrap_node.js:389:7)
Actual script (beginning)

require('chromedriver');
var webdriver = require('Selenium-webdriver'),
By = webdriver.By,
until = webdriver.until;
var driver = new webdriver.Builder().forBrowser('chrome').build();
var timeout = 15000;
18
George Katsanos

Vous utilisez les versions 2.32 de chromediver et notes de publication il est écrit que le support est destiné à Chrome v59-61

En tant que navigateur, vous avez:

Chrome Version 62.0.3202.62 (Official Build) (64-bit) 

Ainsi, depuis ChromeDriver , vous devez utiliser la 2.33

31
Davide Patti

J'ai eu une erreur similaire. Mais les versions correspondaient: j'utilisais Chrome 65 avec la version de pilote 2.38.

J'ai passé beaucoup de temps à essayer de comprendre le problème… .. À la fin, j'ai constaté qu'il était causé par un fichier /etc/hosts vide. Apparemment, Chrome communique via localhost, et si une telle entrée manque dans /etc/hosts - elle se bloquera.

Donc, assurez-vous qu'il a une entrée comme ceci:

127.0.0.1 localhost

17
Slavik

Voici un additif brew à la solution @ davide-patti. :)

Quand j’obtenais l’erreur unable to connect to renderer, j’ai appris de @ Davide-patti que j’utilisais une version plus ancienne de chromedriver, v2.32. Mais je n'ai pas pu mettre à jour ma chromedriver avec homebrew, car je recevais continuellement: No available formula with the name "chromedriver".

Cet article m'a beaucoup aidé à passer à la v2.33 +.

À propos de: Erreur: Aucune formule disponible portant le nom "chromedriver"https://github.com/Homebrew/brew/issues/4089

1
Michael R

Parce que le chargement de la page a pris longtemps, vous devez ajouter une ligne supplémentaire à votre script.

System.setProperty("webdriver.chrome.driver","E:\\Selenium\\chromedriver_2.41\\chromedriver.exe");
//mention the below chrome option to solve timeout exception issue
ChromeOptions options = new ChromeOptions();
options.setPageLoadStrategy(PageLoadStrategy.NONE);
// Instantiate the chrome driver
driver = new ChromeDriver(options);
0
sumit kumar pradhan