org.fluentlenium.configuration.ConfigurationProperties Maven / Gradle / Ivy
package org.fluentlenium.configuration;
import org.fluentlenium.adapter.FluentAdapter;
import org.fluentlenium.core.FluentControl;
import org.openqa.selenium.Capabilities;
import org.openqa.selenium.WebDriver;
/**
* FluentLenium can be configured in many ways through configuration properties.
*
* It's possible to define those properties using:
*
* - Overrides of JavaBean property getters of the test class.
* (ie. override {@link Configuration#getWebDriver()})
*
* - JavaBean property setters of the test class.
* (ie. call {@link Configuration#setWebDriver(String)})
*
* - System properties of the Java Environment, passed using -D on the command line.
* Property names must be prefixed with fluentlenium..
* (ie. Launch test with
-Dfluentlenium.webDriver=chrome
)
*
* -
* Environment Variable of the Operating System. Property names must be prefixed with fluentlenium..
* (ie: EXPORT fluentlenium.webDriver=chrome)
*
* -
* {@link FluentConfiguration} annotation on test class to configure.
*
* {@code
*
* {@literal @FluentConfiguration(webDriver="chrome")} public class SomeFluentTest extends FluentTest {
* ....
* }
* }
*
*
* -
* Java Properties file located at
/fluentlenium.properties
in the classpath
*
* {@code
* webDriver=chrome
* ...
* }
*
*
* -
* {@link ConfigurationProperties} custom implementation specified by
configurationDefaults
property.
*
* {@code
* public class CustomConfigurationDefaults extends ConfigurationDefaults {
* {@literal @Override} public String getWebDriver() {
* return "chrome";
* }
* }
*
* $ cat fluentlenium.properties
* configurationDefaults=org.your.package.CustomConfigurationDefaults
* }
*
*
*
* This list of way to configure fluentlenium is ordered by priority. If a value is defined in an element, lower ways
* to define it will be ignored.
*
* You may implement additionnal ways to read configuration property by implementing another
* {@link ConfigurationFactory} and set your configuration factory class in the
*
configurationFactory
property.
*
* @see ConfigurationFactory
* @see DefaultConfigurationFactory
*/
public interface ConfigurationProperties {
/**
* Trigger mode for Screenshots and HtmlDump features
*/
enum TriggerMode {
/**
* Take screenshot when the test fail.
*/
AUTOMATIC_ON_FAIL, /**
* Only take screenshot manually through API.
*/
MANUAL, /**
* Default value.
*/
DEFAULT
}
/**
* Driver lifecycle.
*/
enum DriverLifecycle {
/**
* WebDriver is created once, and same instance is used for each test class and method.
*/
JVM, /**
* WebDriver is created for each test class, and same instance is used for each test method in the class.
*/
CLASS, /**
* WebDriver is created for each test method, and this instance is used only for one test method.
*/
METHOD, /**
* WebDriver is created for each test thread, and this instance is used only for one test method.
*/
THREAD, /**
* Default value.
*/
DEFAULT
}
/**
* webDriver
property.
*
* Sets the WebDriver type to use.
*
* When FluentLenium needs to create a new {@link WebDriver} instance, it calls {@link FluentAdapter#newWebDriver()}
* which delegates to
* {@link org.fluentlenium.configuration.WebDriversRegistryImpl#newWebDriver(String, Capabilities, ConfigurationProperties)}
* registry using the value stored in webDriver and capabilities property.
*
* Possible values are "firefox", "chrome", "ie", "edge", "htmlunit", "safari", "phantomjs", "opera", "remote"
* or any class name implementing {@link WebDriver}
* or any name that is defined in the `@FactoryName` annotation of a `WebDriverFactory` implementation.
*
* Default value is "firefox".
*
* @return webDriver property value
* @see FluentAdapter#newWebDriver()
* @see DefaultWebDriverFactories
*/
String getWebDriver();
/**
*
remoteUrl
property.
*
* Sets the remoteUrl for "remote" webDriver.
*
* @return remoteUrl property value
* @see org.openqa.selenium.remote.RemoteWebDriver
*/
String getRemoteUrl();
/**
* capabilities
property.
*
* Sets the Capabilities to use, as a
* JSON Object or a URL pointing to a JSON Object.
*
* Default value is "null".
*
* @return Capabilities property value
* @see Capabilities
* @see Selenium DesiredCapabilities Wiki Page
*/
Capabilities getCapabilities();
/**
* baseUrl
property.
*
* Sets the base URL used to build absolute URL when relative URL is given to {@link FluentAdapter#goTo(String)}.
*
* Default value is null.
*
* @return baseUrl property value
*/
String getBaseUrl();
/**
* driverLifecycle
property.
*
* Sets the lifecycle of the WebDriver. WebDriver is fully managed by FluentLenium, so you should never
* create or quit a WebDriver by yourself.
*
* Please keep in mind that this configures when drivers are created and exited at runtime, but it does not deal with
* concurrency of your tests.
*
* Default value is METHOD.
*
* @return driverLifecycle property value
*/
DriverLifecycle getDriverLifecycle();
/**
* browserTimeout
property.
*
* Sets the maximum amount of time when the browser should start responding to the WebDriver.
*
* Default value is 60 seconds.
*
* @return long
*/
Long getBrowserTimeout();
/**
* browserTimeoutRetries
property.
*
* Sets the maximum number of retries for failed WebDriver because of browserTimeout issues.
*
* Default value is 2 times.
*
* @return Integer
*/
Integer getBrowserTimeoutRetries();
/**
* deleteCookies
property.
*
* When using CLASS or JVM driverLifecycle
configuration property, allow to delete cookies between
* each test.
*
* Default value is false.
*
* @return deleteCookies property value.
*/
Boolean getDeleteCookies();
/**
* pageLoadTimeout
property.
*
* Sets the amount of time in millisecond to wait for a page load to complete before throwing an error.
* If the timeout is negative, page loads can be indefinite.
*
* Default value is null.
*
* @return pageLoadTimeout property value
* @see org.openqa.selenium.WebDriver.Timeouts#pageLoadTimeout(long, java.util.concurrent.TimeUnit)
*/
Long getPageLoadTimeout();
/**
* implicitlyWait
property.
*
* Specifies the amount of time in millisecond the driver should wait when searching for an element if it is
* not immediately present.
*
* Default value is null.
*
* @return implicitlyWait property value
* @see org.openqa.selenium.WebDriver.Timeouts#implicitlyWait(long, java.util.concurrent.TimeUnit)
*/
Long getImplicitlyWait();
/**
* scriptTimeout
property.
*
* Sets the amount of time in millisecond to wait for an asynchronous script to finish execution before
* throwing an error. If the timeout is negative, then the script will be allowed to run
* indefinitely.
*
* Default value is null.
*
* @return scriptTimeout property value
* @see org.openqa.selenium.WebDriver.Timeouts#setScriptTimeout(long, java.util.concurrent.TimeUnit)
*/
Long getScriptTimeout();
/**
* awaitAtMost
property.
*
* Sets the default timeout in millisecond when using {@link FluentControl#await()} or
* {@link org.fluentlenium.core.hook.wait.Wait} hook.
*
* @return awaitTimeout property value
* @see org.fluentlenium.core.wait.FluentWait#atMost(long, java.util.concurrent.TimeUnit)
* @see org.fluentlenium.core.wait.FluentWait#atMost(long)
*/
Long getAwaitAtMost();
/**
* awaitPollingEvery
property.
*
* Sets the default polling frequency in millisecond when using {@link FluentControl#await()} or
* {@link org.fluentlenium.core.hook.wait.Wait} hook.
*
* @return awaitPollingEvery property value
* @see org.fluentlenium.core.wait.FluentWait#pollingEvery(long, java.util.concurrent.TimeUnit)
* @see org.fluentlenium.core.wait.FluentWait#pollingEvery(long)
*/
Long getAwaitPollingEvery();
/**
* eventsEnabled
property.
*
* Enables {@link FluentAdapter#events()} by wrapping the {@link WebDriver} in
* {@link org.openqa.selenium.support.events.EventFiringWebDriver}.
*
* Default value is true.
*
* @return eventsEnabled property value.
*/
Boolean getEventsEnabled();
/**
* screenshotPath
property.
*
* Sets the filesystem path where screenshot will be saved when calling {@link FluentAdapter#takeScreenshot()} or
* {@link FluentAdapter#takeScreenshot(String)}.
*
* Default value is null.
*
* @return screenshotPath property value
*/
String getScreenshotPath();
/**
* screenshotMode
property.
*
* Sets the trigger mode of screenshots. Can be {AUTOMATIC_ON_FAIL} to take screenshot when the test fail or {MANUAL}.
*
* Default value is null.
*
* @return screenshotMode property value.
* @see TriggerMode
*/
TriggerMode getScreenshotMode();
/**
* htmlDumpPath
property.
*
* Sets the filesystem path where screenshot will be saved when calling {@link FluentAdapter#takeHtmlDump()} or
* {@link FluentAdapter#takeHtmlDump(String)}.
*
* Default value is null.
*
* @return htmlDumpPath property value
*/
String getHtmlDumpPath();
/**
* htmlDumpMode
property.
*
* Sets the trigger mode of htmlDump. Can be {AUTOMATIC_ON_FAIL} to take html dump when the test fail or {MANUAL}.
*
* Default value is null.
*
* @return htmlDumpMode property value.
* @see TriggerMode
*/
TriggerMode getHtmlDumpMode();
/**
* configurationDefaults
property.
*
* Set this to a class implementing {@link ConfigurationProperties} to provide the default values
* of the configuration properties.
*
* Default value is {@link ConfigurationDefaults}
*
* @return Custom {@link ConfigurationProperties} instance with default values.
*/
Class extends ConfigurationProperties> getConfigurationDefaults();
/**
* configurationFactory
property.
*
* Set this to a class implementing {@link ConfigurationFactory} to customize the ways properties are read.
* This allow to configure properties from sources that are not supported by default FluentLenium.
*
* Default value is {@link DefaultConfigurationFactory} class.
*
* @return Custom {@link ConfigurationFactory} class.
*/
Class extends ConfigurationFactory> getConfigurationFactory();
/**
* Get custom property value.
*
* @param propertyName name of the property
* @return property value
*/
String getCustomProperty(String propertyName);
}