diff options
author | Artur <artur@vaadin.com> | 2017-01-11 13:45:51 +0200 |
---|---|---|
committer | Henri Sara <henri.sara@gmail.com> | 2017-01-11 13:45:51 +0200 |
commit | f7e33df4fcf07a73a06a372955b793bd77fe103a (patch) | |
tree | 2983cb6a2d0f0a1c77d67283220e3c546c6711e7 /testbench-api/src/main/java | |
parent | aae36190f7647dc773c7410f68f41b731c937d97 (diff) | |
download | vaadin-framework-f7e33df4fcf07a73a06a372955b793bd77fe103a.tar.gz vaadin-framework-f7e33df4fcf07a73a06a372955b793bd77fe103a.zip |
Import element tests from TestBench (#8117)
Contains some additional tests and element changes based on review.
Diffstat (limited to 'testbench-api/src/main/java')
6 files changed, 51 insertions, 30 deletions
diff --git a/testbench-api/src/main/java/com/vaadin/testbench/elements/CheckBoxElement.java b/testbench-api/src/main/java/com/vaadin/testbench/elements/CheckBoxElement.java index 6263ce5b0f..788d4a917d 100644 --- a/testbench-api/src/main/java/com/vaadin/testbench/elements/CheckBoxElement.java +++ b/testbench-api/src/main/java/com/vaadin/testbench/elements/CheckBoxElement.java @@ -67,6 +67,9 @@ public class CheckBoxElement extends AbstractFieldElement { @Override public void click() { + if (isReadOnly()) { + throw new ReadOnlyException(); + } WebElement input = getInputElement(); if (isFirefox()) { // When using Valo, the input element is covered by a diff --git a/testbench-api/src/main/java/com/vaadin/testbench/elements/CheckBoxGroupElement.java b/testbench-api/src/main/java/com/vaadin/testbench/elements/CheckBoxGroupElement.java index ed657c085d..ae6e65a62d 100644 --- a/testbench-api/src/main/java/com/vaadin/testbench/elements/CheckBoxGroupElement.java +++ b/testbench-api/src/main/java/com/vaadin/testbench/elements/CheckBoxGroupElement.java @@ -55,11 +55,12 @@ public class CheckBoxGroupElement extends AbstractSelectElement { } /** - * Return value of the selected option in the option group + * Return list of the selected options in the checkbox group * - * @return value of the selected option in the option group + * @return list of the selected options in the checkbox group */ - public String getValue() { + public List<String> getSelection() { + List<String> values = new ArrayList<>(); List<WebElement> options = findElements(bySelectOption); for (WebElement option : options) { WebElement checkedItem; @@ -67,14 +68,14 @@ public class CheckBoxGroupElement extends AbstractSelectElement { String checked = checkedItem.getAttribute("checked"); if (checked != null && checkedItem.getAttribute("checked").equals("true")) { - return option.findElement(By.tagName("label")).getText(); + values.add(option.findElement(By.tagName("label")).getText()); } } - return null; + return values; } /** - * Select option in the option group with the specified value + * Select option in the option group with the specified value. * * @param chars * value of the option in the option group which will be selected diff --git a/testbench-api/src/main/java/com/vaadin/testbench/elements/ComboBoxElement.java b/testbench-api/src/main/java/com/vaadin/testbench/elements/ComboBoxElement.java index 980c4a1e7f..dcd6725363 100644 --- a/testbench-api/src/main/java/com/vaadin/testbench/elements/ComboBoxElement.java +++ b/testbench-api/src/main/java/com/vaadin/testbench/elements/ComboBoxElement.java @@ -44,6 +44,10 @@ public class ComboBoxElement extends AbstractSelectElement { * the text of the option to select */ public void selectByText(String text) { + if (isReadOnly()) { + throw new ReadOnlyException(); + } + if (!isTextInputAllowed()) { selectByTextFromPopup(text); return; @@ -57,7 +61,7 @@ public class ComboBoxElement extends AbstractSelectElement { /** * Selects, without filtering, the first option in the ComboBox which * matches the given text. - * + * * @param text * the text of the option to select */ @@ -96,7 +100,7 @@ public class ComboBoxElement extends AbstractSelectElement { /** * Checks if text input is allowed for the combo box. - * + * * @return <code>true</code> if text input is allowed, <code>false</code> * otherwise */ diff --git a/testbench-api/src/main/java/com/vaadin/testbench/elements/ListSelectElement.java b/testbench-api/src/main/java/com/vaadin/testbench/elements/ListSelectElement.java index 4ce4c9008f..77660904f3 100644 --- a/testbench-api/src/main/java/com/vaadin/testbench/elements/ListSelectElement.java +++ b/testbench-api/src/main/java/com/vaadin/testbench/elements/ListSelectElement.java @@ -40,7 +40,7 @@ public class ListSelectElement extends AbstractSelectElement { } /** - * Selects the option(s) with the given text. + * Selects the option with the given text. * <p> * For a ListSelect in multi select mode, adds the given option(s) to the * current selection. @@ -49,6 +49,10 @@ public class ListSelectElement extends AbstractSelectElement { * the text of the option */ public void selectByText(String text) { + if (isReadOnly()) { + throw new ReadOnlyException(); + } + select.selectByVisibleText(text); if (isPhantomJS() && select.isMultiple()) { // Phantom JS does not fire a change event when @@ -64,6 +68,9 @@ public class ListSelectElement extends AbstractSelectElement { * the text of the option */ public void deselectByText(String text) { + if (isReadOnly()) { + throw new ReadOnlyException(); + } select.deselectByVisibleText(text); if (isPhantomJS() && select.isMultiple()) { // Phantom JS does not fire a change event when diff --git a/testbench-api/src/main/java/com/vaadin/testbench/elements/SliderElement.java b/testbench-api/src/main/java/com/vaadin/testbench/elements/SliderElement.java index 396a2435b3..5f20c0b9d2 100644 --- a/testbench-api/src/main/java/com/vaadin/testbench/elements/SliderElement.java +++ b/testbench-api/src/main/java/com/vaadin/testbench/elements/SliderElement.java @@ -15,10 +15,7 @@ */ package com.vaadin.testbench.elements; -import java.util.List; - import org.openqa.selenium.WebElement; -import org.openqa.selenium.remote.BrowserType; import com.vaadin.testbench.By; import com.vaadin.testbench.elementsbase.ServerClass; @@ -27,27 +24,13 @@ import com.vaadin.testbench.elementsbase.ServerClass; public class SliderElement extends AbstractFieldElement { /** * Get value of the slider - * + * * Warning! This method cause slider popup to appear on the screen. To hide * this popup just focus any other element on the page. */ public String getValue() { - List<WebElement> popupElems = findElements(By.vaadin("#popup")); - // SubPartAware was implemented after 7.2.6, not sure in which release - // it will be included - if (popupElems.isEmpty()) { - throw new UnsupportedOperationException( - "Current version of vaadin doesn't support geting values from sliderElement"); - - } - WebElement popupElem = popupElems.get(0); - - if (BrowserType.IE.equals(getCapabilities().getBrowserName()) - && "8".equals(getCapabilities().getVersion())) { - return popupElem.getAttribute("innerText"); - } else { - return popupElem.getAttribute("textContent"); - } + WebElement popupElem = findElement(By.vaadin("#popup")); + return popupElem.getAttribute("textContent"); } diff --git a/testbench-api/src/main/java/com/vaadin/testbench/elements/TwinColSelectElement.java b/testbench-api/src/main/java/com/vaadin/testbench/elements/TwinColSelectElement.java index c68ade8ff4..7f3859c146 100644 --- a/testbench-api/src/main/java/com/vaadin/testbench/elements/TwinColSelectElement.java +++ b/testbench-api/src/main/java/com/vaadin/testbench/elements/TwinColSelectElement.java @@ -62,7 +62,17 @@ public class TwinColSelectElement extends AbstractSelectElement { } } + /** + * Deselects the option with the given option text, i.e. removes it from the + * right side column. + * + * @param text + * the text of the option to deselect + */ public void deselectByText(String text) { + if (isReadOnly()) { + throw new ReadOnlyException(); + } selectedOptions.deselectAll(); selectedOptions.selectByVisibleText(text); deselButton.click(); @@ -98,7 +108,18 @@ public class TwinColSelectElement extends AbstractSelectElement { return getOptionsFromSelect(options); } + /** + * Selects the option with the given option text, i.e. adds it to the right + * side column. + * + * @param text + * the text of the option to select + */ public void selectByText(String text) { + if (isReadOnly()) { + throw new ReadOnlyException(); + } + options.deselectAll(); options.selectByVisibleText(text); selButton.click(); @@ -113,7 +134,9 @@ public class TwinColSelectElement extends AbstractSelectElement { } /** - * Return first selected item (item in the right part of component) + * Return first selected item (item in the right part of component). + * + * @return the option text for the item */ public String getValue() { String value = ""; |