![JAR search and dependency download from the Maven repository](/logo.png)
io.tourniquet.pageobjects.Locator Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of tourniquet-pageobjects Show documentation
Show all versions of tourniquet-pageobjects Show documentation
A small library to define a pageobject model for testing applications with selenium.
/*
* Copyright 2015-2016 DevCon5 GmbH, [email protected]
*
* 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 io.tourniquet.pageobjects;
import java.lang.annotation.ElementType;
import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import java.util.Optional;
import java.util.function.Function;
import org.openqa.selenium.By;
import org.openqa.selenium.SearchContext;
import org.openqa.selenium.WebElement;
/**
* A locator annotation to declare how a page or an element can be addressed
*/
@Inherited
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.TYPE, ElementType.METHOD, ElementType.FIELD})
public @interface Locator {
/**
* The locator string to specify which element should be located
*
* @return
*/
String value();
/**
* Specifies the locator type
*
* @return
*/
ByLocator by() default ByLocator.URL;
/**
* Timeout in seconds to wait for the element to be present
*
* @return
*/
int timeout() default 60;
enum ByLocator {
/**
* URL are only for pages
*/
URL(null) {
@Override
public Optional locate(String selector) {
return SeleniumContext.currentDriver().flatMap(
d -> {
d.navigate().to(SeleniumContext.resolve(selector));
return Optional.empty();
});
}
},
ID(By::id),
LINK_TEXT(By::linkText),
PARTIAL_LINK_TEXT(By::partialLinkText),
NAME(By::name),
TAG(By::tagName),
XPATH(By::xpath),
CLASS(By::className),
CSS(By::cssSelector);
private transient final Optional> mapper;
ByLocator(Function mapper) {
this.mapper = Optional.ofNullable(mapper);
}
/**
* Locates the web element on the current page using the appropriate locator strategy
*
* @param selector
* the selector for the element to select
*
* @return a reference to the element
*/
public Optional locate(String selector) {
return SeleniumContext.currentDriver().flatMap(d -> locate(d, selector));
}
/**
* Locates the web element on the current page using the appropriate locator strategy
*
* @param selector
* the selector for the element to select
*
* @return a reference to the element
*/
public Optional locate(SearchContext parent, String selector) {
return mapper.map(by -> parent.findElement(by.apply(selector)));
}
/**
* Transforms the ByLocator to a Selenium {@link org.openqa.selenium.By} literal.
* @param selector
* the selector String
* @return
* the selenium By literal
*/
public By withSelector(String selector) {
return mapper.map(by -> by.apply(selector))
.orElseThrow(() -> new IllegalArgumentException("Not supported for " + this.name()));
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy