From 16bc9321f18ff2b17aaaf8c0800d8abb8b2a8867 Mon Sep 17 00:00:00 2001 From: Christoph Weitkamp Date: Sat, 29 Jan 2022 14:01:16 +0100 Subject: [PATCH] Allow String values for other Types (#2699) Signed-off-by: Christoph Weitkamp --- .../internal/validation/TypeIntrospections.java | 13 ++++++++++++- .../validation/ConfigDescriptionValidatorTest.java | 12 ++++++++++++ 2 files changed, 24 insertions(+), 1 deletion(-) diff --git a/bundles/org.openhab.core.config.core/src/main/java/org/openhab/core/config/core/internal/validation/TypeIntrospections.java b/bundles/org.openhab.core.config.core/src/main/java/org/openhab/core/config/core/internal/validation/TypeIntrospections.java index 65b2d5159..3518b5621 100644 --- a/bundles/org.openhab.core.config.core/src/main/java/org/openhab/core/config/core/internal/validation/TypeIntrospections.java +++ b/bundles/org.openhab.core.config.core/src/main/java/org/openhab/core/config/core/internal/validation/TypeIntrospections.java @@ -123,7 +123,18 @@ final class TypeIntrospections { * @return true, if the given value can be assigned to the type of this introspection, otherwise false */ boolean isAssignable(Object value) { - return clazz.isAssignableFrom(value.getClass()); + return clazz.isAssignableFrom(value.getClass()) || isStringInstance(value); + } + + /** + * Returns true, if the given value is a string, otherwise false. + * + * @param value the value to be analyzed + * + * @return true, if the given value is a string, otherwise false + */ + final boolean isStringInstance(Object value) { + return value instanceof String; } /** diff --git a/bundles/org.openhab.core.config.core/src/test/java/org/openhab/core/config/core/internal/validation/ConfigDescriptionValidatorTest.java b/bundles/org.openhab.core.config.core/src/test/java/org/openhab/core/config/core/internal/validation/ConfigDescriptionValidatorTest.java index d3e0fcc63..7a412f2ef 100644 --- a/bundles/org.openhab.core.config.core/src/test/java/org/openhab/core/config/core/internal/validation/ConfigDescriptionValidatorTest.java +++ b/bundles/org.openhab.core.config.core/src/test/java/org/openhab/core/config/core/internal/validation/ConfigDescriptionValidatorTest.java @@ -44,6 +44,8 @@ import org.openhab.core.config.core.validation.ConfigValidationException; import org.openhab.core.config.core.validation.ConfigValidationMessage; import org.osgi.framework.Bundle; import org.osgi.framework.BundleContext; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; /** * Testing the {@link ConfigDescriptionValidator}. @@ -53,6 +55,8 @@ import org.osgi.framework.BundleContext; */ public class ConfigDescriptionValidatorTest { + private final Logger logger = LoggerFactory.getLogger(ConfigDescriptionValidatorTest.class); + private static final int MIN_VIOLATED = 1; private static final int MAX_VIOLATED = 1234; @@ -190,6 +194,14 @@ public class ConfigDescriptionValidatorTest { configDescriptionValidator.validate(params, CONFIG_DESCRIPTION_URI); } + @Test + public void assertValidationThrowsNoExceptionForValidStringConfigParameters() { + params.put(BOOL_PARAM_NAME, "true"); + params.put(INT_PARAM_NAME, "1"); + params.put(DECIMAL_PARAM_NAME, "1.0"); + configDescriptionValidator.validate(params, CONFIG_DESCRIPTION_URI); + } + // =========================================================================== // REQUIRED VALIDATIONS // ===========================================================================