com.redhat.darcy.webdriver.ElementConstructor 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;
import com.redhat.darcy.ui.api.ElementContext;
import com.redhat.darcy.ui.api.elements.Element;
import com.redhat.darcy.webdriver.elements.WebDriverElement;
import com.redhat.darcy.webdriver.internal.ElementLookup;
/**
* A {@link FunctionalInterface} to represent {@link WebDriverElement}s' and subclasses'
* constructors.
*
* Intended to match the signature of
* {@link WebDriverElement#WebDriverElement(com.redhat.darcy.webdriver.internal.ElementLookup, com.redhat.darcy.ui.api.ElementContext)},
* so that a constructor reference may be used as an implementation of this interface. So, for
* example, where a method accepts an {@code ElementConstructor} you may simply pass,
* {@code WebDriverElement::new}.
*/
@FunctionalInterface
public interface ElementConstructor {
T newElement(ElementLookup source, ElementContext context);
}