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

org.fluentlenium.adapter.FluentAdapter Maven / Gradle / Ivy

There is a newer version: 5.0.4
Show newest version
package org.fluentlenium.adapter;

import lombok.experimental.Delegate;
import org.fluentlenium.configuration.Configuration;
import org.fluentlenium.configuration.ConfigurationFactoryProvider;
import org.fluentlenium.configuration.ConfigurationProperties;
import org.fluentlenium.configuration.WebDrivers;
import org.fluentlenium.core.FluentControl;
import org.fluentlenium.core.FluentDriver;
import org.fluentlenium.core.SeleniumDriverControl;
import org.fluentlenium.core.inject.ContainerContext;
import org.fluentlenium.core.inject.ContainerFluentControl;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.support.events.EventFiringWebDriver;

/**
 * Generic adapter to {@link FluentDriver}.
 */
public class FluentAdapter implements FluentControl {

    private final FluentControlContainer controlContainer;

    private final Configuration configuration = ConfigurationFactoryProvider.newConfiguration(getClass());

    /**
     * Creates a new fluent adapter.
     */
    public FluentAdapter() {
        this(new DefaultFluentControlContainer());
    }

    /**
     * Creates a new fluent adapter, using given control interface container.
     *
     * @param controlContainer control interface container
     */
    public FluentAdapter(FluentControlContainer controlContainer) {
        this.controlContainer = controlContainer;
    }

    /**
     * Get the test adapter configuration.
     *
     * @return configuration
     */
    @Delegate
    public Configuration getConfiguration() {
        return configuration;
    }

    @Delegate(types = FluentControl.class, excludes = {SeleniumDriverControl.class, Configuration.class})
    // We want getDriver to be final.
    private ContainerFluentControl getFluentControl() {
        return (ContainerFluentControl) getControlContainer().getFluentControl();
    }

    /**
     * Check if fluent control interface is available from the control interface container.
     *
     * @return true if the fluent control interface is available, false otherwise
     */
    /* default */ boolean isFluentControlAvailable() {
        return getControlContainer().getFluentControl() != null;
    }

    private void setFluentControl(ContainerFluentControl fluentControl) {
        getControlContainer().setFluentControl(fluentControl);
    }

    @Override
    public final WebDriver getDriver() {
        return getFluentControl() == null ? null : getFluentControl().getDriver();
    }

    /**
     * Get the control interface container
     *
     * @return control interface container
     */
    protected FluentControlContainer getControlContainer() {
        return controlContainer;
    }

    /**
     * Load a {@link WebDriver} into this adapter.
     * 

* This method should not be called by end user. * * @param webDriver webDriver to use. * @throws IllegalStateException when trying to register a different webDriver that the current one. */ public void initFluent(WebDriver webDriver) { if (webDriver == null) { releaseFluent(); return; } if (getFluentControl() != null) { if (getFluentControl().getDriver() == webDriver) { return; } if (getFluentControl().getDriver() != null) { throw new IllegalStateException("Trying to init a WebDriver, but another one is still running"); } } ContainerFluentControl adapterFluentControl = new ContainerFluentControl(new FluentDriver(webDriver, this, this)); setFluentControl(adapterFluentControl); ContainerContext context = adapterFluentControl.inject(this); adapterFluentControl.setContext(context); } /** * Release the current {@link WebDriver} from this adapter. *

* This method should not be called by end user. */ public void releaseFluent() { if (getFluentControl() != null) { ((FluentDriver) getFluentControl().getAdapterControl()).releaseFluent(); setFluentControl(null); } } /** * Creates a new {@link WebDriver} instance. *

* This method should not be called by end user, but may be overriden if required. *

* Before overriding this method, you should consider using {@link WebDrivers} registry and configuration * {@link ConfigurationProperties#getWebDriver()}. *

* To retrieve the current managed {@link WebDriver}, call {@link #getDriver()} instead. * * @return A new WebDriver instance. * @see #getDriver() */ public WebDriver newWebDriver() { WebDriver webDriver = WebDrivers.INSTANCE.newWebDriver(getWebDriver(), getCapabilities(), this); if (Boolean.TRUE.equals(getEventsEnabled())) { webDriver = new EventFiringWebDriver(webDriver); } return webDriver; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy