driver.wait() выдает исключение IllegalMonitorStateException

#java #testing #selenium #webdriver #selenium-webdriver

#java #тестирование #selenium #webdriver #selenium-webdriver

Вопрос:

Все варианты wait(…) вызывают приведенное ниже исключение из следующего кода. Что я делаю не так?

 java.lang.IllegalMonitorStateException
    at java.lang.Object.wait(Native Method)
    at java.lang.Object.wait(Object.java:485)
    at LoginPage.main(LoginPage.java:29)

try
        {
            driver.get("http://domain:port/coco/webapp/login/login.faces");

            driver.findElement(By.id("clientCode")).sendKeys("coco");
            driver.findElement(By.id("systemCode")).sendKeys("consumer");
            driver.findElement(By.id("userId")).sendKeys("ffadmin");
            driver.findElement(By.id("password")).sendKeys("password");

            driver.findElement(By.className("af_commandButton")).click();
            driver.wait();
            Assert.assertTrue(driver.getPageSource().contains("Administration"));

        }
        catch (Exception e)
        {
            e.printStackTrace();
        }
  

Ответ №1:

Вы можете только wait для объекта, если вы получили для него блокировку с помощью synchronized .

Я не знаю, предназначены ли вы для использования wait с помощью WebDriver — если это так, вам понадобится что-то вроде:

 synchronized (driver)
{
    driver.wait();
}
  

Однако, если вы ожидаете, что что-то произойдет, более вероятно, что существует альтернативный метод, который вы должны использовать. Возможно WebDriverWait ?

Комментарии:

1. По-видимому, ожидание не требуется начиная с seleniunm 2, поскольку оно поддерживает неявные ожидания. При неявном ожидании вам нужно использовать только один из методов findElement, и если целевой элемент не существует или не виден, Selenium будет ждать, пока он не появится. К сожалению, этот пример устарел, однако, если вы посмотрите на некоторые из моих более свежих примеров, надеюсь, вы обнаружите, что они работают. seleniumexamples.com/blog/examples/selenium-2-examples

Ответ №2:

Я надеюсь, что это поможет вам

 driver.manage().timeouts().implicitlyWait(long time, java.util.concurrent.TimeUnit unit); 
  

или

 WebDriverWait wait = new WebDriverWait(driver, long timeOutInSeconds);

WebElement element = wait.until(presenceOfElementLocated(org.openqa.selenium.By locator));
  

Пожалуйста, обратите внимание, что я не выполнил этот код, поскольку у меня нет webdriver, но я написал это после обращения к javadocs.

Пожалуйста, обратитесь к javadocs для получения более подробной информации об этом.

Комментарии:

1. Здесь ошибка, последняя строка не должна включать тайм-аут в качестве параметра для wait.until. По крайней мере, не начиная с кода 2015 (но я также не понимаю, почему в старой версии было бы такое дублирование).

2. @EricaKane — Спасибо, что указали на это. Я это исправил.

3. У меня это сработало driver.manage().timeouts().implicitlyWait(2000,TimeUnit.MILLISECONDS);

Ответ №3:

driver.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS); это лучшее решение. В противном случае вам придется окружить driver.wait блоком синхронизации

Ответ №4:

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

Вероятно, вы намеревались вызвать метод selenium для ожидания условия: https://selenium.googlecode.com/svn/trunk/docs/api/java/org/openqa/selenium/support/ui/WebDriverWait.html

То, что вы на самом деле вызвали, было очень примитивным методом многопоточности (для ожидания, пока кто-то другой не вызовет notify () в вашем потоке): https://docs.oracle.com/javase/7/docs/api/java/lang/Object.html

Ответ №5:

Используйте приведенный ниже код, это сработает.

 synchronized (driver)
{
  driver.wait(2000);
}
driver.context(NATIVE_APP);
driver.findElementByXPath("//android.widget.Button[@resourceid=‘android:id/button1’]").click();