]> source.dussan.org Git - vaadin-framework.git/commitdiff
Update active tab index when overriding selection (#15274)
authorLeif Åstrand <leif@vaadin.com>
Fri, 22 May 2015 10:17:28 +0000 (13:17 +0300)
committerVaadin Code Review <review@vaadin.com>
Tue, 26 May 2015 10:46:50 +0000 (10:46 +0000)
Change-Id: I0480b640cec251bb430cdb9224e2a23ea26b7259

client/src/com/vaadin/client/ui/tabsheet/TabsheetConnector.java
uitest/src/com/vaadin/tests/components/tabsheet/VetoTabChange.java [new file with mode: 0644]
uitest/src/com/vaadin/tests/components/tabsheet/VetoTabChangeTest.java [new file with mode: 0644]

index 469fc6ba9571bc3f293d1f41a0ecb5080595c7f6..1b043c8a513d237b2309713b0305d663bb70f602 100644 (file)
@@ -42,6 +42,7 @@ public class TabsheetConnector extends TabsheetBaseConnector implements
                     final boolean selected = key.equals(getState().selected);
                     if (selected) {
                         getWidget().waitingForResponse = false;
+                        getWidget().setActiveTabIndex(i);
                         getWidget().selectTab(i);
                         break;
                     }
diff --git a/uitest/src/com/vaadin/tests/components/tabsheet/VetoTabChange.java b/uitest/src/com/vaadin/tests/components/tabsheet/VetoTabChange.java
new file mode 100644 (file)
index 0000000..6671b86
--- /dev/null
@@ -0,0 +1,50 @@
+/*
+ * 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.tabsheet;
+
+import com.vaadin.annotations.Theme;
+import com.vaadin.server.VaadinRequest;
+import com.vaadin.tests.components.AbstractTestUI;
+import com.vaadin.ui.Label;
+import com.vaadin.ui.TabSheet;
+import com.vaadin.ui.TabSheet.SelectedTabChangeEvent;
+import com.vaadin.ui.TabSheet.SelectedTabChangeListener;
+
+@Theme("valo")
+public class VetoTabChange extends AbstractTestUI {
+
+    @Override
+    protected void setup(VaadinRequest request) {
+        final TabSheet ts = new TabSheet();
+        ts.addSelectedTabChangeListener(new SelectedTabChangeListener() {
+            @Override
+            public void selectedTabChange(SelectedTabChangeEvent event) {
+                ts.setSelectedTab(0);
+            }
+        });
+
+        ts.addTab(new Label("Tab 1"), "Tab 1");
+        ts.addTab(new Label("Tab 2"), "Tab 2");
+
+        addComponent(ts);
+    }
+
+    @Override
+    public String getDescription() {
+        return "Tests the behavior when there's a listener that always changes back to the first tab.";
+    }
+
+}
diff --git a/uitest/src/com/vaadin/tests/components/tabsheet/VetoTabChangeTest.java b/uitest/src/com/vaadin/tests/components/tabsheet/VetoTabChangeTest.java
new file mode 100644 (file)
index 0000000..a30299f
--- /dev/null
@@ -0,0 +1,47 @@
+/*
+ * 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.tabsheet;
+
+import org.junit.Assert;
+import org.junit.Test;
+
+import com.vaadin.testbench.elements.LabelElement;
+import com.vaadin.testbench.elements.TabSheetElement;
+import com.vaadin.tests.tb3.SingleBrowserTest;
+
+public class VetoTabChangeTest extends SingleBrowserTest {
+    @Test
+    public void testReselectTabAfterVeto() {
+        openTestURL();
+
+        TabSheetElement tabSheet = $(TabSheetElement.class).first();
+        Assert.assertEquals("Tab 1 should be there by default", "Tab 1",
+                getTabContent(tabSheet));
+
+        tabSheet.openTab(1);
+
+        Assert.assertEquals("Tab should not have changed", "Tab 1",
+                getTabContent(tabSheet));
+
+        tabSheet.openTab(0);
+        Assert.assertEquals("Tab should still be there", "Tab 1",
+                getTabContent(tabSheet));
+    }
+
+    private String getTabContent(TabSheetElement tabSheet) {
+        return tabSheet.getContent(LabelElement.class).getText();
+    }
+}