Время ожидания получения сообщения от средства визуализации: ошибка 300.000 при переключении между windows с использованием ChromeDriver и Chrome через Selenium и Java - PullRequest
0 голосов
/ 23 января 2020

У меня проблема с селеном 3.13.0 и chrome версиями 79.0.3945.130 и java. Я написал этот код для тестирования веб-страницы, которая должна переключаться между 2 windows. когда я запускаю этот скрипт, все в порядке, но когда драйвер переключается в новое окно, оно больше не доступно! И спустя долгое время я получил эту ошибку. Кто-нибудь знает, где проблема?

(я уверен, что управление программой выйдет из l oop и переключится в новое окно, но кажется, что драйвер будет потерян после ухода l oop.)

некоторые функции, такие как driver.quit () или driver.getWindowHandles (), работали после выхода из l oop, но некоторые другие, такие как driver.getPageSource () или driver.manage () .window (). maximize () не работают и вызывают эту ошибку.

Вот мой пример кода:

public class myClassFirst {

public static void main(String[] args) throws InterruptedException {
    System.setProperty("webdriver.chrome.driver","Driver_Path");
    WebDriver driver = new ChromeDriver();
    driver.manage().window().maximize();      //it works correctly
    driver.get("Web_page_Url");
    Thread.sleep(15000);  //to load page
    System.out.println("finish waiting ...");
    /*
        some script here
    */
    // go to appropriate frame
    driver.switchTo().defaultContent();
    driver.switchTo().frame("Faci3");
    driver.switchTo().frame(driver.findElement(By.name("Commander")));
    Set<String> s = driver.getWindowHandles();
    System.out.println(s);  //print windowID of current window(1)
    //select button element
    WebElement prepareToPrint = driver.findElement(By.id("PreparePrint"));
    prepareToPrint.click();
    Thread.sleep(5000);  //to load new window(2)
    String sThis = driver.getWindowHandle();   //get windowID of current window(1)
    for (String winId:driver.getWindowHandles()) {
        if (!winId.equals(sThis)) {
            driver.switchTo().window(winId);   //switch to new window(2)
            System.out.println(winId);          //print windowID of new window(2)
            break;
        }
    }
    System.out.println("exit from the loop");
    driver.manage().window().maximize();  //From here does not work anymore(real line 92)
    Actions builder = new Actions(driver);
    builder.contextClick().perform();
    System.out.println("End = Finish");
    driver.quit();
}
}

, и это вывод:

finish waiting ...
[CDwindow-9B003436EA7F9E41C56694893D686231]
CDwindow-7205BC1AD0022BD28BFD18FCD4FA379B
exit from the loop
[1579772104.277][SEVERE]: Timed out receiving message from renderer: 300.000
[1579772104.280][SEVERE]: Timed out receiving message from renderer: -0.003
Exception in thread "main" org.openqa.selenium.TimeoutException: timeout
  (Session info: chrome=79.0.3945.130)
