Skip to content

Commit

Permalink
Moving Wait from com.thoughtworks.selenium to com.thoughtworks.seleni…
Browse files Browse the repository at this point in the history
…um.webdriven because it is not used outside this package, and RC is going to be removed soon
  • Loading branch information
barancev committed Oct 29, 2014
1 parent 1cf9853 commit a79f932
Show file tree
Hide file tree
Showing 7 changed files with 126 additions and 5 deletions.
2 changes: 2 additions & 0 deletions java/client/src/com/thoughtworks/selenium/Wait.java
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,8 @@
*
*
* @author Dan Fabulich
*
* @deprecated Moved to com.thoughtworks.selenium.webdriven
*
*/
public abstract class Wait {
Expand Down
118 changes: 118 additions & 0 deletions java/client/src/com/thoughtworks/selenium/webdriven/Wait.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,118 @@
/*
Copyright 2006-2014 Selenium committers
Copyright 2006-2014 Software Freedom Conservancy
Licensed 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.webdriven;

/**
* A utility class, designed to help the user automatically wait until a condition turns true.
*
* Use it like this:
*
* <p>
* <code>new Wait("Couldn't find close button!") {<br/>
* &nbsp;&nbsp;&nbsp;&nbsp;boolean until() {<br/>
* &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return selenium.isElementPresent("button_Close");<br/>
* &nbsp;&nbsp;&nbsp;&nbsp;}<br/>
* };</code>
* </p>
*/
public abstract class Wait {
public Wait() {
}

public Wait(String messageToShowIfTimeout) {
wait(messageToShowIfTimeout, DEFAULT_TIMEOUT, DEFAULT_INTERVAL);
}

/** Returns 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);
}

}
}
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@

package com.thoughtworks.selenium.webdriven.commands;

import com.thoughtworks.selenium.Wait;
import com.thoughtworks.selenium.webdriven.Wait;
import com.thoughtworks.selenium.webdriven.ScriptMutator;
import com.thoughtworks.selenium.webdriven.SeleneseCommand;

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@

import com.google.common.base.Throwables;

import com.thoughtworks.selenium.Wait;
import com.thoughtworks.selenium.webdriven.Wait;
import com.thoughtworks.selenium.webdriven.SeleneseCommand;

import org.openqa.selenium.By;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@
package com.thoughtworks.selenium.webdriven.commands;

import com.thoughtworks.selenium.SeleniumException;
import com.thoughtworks.selenium.Wait;
import com.thoughtworks.selenium.webdriven.Wait;
import com.thoughtworks.selenium.webdriven.SeleneseCommand;
import com.thoughtworks.selenium.webdriven.Windows;

Expand Down
3 changes: 2 additions & 1 deletion java/client/test/com/thoughtworks/selenium/WaitTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,8 @@
import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail;

import com.thoughtworks.selenium.Wait.WaitTimedOutException;
import com.thoughtworks.selenium.webdriven.Wait;
import com.thoughtworks.selenium.webdriven.Wait.WaitTimedOutException;

import org.junit.Before;
import org.junit.Test;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@
import static org.junit.Assert.fail;

import com.thoughtworks.selenium.Selenium;
import com.thoughtworks.selenium.Wait;
import com.thoughtworks.selenium.webdriven.Wait;
import com.thoughtworks.selenium.webdriven.WebDriverBackedSelenium;

import org.junit.Before;
Expand Down

0 comments on commit a79f932

Please sign in to comment.