У меня проблема с селеном 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