diff options
author | Mika Murtojarvi <mika@vaadin.com> | 2015-06-25 13:07:23 +0300 |
---|---|---|
committer | Vaadin Code Review <review@vaadin.com> | 2015-06-29 06:47:47 +0000 |
commit | dfce3a27fe3ca04db83cb537760354782c5b56c6 (patch) | |
tree | 3a0d13cd6db9db0e3e51ebae397cd13783743dfa /uitest/src | |
parent | b541e8e4e9346971f33025135619120166aac425 (diff) | |
download | vaadin-framework-dfce3a27fe3ca04db83cb537760354782c5b56c6.tar.gz vaadin-framework-dfce3a27fe3ca04db83cb537760354782c5b56c6.zip |
Change focused Grid cell when scrolling with the keyboard (#18356).
- The focused cell is now updated when scrolling with pageup/down, home
or end key.
- The scroll amount is slightly reduced to ensure that no cells are
skipped over with pgup/down scroll.
Change-Id: Id1ddd4f0f3f3b1315df3f8d9813080fbd5009bcd
Diffstat (limited to 'uitest/src')
-rw-r--r-- | uitest/src/com/vaadin/tests/components/grid/basicfeatures/server/GridKeyboardNavigationTest.java | 47 |
1 files changed, 29 insertions, 18 deletions
diff --git a/uitest/src/com/vaadin/tests/components/grid/basicfeatures/server/GridKeyboardNavigationTest.java b/uitest/src/com/vaadin/tests/components/grid/basicfeatures/server/GridKeyboardNavigationTest.java index 3f2e82793b..6724a7bb49 100644 --- a/uitest/src/com/vaadin/tests/components/grid/basicfeatures/server/GridKeyboardNavigationTest.java +++ b/uitest/src/com/vaadin/tests/components/grid/basicfeatures/server/GridKeyboardNavigationTest.java @@ -21,6 +21,7 @@ import static org.junit.Assert.assertTrue; import org.junit.Test; import org.openqa.selenium.By; import org.openqa.selenium.Keys; +import org.openqa.selenium.WebElement; import org.openqa.selenium.interactions.Actions; import com.vaadin.testbench.elements.GridElement; @@ -192,30 +193,40 @@ public class GridKeyboardNavigationTest extends GridBasicFeaturesTest { selectMenuPath("Component", "Size", "HeightMode Row"); - getGridElement().getCell(5, 2).click(); - + getGridElement().getCell(9, 2).click(); new Actions(getDriver()).sendKeys(Keys.PAGE_DOWN).perform(); - assertTrue("Row 20 did not become visible", - isElementPresent(By.xpath("//td[text() = '(20, 2)']"))); + assertTrue("Row 17 did not become visible", + isElementPresent(By.xpath("//td[text() = '(17, 2)']"))); new Actions(getDriver()).sendKeys(Keys.PAGE_DOWN).perform(); - assertTrue("Row 30 did not become visible", - isElementPresent(By.xpath("//td[text() = '(30, 2)']"))); - - assertTrue("Originally focused cell is no longer focused", - getGridElement().getCell(5, 2).isFocused()); - - getGridElement().getCell(50, 2).click(); + assertTrue("Row 25 did not become visible", + isElementPresent(By.xpath("//td[text() = '(25, 2)']"))); + checkFocusedCell(29, 2, 4); + getGridElement().getCell(41, 2).click(); new Actions(getDriver()).sendKeys(Keys.PAGE_UP).perform(); - assertTrue("Row 31 did not become visible", - isElementPresent(By.xpath("//td[text() = '(31, 2)']"))); + assertTrue("Row 33 did not become visible", + isElementPresent(By.xpath("//td[text() = '(33, 2)']"))); new Actions(getDriver()).sendKeys(Keys.PAGE_UP).perform(); - assertTrue("Row 21 did not become visible", - isElementPresent(By.xpath("//td[text() = '(21, 2)']"))); + assertTrue("Row 25 did not become visible", + isElementPresent(By.xpath("//td[text() = '(25, 2)']"))); + checkFocusedCell(21, 2, 4); + } - assertTrue("Originally focused cell is no longer focused", - getGridElement().getCell(50, 2).isFocused()); + private void checkFocusedCell(int row, int column, int rowTolerance) { + WebElement focusedCell = getGridElement().findElement( + By.className("v-grid-cell-focused")); + String cellContents = focusedCell.getText(); + String[] rowAndCol = cellContents.replaceAll("[()\\s]", "").split(","); + int focusedRow = Integer.parseInt(rowAndCol[0].trim()); + int focusedColumn = Integer.parseInt(rowAndCol[1].trim()); + // rowTolerance is the maximal allowed difference from the expected + // focused row. It is required because scrolling using page up/down + // may not move the position by exactly the visible height of the grid. + assertTrue("The wrong cell is focused. Expected (" + row + "," + column + + "), was " + cellContents, + column == focusedColumn + && Math.abs(row - focusedRow) <= rowTolerance); } -} +}
\ No newline at end of file |