From 92ccddf4f2465dae1f43e6087ca25ae41cae637d Mon Sep 17 00:00:00 2001 From: Artur Signell Date: Mon, 27 Mar 2017 21:51:03 +0300 Subject: Make CustomField iterator() comply with contract Fixes #8957 --- .../src/main/java/com/vaadin/ui/CustomField.java | 32 ++++------- .../test/java/com/vaadin/ui/CustomFieldTest.java | 63 ++++++++++++++++++++++ 2 files changed, 72 insertions(+), 23 deletions(-) create mode 100644 server/src/test/java/com/vaadin/ui/CustomFieldTest.java (limited to 'server/src') diff --git a/server/src/main/java/com/vaadin/ui/CustomField.java b/server/src/main/java/com/vaadin/ui/CustomField.java index c8cfc2a25e..bd073598b4 100644 --- a/server/src/main/java/com/vaadin/ui/CustomField.java +++ b/server/src/main/java/com/vaadin/ui/CustomField.java @@ -16,7 +16,7 @@ package com.vaadin.ui; -import java.io.Serializable; +import java.util.Collections; import java.util.Iterator; import com.vaadin.data.HasValue; @@ -130,30 +130,16 @@ public abstract class CustomField extends AbstractField // ComponentContainer methods - private class ComponentIterator - implements Iterator, Serializable { - boolean first = (root != null); - - @Override - public boolean hasNext() { - return first; - } - - @Override - public Component next() { - first = false; - return getContent(); - } - - @Override - public void remove() { - throw new UnsupportedOperationException(); - } - } - @Override public Iterator iterator() { - return new ComponentIterator(); + // Can't use getContent() here as this will cause an infinite loop if + // initContent happens to all iterator(). This happens if you do + // setWidth... + if (root != null) { + return Collections.singletonList(root).iterator(); + } else { + return Collections. emptyList().iterator(); + } } /** diff --git a/server/src/test/java/com/vaadin/ui/CustomFieldTest.java b/server/src/test/java/com/vaadin/ui/CustomFieldTest.java new file mode 100644 index 0000000000..94636dcdc0 --- /dev/null +++ b/server/src/test/java/com/vaadin/ui/CustomFieldTest.java @@ -0,0 +1,63 @@ +/* + * Copyright 2000-2016 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.ui; + +import java.util.Iterator; +import java.util.NoSuchElementException; + +import org.junit.Assert; +import org.junit.Test; + +public class CustomFieldTest { + + public static class TestCustomField extends CustomField { + + private String value = "initial"; + private Button button; + + @Override + public String getValue() { + return value; + } + + @Override + protected Component initContent() { + button = new Button("Content"); + return button; + } + + @Override + protected void doSetValue(String value) { + this.value = value; + + } + + } + + @Test(expected = NoSuchElementException.class) + public void iterator() { + TestCustomField field = new TestCustomField(); + // Needs to trigger initContent somehow as + // iterator() can't do it even though it should... + field.getContent(); + Iterator iterator = field.iterator(); + Assert.assertNotNull(iterator); + Assert.assertTrue(iterator.hasNext()); + Assert.assertEquals(field.button, iterator.next()); + Assert.assertFalse(iterator.hasNext()); + iterator.next(); + } +} -- cgit v1.2.3