driver.wait()抛出IllegalMonitorStateException
wait(…)的所有变体都从以下代码中抛出以下exception。 我究竟做错了什么?
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(); }
如果您使用synchronized
获取了对象,则只能wait
对象。
我不知道你是否打算使用WebDriver wait
– 如果你是,你需要这样的东西:
synchronized (driver) { driver.wait(); }
但是,如果您正在等待某些事情发生,那么您更有可能使用另一种方法。 也许WebDriverWait
?
我希望这可以帮助你
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 。
这是一个死灵,但由于没有更好的答案,而其他人可能会发生:你正在调用错误的方法。
您可能打算将selenium方法称为等待条件: https : //selenium.googlecode.com/svn/trunk/docs/api/java/org/openqa/selenium/support/ui/WebDriverWait.html
您实际调用的是非常原始的multithreading方法(等到其他人在您的线程上调用notify()): https : //docs.oracle.com/javase/7/docs/api/java/lang/Object。 HTML
使用下面的代码,这将工作。
synchronized (driver) { driver.wait(2000); } driver.context(NATIVE_APP); driver.findElementByXPath("//android.widget.Button[@resourceid='android:id/button1']").click();