Skip to content

Commit

Permalink
#2: Added documentation
Browse files Browse the repository at this point in the history
  • Loading branch information
Artem Eroshenko committed May 7, 2013
1 parent eab13d1 commit 7be6910
Show file tree
Hide file tree
Showing 2 changed files with 139 additions and 4 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -13,24 +13,22 @@
*/
public class SearchPage {

@SuppressWarnings("unused")
private WebDriver driver;

@FindBy(className = "b-serp-list")
@SuppressWarnings("unused")
private SearchResults searchResults;

@FindBy(className = "b-morda-search-form")
@SuppressWarnings("unused")
private SearchArrow searchArrow;

public SearchPage(WebDriver driver) {
PageFactory.initElements(new HtmlElementDecorator(driver), this);
this.driver = driver;
}

public void searchFor(String request) {
public SearchPage searchFor(String request) {
this.searchArrow.searchFor(request);
return this;
}

public SearchResults getSearchResults() {
Expand Down
137 changes: 137 additions & 0 deletions htmlelements-junit-example/src/site/junit-example.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,137 @@
HtmlElements jUnit Samples
==========================

Подключение зависимостей
------------------------

Чтобы использовать библиотеку HtmlElements необходимо создать простой [maven-проект](http://maven.apache.org/guides/getting-started/index.html).
После этого добавить в зависимости свежую версию библиотеки:

```xml
<dependency>
<groupId>ru.yandex.qatools.htmlelements</groupId>
<artifactId>htmlelements-java</artifactId>
<version>1.10</version>
</dependency>
```

Выполните команду `mvn clean compile`, чтобы проерить, что ваш проект компилируется.

Пример использования HtmlElements
---------------------------------

В качестве примера возьмем главную страницу Яндекса (http://www.yandex.ru).
Давайте опишем для начала простенький элемент, например поисковую строку:

```java
public class SearchArrow extends HtmlElement {

@FindBy(xpath = ".//input[@class='b-form-input__input']")
public TextInput requestInput;

@FindBy(xpath = ".//input[@class='b-form-button__input']")
public Button searchButton;

public void searchFor(String request) {
requestInput.clear();
requestInput.sendKeys(request);
searchButton.click();
}
}
```

Этот класс описывает структуру поисковой строки и логику взаимодействия с ней.
Дальше необходимо создать класс MainPage, который содержит поисковую строку:

```java
public class MainPage {

private WebDriver driver;

@FindBy(className = "b-morda-search-form")
private SearchArrow searchArrow;

public MainPage(final WebDriver driver) {
PageFactory.initElements(new HtmlElementDecorator(driver), this);
this.driver = driver;
}

public SearchPage searchFor(String request) {
this.searchArrow.searchFor(request);
return new SearchPage(driver);
}

}
```

Как видно, в конструкторе вызывается инициализация внутренних эелементов стнаицы MainPage используется
кастомный декоратор полей класса: HtmlElementDecorator.
Так как поле 'searchArrow' является наследником HtmlElements, то его инициализация происходит рекурсивно.
Таком образом, инициализируются и внутренние элементы поисковой строки:
- protected WebElement requestInput;
- protected WebElement searchButton;

Как видно из описания, метод `searchFor` возвращает экземпляр поисковой страницы. Опишем ее:

```java
public class SearchPage {

private WebDriver driver;

@FindBy(className = "b-serp-list")
private SearchResults searchResults;

@FindBy(className = "b-morda-search-form")
private SearchArrow searchArrow;

public SearchPage(WebDriver driver) {
PageFactory.initElements(new HtmlElementDecorator(driver), this);
this.driver = driver;
}

public SearchPage searchFor(String request) {
this.searchArrow.searchFor(request);
return this;
}

public SearchResults getSearchResults() {
return this.searchResults;
}
}
```

Для того, чтобы это проверить создадим простенький тест для проверки поисковых результатов,
в котором создим экземляр нашей страницы:

```java
public class SearchingByRequestTest {

private final int DEFAULT_RESULTS_COUNT;

public WebDriver driver = new FirefoxDriver();

public SearchingByRequestTest() {
DEFAULT_RESULTS_COUNT = 10;
}

@Before
public void loadStartPage() {
driver.get("http://www.yandex.ru");
}

@Test
public void afterSearchingUserShouldSeSearchResults() {
MainPage mainPage = new MainPage(driver);
SearchPage page = mainPage.searchFor("Yandex");
assertThat(page.getSearchResults(), exists());
assertThat(page.getSearchResults().getSearchItems(), hasSize(DEFAULT_RESULTS_COUNT));
}

@After
public void killWebDriver() {
driver.quit();
}
}
```

В этом примере видно, что после инициализации самой страницы `MainPage` произошла инициализация внутренних элементов.

0 comments on commit 7be6910

Please sign in to comment.