aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArtur Signell <artur@vaadin.com>2012-03-30 18:39:21 +0300
committerArtur Signell <artur@vaadin.com>2012-03-30 18:39:21 +0300
commit7dc23cacce4c98c5c4a9fbf0b0044d7a312de3c3 (patch)
tree0128f964bb3ec60c8e0e49ac6e0d51be06cd614a
parentf38da072d3d3846b987da3160bb458eaa14747e0 (diff)
parenta6e0d4d7ea1e47a2ced9cb2278e2944e8bbcbe16 (diff)
downloadvaadin-framework-7dc23cacce4c98c5c4a9fbf0b0044d7a312de3c3.tar.gz
vaadin-framework-7dc23cacce4c98c5c4a9fbf0b0044d7a312de3c3.zip
Merge remote-tracking branch 'origin/6.8'
Conflicts: tests/test.xml
-rw-r--r--src/com/vaadin/terminal/gwt/client/ApplicationConnection.java13
-rw-r--r--tests/integration_tests.xml2
-rw-r--r--tests/test.xml2
-rw-r--r--tests/testbench/com/vaadin/tests/components/table/MultiClickingItemThatDetachesTable.java49
4 files changed, 63 insertions, 3 deletions
diff --git a/src/com/vaadin/terminal/gwt/client/ApplicationConnection.java b/src/com/vaadin/terminal/gwt/client/ApplicationConnection.java
index 2d198e8c52..31a1bf2954 100644
--- a/src/com/vaadin/terminal/gwt/client/ApplicationConnection.java
+++ b/src/com/vaadin/terminal/gwt/client/ApplicationConnection.java
@@ -745,6 +745,10 @@ public class ApplicationConnection {
}
protected void startRequest() {
+ if (hasActiveRequest) {
+ throw new IllegalStateException(
+ "Trying to start a new request while another is active");
+ }
hasActiveRequest = true;
requestStartTime = new Date();
// show initial throbber
@@ -769,11 +773,18 @@ public class ApplicationConnection {
}
protected void endRequest() {
+ if (!hasActiveRequest) {
+ throw new IllegalStateException("No active request");
+ }
+ // After checkForPendingVariableBursts() there may be a new active
+ // request, so we must set hasActiveRequest to false before, not after,
+ // the call. Active requests used to be tracked with an integer counter,
+ // so setting it after used to work but not with the #8505 changes.
+ hasActiveRequest = false;
if (applicationRunning) {
checkForPendingVariableBursts();
runPostRequestHooks(configuration.getRootPanelId());
}
- hasActiveRequest = false;
// deferring to avoid flickering
Scheduler.get().scheduleDeferred(new Command() {
public void execute() {
diff --git a/tests/integration_tests.xml b/tests/integration_tests.xml
index 3350a0d215..7bb179056a 100644
--- a/tests/integration_tests.xml
+++ b/tests/integration_tests.xml
@@ -13,7 +13,7 @@
<fail unless="test.integration.antfile" message="test.integration.antfile must be set for integration tests to run" />
<!-- Test with these browsers -->
- <property name="test_browsers" value="winxp-firefox10" />
+ <property name="test_browsers" value="winxp-firefox11" />
<!-- Path to key file. Default value -->
<property name="sshkey.file" value="id_dsa" />
diff --git a/tests/test.xml b/tests/test.xml
index dd308ce0a9..28459c37e9 100644
--- a/tests/test.xml
+++ b/tests/test.xml
@@ -11,7 +11,7 @@
<!-- Configuration -->
<!-- ================================================================== -->
<!-- Browsers to use for testing -->
- <property name="browsers-windows" value="winxp-ie8,win7-ie9,winxp-firefox10,winxp-safari5,winxp-googlechrome17,winxp-opera11" />
+ <property name="browsers-windows" value="winxp-ie8,win7-ie9,winxp-firefox11,winxp-safari5,winxp-googlechrome18,winxp-opera11" />
<property name="browsers-linux" value="linux-firefox3,linux-opera10,linux-googlechrome8" />
<property name="browsers-mac" value="osx-firefox3,osx-opera10,osx-googlechrome8,osx-safari4,osx-safari5" />
diff --git a/tests/testbench/com/vaadin/tests/components/table/MultiClickingItemThatDetachesTable.java b/tests/testbench/com/vaadin/tests/components/table/MultiClickingItemThatDetachesTable.java
new file mode 100644
index 0000000000..d437ab7a04
--- /dev/null
+++ b/tests/testbench/com/vaadin/tests/components/table/MultiClickingItemThatDetachesTable.java
@@ -0,0 +1,49 @@
+package com.vaadin.tests.components.table;
+
+import com.vaadin.data.Item;
+import com.vaadin.event.ItemClickEvent;
+import com.vaadin.event.ItemClickEvent.ItemClickListener;
+import com.vaadin.tests.components.TestBase;
+import com.vaadin.ui.Label;
+import com.vaadin.ui.Table;
+
+@SuppressWarnings("serial")
+public class MultiClickingItemThatDetachesTable extends TestBase {
+ @Override
+ public void setup() {
+ final Table table = new Table();
+ table.setImmediate(true);
+ table.addContainerProperty("p1", String.class, "p1");
+ table.addContainerProperty("p2", String.class, "p2");
+ for (int i = 0; i < 200; ++i) {
+ final Item item = table.getItem(table.addItem());
+ item.getItemProperty("p2").setValue(i + "");
+ item.getItemProperty("p1").setValue(i + "");
+ }
+ table.addListener(new ItemClickListener() {
+ public void itemClick(ItemClickEvent event) {
+ if (event.isDoubleClick()) {
+ try {
+ // Wait a bit so there's time to click multiple times
+ Thread.sleep(3000);
+ } catch (InterruptedException e) {
+ e.printStackTrace();
+ }
+ replaceComponent(table, new Label("Completed!"));
+ }
+ }
+ });
+ addComponent(table);
+ }
+
+ @Override
+ protected String getDescription() {
+ return "Clicking multiple times on an item whose listener detaches the table causes Out of Sync";
+ }
+
+ @Override
+ protected Integer getTicketNumber() {
+ return 8580;
+ }
+
+}