com.redhat.darcy.webdriver.internal.TargetedWebDriver Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of darcy-webdriver Show documentation
Show all versions of darcy-webdriver Show documentation
An implementation of darcy and darcy-web that uses Selenium WebDriver as the automation library backend.
The newest version!
/*
Copyright 2014 Red Hat, Inc. and/or its affiliates.
This file is part of darcy-webdriver.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see .
*/
package com.redhat.darcy.webdriver.internal;
import com.redhat.darcy.ui.api.elements.Findable;
import org.openqa.selenium.TakesScreenshot;
import org.openqa.selenium.WebDriver;
/**
* Interface for {@link WebDriver} implementations that are "targeted", that is, every method
* invocation on the driver will be intercepted so that the driver may be switched to the
* appropriate target before proceeding with the method. A target is a specific frame or
* window. In this way, every instance of a TargetedWebDriver is specific to a target that a driver
* may point to, as opposed to pointing to one of a number of possible targets.
*
* Elements found by this driver should also be targeted. That is, elements are associated with a
* driver and target and will ensure the driver is switched before interacting with the element.
*/
public interface TargetedWebDriver extends WebDriver, Findable, TakesScreenshot {
WebDriverTarget getWebDriverTarget();
/**
* Send future commands to a different frame or window. These windows and frames will be
* "targeted." That is, specific driver instances will refer to specific targets, and only their
* target, ever.
*/
@Override
TargetedTargetLocator switchTo();
}