summaryrefslogtreecommitdiffstats
path: root/uitest/src/com
diff options
context:
space:
mode:
authorArtur Signell <artur@vaadin.com>2015-09-30 17:05:24 +0300
committerTeemu Suo-Anttila <teemusa@vaadin.com>2015-10-19 11:17:29 +0000
commitada7b5c4c5ad4ac30a479287fc7dfdd1eaa71f72 (patch)
tree8575f672f25c929feba5fbf4464cfb06903efc5b /uitest/src/com
parent32894becb285c53a92227462101968ae5b85e694 (diff)
downloadvaadin-framework-ada7b5c4c5ad4ac30a479287fc7dfdd1eaa71f72.tar.gz
vaadin-framework-ada7b5c4c5ad4ac30a479287fc7dfdd1eaa71f72.zip
Properly cleanup stream variables if DragAndDropWrapper is detached (#14882)
If DragAndDropWrapper is removed from the UI for whatever reason before cleanup happens, the UI can no longer be found through it. If we do not do cleanup, we leave a reference hanging forever in ConnectorTracker. Change-Id: Ia445dafda7fdfaab9617bdfa9b48bfdbe5289241
Diffstat (limited to 'uitest/src/com')
-rw-r--r--uitest/src/com/vaadin/tests/components/draganddropwrapper/SingleUseDragAndDropUpload.java125
1 files changed, 125 insertions, 0 deletions
diff --git a/uitest/src/com/vaadin/tests/components/draganddropwrapper/SingleUseDragAndDropUpload.java b/uitest/src/com/vaadin/tests/components/draganddropwrapper/SingleUseDragAndDropUpload.java
new file mode 100644
index 0000000000..7c7e17a5a6
--- /dev/null
+++ b/uitest/src/com/vaadin/tests/components/draganddropwrapper/SingleUseDragAndDropUpload.java
@@ -0,0 +1,125 @@
+/*
+ * Copyright 2000-2014 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.draganddropwrapper;
+
+import java.io.OutputStream;
+
+import org.apache.commons.io.output.NullOutputStream;
+
+import com.vaadin.annotations.Theme;
+import com.vaadin.event.Transferable;
+import com.vaadin.event.dd.DragAndDropEvent;
+import com.vaadin.event.dd.DropHandler;
+import com.vaadin.event.dd.acceptcriteria.AcceptAll;
+import com.vaadin.event.dd.acceptcriteria.AcceptCriterion;
+import com.vaadin.server.FontAwesome;
+import com.vaadin.server.StreamVariable;
+import com.vaadin.server.VaadinRequest;
+import com.vaadin.shared.ui.label.ContentMode;
+import com.vaadin.tests.components.AbstractTestUIWithLog;
+import com.vaadin.ui.Button;
+import com.vaadin.ui.DragAndDropWrapper;
+import com.vaadin.ui.DragAndDropWrapper.WrapperTransferable;
+import com.vaadin.ui.Html5File;
+import com.vaadin.ui.Label;
+
+@Theme("valo")
+public class SingleUseDragAndDropUpload extends AbstractTestUIWithLog {
+
+ @Override
+ protected void setup(VaadinRequest request) {
+ Label upload = new Label(FontAwesome.UPLOAD.getHtml(), ContentMode.HTML);
+ upload.setSizeUndefined();
+ upload.setStyleName("upload");
+ getPage()
+ .getStyles()
+ .add(".upload{ font-size: 36px; border: 1px solid black; padding:15px;}");
+
+ final DragAndDropWrapper dnd = new DragAndDropWrapper(upload);
+ dnd.setSizeUndefined();
+ addComponent(dnd);
+ dnd.setDropHandler(new DropHandler() {
+
+ @Override
+ public AcceptCriterion getAcceptCriterion() {
+ return AcceptAll.get();
+ }
+
+ @Override
+ public void drop(DragAndDropEvent event) {
+ Transferable transferable = event.getTransferable();
+ log("Drop occured");
+ if (transferable instanceof WrapperTransferable) {
+ WrapperTransferable wTransferable = (WrapperTransferable) transferable;
+ Html5File[] files = wTransferable.getFiles();
+
+ if (files != null) {
+ for (Html5File file : files) {
+ log("Uploading file " + file.getFileName());
+ file.setStreamVariable(new StreamVariable() {
+
+ @Override
+ public void streamingStarted(
+ StreamingStartEvent event) {
+ log("Streaming started");
+ }
+
+ @Override
+ public void streamingFinished(
+ StreamingEndEvent event) {
+ log("Streaming finished");
+ removeComponent(dnd);
+ log("DragAndDropWrapper removed");
+ }
+
+ @Override
+ public void streamingFailed(
+ StreamingErrorEvent event) {
+ }
+
+ @Override
+ public void onProgress(
+ StreamingProgressEvent event) {
+ }
+
+ @Override
+ public boolean listenProgress() {
+ return false;
+ }
+
+ @Override
+ public boolean isInterrupted() {
+ return false;
+ }
+
+ @Override
+ public OutputStream getOutputStream() {
+ return new NullOutputStream();
+ }
+ });
+ }
+ }
+ }
+ }
+ });
+ addComponent(new Button("Poll for changes"));
+ }
+
+ @Override
+ protected String getTestDescription() {
+ return "Drag a file to the upload icon and ensure there is no exceptions logged in the console";
+ }
+}