diff options
-rw-r--r-- | server/src/main/java/com/vaadin/data/validator/NotEmptyValidator.java | 76 | ||||
-rw-r--r-- | server/src/test/java/com/vaadin/data/validator/NotEmptyValidatorTest.java | 54 | ||||
-rw-r--r-- | server/src/test/java/com/vaadin/data/validator/NotNullValidatorTest.java (renamed from server/src/test/java/com/vaadin/data/validator/NullValidatorTest.java) | 2 |
3 files changed, 131 insertions, 1 deletions
diff --git a/server/src/main/java/com/vaadin/data/validator/NotEmptyValidator.java b/server/src/main/java/com/vaadin/data/validator/NotEmptyValidator.java new file mode 100644 index 0000000000..ac827c45b6 --- /dev/null +++ b/server/src/main/java/com/vaadin/data/validator/NotEmptyValidator.java @@ -0,0 +1,76 @@ +/* + * 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.data.validator; + +import java.util.Objects; + +import com.vaadin.data.HasRequired; +import com.vaadin.data.Result; +import com.vaadin.data.Validator; + +/** + * Simple validator to check against {@code null} value and empty {@link String} + * value. + * <p> + * This validator works similar to {@link NotNullValidator} but in addition it + * also check whether the value is not an empty String. + * <p> + * The main purpose of this validator is its usage with {@link HasRequired} + * field instances. + * <p> + * If the field is required, it is visually indicated in the user interface. + * Furthermore, required fields requires "non-empty" validator. So in addition + * to call {@link HasRequired#setRequired(boolean)} method one should add an + * instance of this validator explicitly so the code looks like this: + * + * <pre> + * <code> + * Binder<Bean,String, String> binder = new Binder<>(); + * TextField name = new TextField(); + * name.setRequired(true); + * binder.forField(name).withValidator( + * new NonEmptyValidator("Name cannot be empty")) + * .bind(Bean::getName, Bean::setName); + * </code> + * </pre> + * + * @see HasRequired + * @author Vaadin Ltd + * @since 8.0 + * + */ +public class NotEmptyValidator<T> implements Validator<T> { + + private final String message; + + /** + * @param message + * error validation message + */ + public NotEmptyValidator(String message) { + this.message = message; + } + + @Override + public Result<T> apply(T value) { + if (Objects.isNull(value) || Objects.equals(value, "")) { + return Result.error(message); + } else { + return Result.ok(value); + } + } + +} diff --git a/server/src/test/java/com/vaadin/data/validator/NotEmptyValidatorTest.java b/server/src/test/java/com/vaadin/data/validator/NotEmptyValidatorTest.java new file mode 100644 index 0000000000..78101b898e --- /dev/null +++ b/server/src/test/java/com/vaadin/data/validator/NotEmptyValidatorTest.java @@ -0,0 +1,54 @@ +/* + * 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.data.validator; + +import org.junit.Assert; +import org.junit.Test; + +import com.vaadin.data.Result; + +/** + * @author Vaadin Ltd + * + */ +public class NotEmptyValidatorTest { + + @Test + public void nullValueIsDisallowed() { + NotEmptyValidator<String> validator = new NotEmptyValidator<>("foo"); + Result<String> result = validator.apply(null); + Assert.assertTrue(result.isError()); + Assert.assertEquals("foo", result.getMessage().get()); + } + + @Test + public void emptyValueIsDisallowed() { + NotEmptyValidator<String> validator = new NotEmptyValidator<>("foo"); + Result<String> result = validator.apply(""); + Assert.assertTrue(result.isError()); + Assert.assertEquals("foo", result.getMessage().get()); + } + + @Test + public void nonNullValueIsAllowed() { + NotEmptyValidator<Object> validator = new NotEmptyValidator<>("foo"); + Object value = new Object(); + Result<Object> result = validator.apply(value); + Assert.assertFalse(result.isError()); + result.ifOk(val -> Assert.assertEquals(value, val)); + result.ifError(msg -> Assert.fail()); + } +} diff --git a/server/src/test/java/com/vaadin/data/validator/NullValidatorTest.java b/server/src/test/java/com/vaadin/data/validator/NotNullValidatorTest.java index 26c510523c..8762e74fa3 100644 --- a/server/src/test/java/com/vaadin/data/validator/NullValidatorTest.java +++ b/server/src/test/java/com/vaadin/data/validator/NotNullValidatorTest.java @@ -20,7 +20,7 @@ import org.junit.Test; import com.vaadin.data.Result; -public class NullValidatorTest { +public class NotNullValidatorTest { @Test public void nullValueIsDisallowed() { |