summaryrefslogtreecommitdiffstats
path: root/testbench-api
diff options
context:
space:
mode:
Diffstat (limited to 'testbench-api')
-rw-r--r--testbench-api/src/main/java/com/vaadin/testbench/elements/TreeElement.java32
1 files changed, 24 insertions, 8 deletions
diff --git a/testbench-api/src/main/java/com/vaadin/testbench/elements/TreeElement.java b/testbench-api/src/main/java/com/vaadin/testbench/elements/TreeElement.java
index 80f90fd349..371cc8b31f 100644
--- a/testbench-api/src/main/java/com/vaadin/testbench/elements/TreeElement.java
+++ b/testbench-api/src/main/java/com/vaadin/testbench/elements/TreeElement.java
@@ -17,6 +17,7 @@ package com.vaadin.testbench.elements;
import java.util.Arrays;
import java.util.List;
+import java.util.stream.Collectors;
import org.openqa.selenium.By;
import org.openqa.selenium.NoSuchElementException;
@@ -109,25 +110,40 @@ public class TreeElement extends AbstractComponentElement {
}
/**
- * Gets all items currently shown in this tree.
+ * Gets all items currently shown in this tree. The returned element objects
+ * are the rendered contents for each item.
*
- * @return list of all items
+ * @return list of content elements for all items
*/
public List<TestBenchElement> getAllItems() {
- return TestBenchElement.wrapElements(
- asTreeGrid().getBody().findElements(By.tagName("tr")),
- getCommandExecutor());
+ return asTreeGrid().getBody().findElements(By.tagName("tr")).stream()
+ .map(this::findCellContentFromRow).collect(Collectors.toList());
}
/**
- * Gets an item at given index.
+ * Gets an item at given index. The returned element object is the rendered
+ * content in the given index.
*
* @param index
* 0-based row index
- * @return item at given index
+ * @return content element for item at given index
*/
public TestBenchElement getItem(int index) {
- return asTreeGrid().getCell(index, 0);
+ return findCellContentFromRow(asTreeGrid().getRow(index));
+ }
+
+ /**
+ * Finds the rendered cell content from given row element. This expects the
+ * row to contain only a single column rendered with TreeRenderer.
+ *
+ * @param rowElement
+ * the row element
+ * @return cell content element
+ */
+ protected TestBenchElement findCellContentFromRow(WebElement rowElement) {
+ return TestBenchElement.wrapElement(
+ rowElement.findElement(By.className("gwt-HTML")),
+ getCommandExecutor());
}
/**