All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.thoughtworks.selenium.Wait Maven / Gradle / Ivy

Go to download

Selenium automates browsers. That's it! What you do with that power is entirely up to you.

There is a newer version: 4.0.0-alpha-2
Show newest version
// Licensed to the Software Freedom Conservancy (SFC) under one
// or more contributor license agreements.  See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership.  The SFC licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License.  You may obtain a copy of the License at
//
//   http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied.  See the License for the
// specific language governing permissions and limitations
// under the License.


package com.thoughtworks.selenium;

/**
 * A utility class, designed to help the user automatically wait until a condition turns true.
 *
 * Use it like this:
 *
 * 
{@code
 * new Wait("Couldn't find close button!") {
 *     boolean until() {
 *         return selenium.isElementPresent("button_Close");
 *     }
 * };}
* * * @author Dan Fabulich * * @deprecated The RC interface will be removed in Selenium 3.0. Please migrate to using WebDriver. */ @Deprecated public abstract class Wait { public Wait() { } public Wait(String messageToShowIfTimeout) { wait(messageToShowIfTimeout, DEFAULT_TIMEOUT, DEFAULT_INTERVAL); } /** @return true when it's time to stop waiting */ public abstract boolean until(); /** The amount of time to wait before giving up; the default is 30 seconds */ public static final long DEFAULT_TIMEOUT = 30000L; /** The interval to pause between checking; the default is 500 milliseconds */ public static final long DEFAULT_INTERVAL = 500L; /** * Wait until the "until" condition returns true or time runs out. * * @param message the failure message * @throws WaitTimedOutException if "until" doesn't return true until the timeout * @see #until() */ public void wait(String message) { wait(message, DEFAULT_TIMEOUT, DEFAULT_INTERVAL); } /** * Wait until the "until" condition returns true or time runs out. * * @param message the failure message * @param timeoutInMilliseconds the amount of time to wait before giving up * @throws WaitTimedOutException if "until" doesn't return true until the timeout * @see #until() */ public void wait(String message, long timeoutInMilliseconds) { wait(message, timeoutInMilliseconds, DEFAULT_INTERVAL); } /** * Wait until the "until" condition returns true or time runs out. * * @param message the failure message * @param timeoutInMilliseconds the amount of time to wait before giving up * @param intervalInMilliseconds the interval to pause between checking "until" * @throws WaitTimedOutException if "until" doesn't return true until the timeout * @see #until() */ public void wait(String message, long timeoutInMilliseconds, long intervalInMilliseconds) { long start = System.currentTimeMillis(); long end = start + timeoutInMilliseconds; while (System.currentTimeMillis() < end) { if (until()) return; try { Thread.sleep(intervalInMilliseconds); } catch (InterruptedException e) { throw new RuntimeException(e); } } throw new WaitTimedOutException(message); } public class WaitTimedOutException extends RuntimeException { private static final long serialVersionUID = 1L; public WaitTimedOutException() { super(); } public WaitTimedOutException(String message, Throwable cause) { super(message, cause); } public WaitTimedOutException(String message) { super(message); } public WaitTimedOutException(Throwable cause) { super(cause); } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy