Html Elements framework
[]
(https://github.com/yandex-qatools/htmlelements/releases/latest)
[
]
(https://maven-badges.herokuapp.com/maven-central/ru.yandex.qatools.htmlelements/htmlelements-java)
This framework is designed to provide an easy-to-use way of interacting with web-page elements in your tests. It can be considered to be an extension of WebDriver Page Object.
With the help of the Html Elements framework you can group web-page elements into blocks, encapsulate logic of interaction within them and then easily use created blocks in page objects. It also provides a set of helpful matchers to use with web-page elements and blocks. See [JavaDocs] (https://oss.sonatype.org/service/local/repositories/releases/archive/ru/yandex/qatools/htmlelements/htmlelements-java/1.16/htmlelements-java-1.16-javadoc.jar/!/index.html) and Samples for more details.
You can ask your questions on StackOverflow with the [![htmlelements] (https://img.shields.io/badge/stackoverflow-htmlelements-orange.svg?style=flat)] (http://stackoverflow.com/questions/tagged/htmlelements) tag.
Other Languages
In case you are not a Java guy/gal, don't panic, there are still few options:
- Html Elements .NET implementation - .NET port made by Vadzim Hushchanskou
- Html Elements PHP implementation - PHP port made by Alexander Obuhovich
- bumblebee framework (C#) - same idea, nice implementation
Release Notes
- Version 1.17 Release Notes
- Version 1.16 Release Notes
- Version 1.15 Release Notes
- Version 1.14 Release Notes
- Version 1.13 Release Notes
- Version 1.12 Release Notes
- Version 1.11 Release Notes
- Version 1.10 Release Notes
- Version 1.9 Release Notes
Include Html Elements in your project
Maven dependencies for Html Elements core:
<dependency> <groupId>ru.yandex.qatools.htmlelements</groupId> <artifactId>htmlelements-java</artifactId> <version>1.17</version> </dependency>
And for Thucydides integration:
<dependency> <groupId>ru.yandex.qatools.htmlelements</groupId> <artifactId>htmlelements-thucydides</artifactId> <version>1.17</version> </dependency>
Or you can include all modules at once if needed:
<dependency> <groupId>ru.yandex.qatools.htmlelements</groupId> <artifactId>htmlelements-all</artifactId> <version>1.17</version> </dependency>
Since 1.15 Java 8 is required. Please use 1.14 for Java 7 support.
Create blocks of elements
For example, let's create a block for the search form on the page http://www.yandex.com:
@Name("Search form") @FindBy(xpath = "//form") public class SearchArrow extends HtmlElement { @Name("Search request input") @FindBy(id = "searchInput") private TextInput requestInput; @Name("Search button") @FindBy(className = "b-form-button__input") private Button searchButton; public void search(String request) { requestInput.sendKeys(request); searchButton.click(); } }
Construct page object using created blocks
You can easily use created blocks in page objects:
public class SearchPage { private SearchArrow searchArrow; // Other blocks and elements here ... public SearchPage(WebDriver driver) { PageFactory.initElements(new HtmlElementDecorator(new HtmlElementLocatorFactory(driver)), this); } public void search(String request) { searchArrow.search(request); } // Other methods here ... }
Use page objects in your tests
Created page objects can be used in your tests. This makes tests more concise, easier to maintain, and easy to write.
public class SampleTest { private WebDriver driver = new FirefoxDriver(); private SearchPage searchPage = new SearchPage(driver); @Before public void loadPage() { driver.get("http://www.yandex.com"); } @Test public void sampleTest() { searchPage.search("yandex"); // Some assertion here } @After public void closeDriver() { driver.quit(); } }
Questions?
In case you can't find an answer in documentation and examples provided above, you can ask it on StackOverflow with the
tag.