summaryrefslogtreecommitdiffstats
path: root/uitest/src/main
diff options
context:
space:
mode:
authorAnsku <Ansku@users.noreply.github.com>2017-10-10 18:45:44 +0300
committerHenri Sara <henri.sara@gmail.com>2017-10-10 18:45:44 +0300
commit4a04a3afae4ed691c3a1f2fe6e83b7f2badeae4d (patch)
tree67969ee86c5b6ed566e7f7818e595775fb759338 /uitest/src/main
parentfa62729e243df9cea8fd3c93cf10a96b7f9c713c (diff)
downloadvaadin-framework-4a04a3afae4ed691c3a1f2fe6e83b7f2badeae4d.tar.gz
vaadin-framework-4a04a3afae4ed691c3a1f2fe6e83b7f2badeae4d.zip
Prevent Grid refreshAll from getting stuck due mismatched state (#10161)
Fixes #10038
Diffstat (limited to 'uitest/src/main')
-rw-r--r--uitest/src/main/java/com/vaadin/tests/components/grid/GridDataProviderRefresh.java93
1 files changed, 93 insertions, 0 deletions
diff --git a/uitest/src/main/java/com/vaadin/tests/components/grid/GridDataProviderRefresh.java b/uitest/src/main/java/com/vaadin/tests/components/grid/GridDataProviderRefresh.java
new file mode 100644
index 0000000000..4dc17950c0
--- /dev/null
+++ b/uitest/src/main/java/com/vaadin/tests/components/grid/GridDataProviderRefresh.java
@@ -0,0 +1,93 @@
+/*
+ * Copyright 2000-2017 Vaadin Ltd.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License"); you may not
+ * use this file except in compliance with the License. You may obtain a copy of
+ * the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations under
+ * the License.
+ */
+package com.vaadin.tests.components.grid;
+
+import java.util.Arrays;
+import java.util.concurrent.atomic.AtomicReference;
+import java.util.stream.Stream;
+
+import com.vaadin.data.provider.AbstractBackEndDataProvider;
+import com.vaadin.data.provider.Query;
+import com.vaadin.server.VaadinRequest;
+import com.vaadin.ui.Button;
+import com.vaadin.ui.Grid;
+
+/**
+ * Tests that Grid refresh doesn't get stuck when filtering doesn't match row
+ * requests.
+ *
+ * @author Vaadin Ltd
+ */
+public class GridDataProviderRefresh extends SimpleGridUI {
+
+ private volatile Boolean filter = false;
+
+ private Stream<AtomicReference<String>> fetchValue(Boolean filter) {
+ if (filter) {
+ return Arrays
+ .asList("One", String.valueOf(System.currentTimeMillis()))
+ .stream().map(s -> new AtomicReference<>(s));
+ } else {
+ return Stream.empty();
+ }
+ }
+
+ @Override
+ protected void setup(VaadinRequest request) {
+ AbstractBackEndDataProvider<AtomicReference<String>, Object> dataProvider = new AbstractBackEndDataProvider<AtomicReference<String>, Object>() {
+ @Override
+ protected Stream<AtomicReference<String>> fetchFromBackEnd(
+ Query<AtomicReference<String>, Object> query) {
+ try {
+ Thread.sleep(250);
+ } catch (InterruptedException e) {
+ e.printStackTrace();
+ }
+ return fetchValue(filter);
+ }
+
+ @Override
+ protected int sizeInBackEnd(
+ Query<AtomicReference<String>, Object> query) {
+ return (int) fetchValue(filter).count();
+ }
+ };
+
+ Grid<AtomicReference<String>> grid = new Grid<>();
+ grid.setDataProvider(dataProvider);
+ grid.addColumn(AtomicReference::get);
+ addComponent(grid);
+
+ Button button = new Button("Refresh");
+ button.addClickListener(event1 -> {
+ filter = new Boolean(!filter);
+ dataProvider.refreshAll();
+ });
+ addComponent(button);
+ }
+
+ @Override
+ protected String getTestDescription() {
+ return "Grid refreshAll shouldn't get stuck when filtering doesn't match row requests "
+ + "(randomly triggered when button is clicked fast enough "
+ + "several times in a row, especially if using old and slow Windows)";
+ }
+
+ @Override
+ protected Integer getTicketNumber() {
+ return 10038;
+ }
+}