Build info: version: '3.13.0', revision: '2f0d292', time: '2018-06-25T15:32:14.902Z'
System info: host: 'DESKTOP-BT6SU1U', ip: '192.168.67.1', os.name: 'Windows 10', os.arch: 'amd64', os.version: '10.0', java.version: '1.8.0_181'
Driver info: org.openqa.selenium.chrome.ChromeDriver
Capabilities {acceptInsecureCerts: false, browserName: chrome, browserVersion: 79.0.3945.130, chrome: {chromedriverVersion: 79.0.3945.36 (3582db32b3389..., userDataDir: C:\Users\Sadell\AppData\Loc...}, goog:chromeOptions: {debuggerAddress: localhost:61628}, javascriptEnabled: true, networkConnectionEnabled: false, pageLoadStrategy: normal, platform: WINDOWS, platformName: WINDOWS, proxy: Proxy(), setWindowRect: true, strictFileInteractability: false, timeouts: {implicit: 0, pageLoad: 300000, script: 30000}, unhandledPromptBehavior: dismiss and notify}
Session ID: 5b36cc7b69534ede85d7c957306c2626
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
    at org.openqa.selenium.remote.http.W3CHttpResponseCodec.createException(W3CHttpResponseCodec.java:187)
    at org.openqa.selenium.remote.http.W3CHttpResponseCodec.decode(W3CHttpResponseCodec.java:122)
    at org.openqa.selenium.remote.http.W3CHttpResponseCodec.decode(W3CHttpResponseCodec.java:49)
    at org.openqa.selenium.remote.HttpCommandExecutor.execute(HttpCommandExecutor.java:158)
    at org.openqa.selenium.remote.service.DriverCommandExecutor.execute(DriverCommandExecutor.java:83)
    at org.openqa.selenium.remote.RemoteWebDriver.execute(RemoteWebDriver.java:548)
    at org.openqa.selenium.remote.RemoteWebDriver.perform(RemoteWebDriver.java:614)
    at org.openqa.selenium.interactions.Actions$BuiltAction.perform(Actions.java:638)
    at org.openqa.selenium.interactions.Actions.perform(Actions.java:594)
    at myClassFirst.main(myClassFirst.java:92)

Process finished with exit code 1

Ответы [ 3 ]

0 голосов
/ 23 января 2020

Это сообщение об ошибке ...

[1579772104.277][SEVERE]: Timed out receiving message from renderer: 300.000
[1579772104.280][SEVERE]: Timed out receiving message from renderer: -0.003
Exception in thread "main" org.openqa.selenium.TimeoutException: timeout
  (Session info: chrome=79.0.3945.130)
Build info: version: '3.13.0', revision: '2f0d292', time: '2018-06-25T15:32:14.902Z'
.
.
Capabilities {acceptInsecureCerts: false, browserName: chrome, browserVersion: 79.0.3945.130, chrome: {chromedriverVersion: 79.0.3945.36 (3582db32b3389..., userDataDir: C:\Users\Sadell\AppData\Loc...}, goog:chromeOptions: {debuggerAddress: localhost:61628}, javascriptEnabled: true, networkConnectionEnabled: false, pageLoadStrategy: normal, platform: WINDOWS, platformName: WINDOWS, proxy: Proxy(), setWindowRect: true, strictFileInteractability: false, timeouts: {implicit: 0, pageLoad: 300000, script: 30000}, unhandledPromptBehavior: dismiss and notify}

... означает, что ChromeDriver не смог переключиться на новый TAB .


Ваша главная проблема - несовместимость между версиями двоичных файлов, которые вы используете, следующим образом:

  • Вы используете chromedriver = 79.0.3945.36 и chrome = 79.0.3945.130 и совместимы
  • Но ваша Selenium Client версия 3.13.0 из 2018- 06-25T15: 32: 14.902Z , который почти на 2 лет старше.

Таким образом, существует явное несоответствие между Selenium Client v3.13.0 , ChromeDriver v79.0 и Chrome Браузер v79.0


Решение

Убедитесь, что:

  • JDK обновлен до текущих уровней JDK 8u222 .
  • Selenium обновлен до текущих уровней Версия 3.141 .59 .
  • ChromeDriver * 106 0 * обновлен до текущего ChromeDriver v79.0.3945.36 уровня.
  • Chrome обновлен до текущего Chrome Версия 79.0 уровень. (согласно примечаниям к выпуску ChromeDriver v79.0 )
  • Очистка вашего Рабочего пространства проекта через IDE и Перестройте ваш проект только с необходимыми зависимостями.
0 голосов
/ 06 февраля 2020

Уважаемые

В этой проблеме я изменил свой веб-драйвер с chrome на firefox, и он был временно разрешен. Надеюсь, это вам тоже поможет.

0 голосов
/ 23 января 2020

Попробуйте этот driver.switchTo (). Window (окно) .manage (). Window (). Maximize ()

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...