diff options
author | Michal Duda <michal.duda@sonarsource.com> | 2020-04-08 19:38:02 +0200 |
---|---|---|
committer | sonartech <sonartech@sonarsource.com> | 2020-04-14 20:04:04 +0000 |
commit | d662d0c0269e1a12da0c3ecdb8f9d33b765ccdcc (patch) | |
tree | 7ec6d738cc8516bf42f42552a64f1cdbb0307a37 /sonar-plugin-api | |
parent | ab6328a769fbe531464fc9dd77cc64efc72ba390 (diff) | |
download | sonarqube-d662d0c0269e1a12da0c3ecdb8f9d33b765ccdcc.tar.gz sonarqube-d662d0c0269e1a12da0c3ecdb8f9d33b765ccdcc.zip |
SONAR-13272 fix issue with setting some properties through env variables
Diffstat (limited to 'sonar-plugin-api')
-rw-r--r-- | sonar-plugin-api/src/main/java/org/sonar/api/config/PropertyDefinitions.java | 25 | ||||
-rw-r--r-- | sonar-plugin-api/src/test/java/org/sonar/api/config/PropertyDefinitionsTest.java | 65 |
2 files changed, 70 insertions, 20 deletions
diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/config/PropertyDefinitions.java b/sonar-plugin-api/src/main/java/org/sonar/api/config/PropertyDefinitions.java index f76de7ebae3..2bc87e54510 100644 --- a/sonar-plugin-api/src/main/java/org/sonar/api/config/PropertyDefinitions.java +++ b/sonar-plugin-api/src/main/java/org/sonar/api/config/PropertyDefinitions.java @@ -23,19 +23,23 @@ import java.util.ArrayList; import java.util.Arrays; import java.util.Collection; import java.util.HashMap; +import java.util.Locale; import java.util.Map; +import java.util.Optional; import javax.annotation.CheckForNull; import javax.annotation.Nullable; import org.apache.commons.lang.StringUtils; import org.sonar.api.CoreProperties; import org.sonar.api.Properties; import org.sonar.api.Property; -import org.sonar.api.scanner.ScannerSide; import org.sonar.api.ce.ComputeEngineSide; +import org.sonar.api.scanner.ScannerSide; import org.sonar.api.server.ServerSide; import org.sonar.api.utils.AnnotationUtils; +import org.sonar.api.utils.System2; import static java.util.Objects.requireNonNull; +import static java.util.Optional.ofNullable; /** * Metadata of all the properties declared by plugins @@ -48,17 +52,22 @@ import static java.util.Objects.requireNonNull; public final class PropertyDefinitions { private final Map<String, PropertyDefinition> definitions = new HashMap<>(); + private final Map<String, String> propertyValueFromEnvironment = new HashMap<>(); private final Map<String, Category> categories = new HashMap<>(); private final Map<String, SubCategory> subcategories = new HashMap<>(); // deprecated key -> new key private final Map<String, String> deprecatedKeys = new HashMap<>(); - public PropertyDefinitions(Object... components) { + private final System2 system; + + public PropertyDefinitions(System2 system, Object... components) { + this.system = system; addComponents(Arrays.asList(components)); } - public PropertyDefinitions(Collection<PropertyDefinition> components) { + public PropertyDefinitions(System2 system, Collection<PropertyDefinition> components) { + this.system = system; addComponents(components); } @@ -108,6 +117,8 @@ public final class PropertyDefinitions { private PropertyDefinitions add(PropertyDefinition definition, String defaultCategory) { if (!definitions.containsKey(definition.key())) { definitions.put(definition.key(), definition); + String envVar = definition.key().toUpperCase(Locale.ENGLISH).replace('.', '_').replace('-', '_'); + ofNullable(system.envVariable(envVar)).ifPresent(value -> propertyValueFromEnvironment.put(definition.key(), value)); String category = StringUtils.defaultIfBlank(definition.category(), defaultCategory); categories.put(definition.key(), new Category(category)); String subcategory = StringUtils.defaultIfBlank(definition.subCategory(), category); @@ -124,6 +135,14 @@ public final class PropertyDefinitions { return definitions.get(validKey(key)); } + public Optional<String> getValueFromEnv(String key) { + return ofNullable(propertyValueFromEnvironment.get(key)); + } + + public Map<String, String> getAllPropertiesSetInEnv() { + return new HashMap<>(propertyValueFromEnvironment); + } + public Collection<PropertyDefinition> getAll() { return definitions.values(); } diff --git a/sonar-plugin-api/src/test/java/org/sonar/api/config/PropertyDefinitionsTest.java b/sonar-plugin-api/src/test/java/org/sonar/api/config/PropertyDefinitionsTest.java index d7555cc3701..fa915935f0f 100644 --- a/sonar-plugin-api/src/test/java/org/sonar/api/config/PropertyDefinitionsTest.java +++ b/sonar-plugin-api/src/test/java/org/sonar/api/config/PropertyDefinitionsTest.java @@ -19,6 +19,7 @@ */ package org.sonar.api.config; +import com.google.common.collect.ImmutableMap; import java.util.Arrays; import java.util.List; import java.util.Random; @@ -30,9 +31,12 @@ import org.junit.rules.ExpectedException; import org.sonar.api.Properties; import org.sonar.api.Property; import org.sonar.api.resources.Qualifiers; +import org.sonar.api.utils.System2; import static java.util.Collections.singletonList; import static org.assertj.core.api.Assertions.assertThat; +import static org.mockito.Mockito.mock; +import static org.mockito.Mockito.when; public class PropertyDefinitionsTest { @Rule @@ -44,14 +48,14 @@ public class PropertyDefinitionsTest { PropertyDefinition.builder("foo").name("Foo").build(), PropertyDefinition.builder("one").name("One").build(), PropertyDefinition.builder("two").name("Two").defaultValue("2").build()); - PropertyDefinitions def = new PropertyDefinitions(list); + PropertyDefinitions def = new PropertyDefinitions(System2.INSTANCE, list); assertProperties(def); } @Test public void should_inspect_plugin_objects() { - PropertyDefinitions def = new PropertyDefinitions( + PropertyDefinitions def = new PropertyDefinitions(System2.INSTANCE, PropertyDefinition.builder("foo").name("Foo").build(), PropertyDefinition.builder("one").name("One").build(), PropertyDefinition.builder("two").name("Two").defaultValue("2").build()); @@ -61,21 +65,21 @@ public class PropertyDefinitionsTest { @Test public void should_inspect_annotation_plugin_objects() { - PropertyDefinitions def = new PropertyDefinitions(new PluginWithProperty(), new PluginWithProperties()); + PropertyDefinitions def = new PropertyDefinitions(System2.INSTANCE, new PluginWithProperty(), new PluginWithProperties()); assertProperties(def); } @Test public void should_inspect_plugin_classes() { - PropertyDefinitions def = new PropertyDefinitions(PluginWithProperty.class, PluginWithProperties.class); + PropertyDefinitions def = new PropertyDefinitions(System2.INSTANCE, PluginWithProperty.class, PluginWithProperties.class); assertProperties(def); } @Test public void test_categories() { - PropertyDefinitions def = new PropertyDefinitions( + PropertyDefinitions def = new PropertyDefinitions(System2.INSTANCE, PropertyDefinition.builder("inCateg").name("In Categ").category("categ").build(), PropertyDefinition.builder("noCateg").name("No categ").build()); @@ -85,7 +89,7 @@ public class PropertyDefinitionsTest { @Test public void test_categories_on_annotation_plugin() { - PropertyDefinitions def = new PropertyDefinitions(Categories.class); + PropertyDefinitions def = new PropertyDefinitions(System2.INSTANCE, Categories.class); assertThat(def.getCategory("inCateg")).isEqualTo("categ"); assertThat(def.getCategory("noCateg")).isEqualTo(""); @@ -93,7 +97,7 @@ public class PropertyDefinitionsTest { @Test public void test_default_category() { - PropertyDefinitions def = new PropertyDefinitions(); + PropertyDefinitions def = new PropertyDefinitions(System2.INSTANCE); def.addComponent(PropertyDefinition.builder("inCateg").name("In Categ").category("categ").build(), "default"); def.addComponent(PropertyDefinition.builder("noCateg").name("No categ").build(), "default"); @@ -103,7 +107,7 @@ public class PropertyDefinitionsTest { @Test public void test_default_category_on_annotation_plugin() { - PropertyDefinitions def = new PropertyDefinitions(); + PropertyDefinitions def = new PropertyDefinitions(System2.INSTANCE); def.addComponent(Categories.class, "default"); assertThat(def.getCategory("inCateg")).isEqualTo("categ"); assertThat(def.getCategory("noCateg")).isEqualTo("default"); @@ -111,7 +115,7 @@ public class PropertyDefinitionsTest { @Test public void should_return_special_categories() { - PropertyDefinitions def = new PropertyDefinitions(); + PropertyDefinitions def = new PropertyDefinitions(System2.INSTANCE); assertThat(def.propertiesByCategory(null).get(new Category("general")).keySet()).containsOnly(new SubCategory("email")); assertThat(def.propertiesByCategory(null).get(new Category("general")).keySet().iterator().next().isSpecial()).isTrue(); @@ -123,7 +127,7 @@ public class PropertyDefinitionsTest { @Test public void should_group_by_category() { - PropertyDefinitions def = new PropertyDefinitions( + PropertyDefinitions def = new PropertyDefinitions(System2.INSTANCE, PropertyDefinition.builder("global1").name("Global1").category("catGlobal1").build(), PropertyDefinition.builder("global2").name("Global2").category("catGlobal1").build(), PropertyDefinition.builder("global3").name("Global3").category("catGlobal2").build(), @@ -142,7 +146,7 @@ public class PropertyDefinitionsTest { @Test public void should_group_by_subcategory() { - PropertyDefinitions def = new PropertyDefinitions( + PropertyDefinitions def = new PropertyDefinitions(System2.INSTANCE, PropertyDefinition.builder("global1").name("Global1").category("catGlobal1").subCategory("sub1").build(), PropertyDefinition.builder("global2").name("Global2").category("catGlobal1").subCategory("sub2").build(), PropertyDefinition.builder("global3").name("Global3").category("catGlobal1").build(), @@ -155,7 +159,7 @@ public class PropertyDefinitionsTest { @Test public void should_group_by_category_on_annotation_plugin() { - PropertyDefinitions def = new PropertyDefinitions(ByCategory.class); + PropertyDefinitions def = new PropertyDefinitions(System2.INSTANCE, ByCategory.class); assertThat(def.propertiesByCategory(null).keySet()).contains(new Category("catglobal1"), new Category("catglobal2")); assertThat(def.propertiesByCategory(Qualifiers.PROJECT).keySet()).containsOnly(new Category("catproject")); @@ -176,7 +180,7 @@ public class PropertyDefinitionsTest { @Test public void validKey_throws_NPE_if_key_is_null() { - PropertyDefinitions underTest = new PropertyDefinitions(); + PropertyDefinitions underTest = new PropertyDefinitions(System2.INSTANCE); expectedException.expect(NullPointerException.class); expectedException.expectMessage("key can't be null"); @@ -186,7 +190,7 @@ public class PropertyDefinitionsTest { @Test public void get_throws_NPE_if_key_is_null() { - PropertyDefinitions underTest = new PropertyDefinitions(); + PropertyDefinitions underTest = new PropertyDefinitions(System2.INSTANCE); expectedException.expect(NullPointerException.class); expectedException.expectMessage("key can't be null"); @@ -199,15 +203,15 @@ public class PropertyDefinitionsTest { Random random = new Random(); String key = RandomStringUtils.randomAlphanumeric(4); String deprecatedKey = RandomStringUtils.randomAlphanumeric(4); - PropertyDefinitions underTest = new PropertyDefinitions(singletonList( + PropertyDefinitions underTest = new PropertyDefinitions(System2.INSTANCE, singletonList( PropertyDefinition.builder(key) .deprecatedKey(deprecatedKey) .build())); String untrimmedKey = blank(random) + deprecatedKey + blank(random); assertThat(underTest.get(untrimmedKey).key()) - .describedAs("expecting key %s being returned for get(%s)", key, untrimmedKey) - .isEqualTo(key); + .describedAs("expecting key %s being returned for get(%s)", key, untrimmedKey) + .isEqualTo(key); } private static String blank(Random random) { @@ -216,6 +220,33 @@ public class PropertyDefinitionsTest { return b.toString(); } + @Test + public void get_value_from_env() { + System2 system = mock(System2.class); + when(system.envVariable("FOO")).thenReturn("777"); + when(system.envVariable("ONE")).thenReturn("888"); + when(system.envVariable("SOME_COMPLETELY_RANDOM_ENV_VAR")).thenReturn("999"); + + PropertyDefinitions underTest = new PropertyDefinitions(system, new PluginWithProperty(), new PluginWithProperties()); + + assertThat(underTest.getValueFromEnv("foo")).hasValue("777"); + assertThat(underTest.getValueFromEnv("one")).hasValue("888"); + assertThat(underTest.getValueFromEnv("two")).isEmpty(); + assertThat(underTest.getValueFromEnv("some.unrecognizable.prop")).isEmpty(); + } + + @Test + public void get_all_properties_set_in_env() { + System2 system = mock(System2.class); + when(system.envVariable("FOO")).thenReturn("777"); + when(system.envVariable("ONE")).thenReturn("888"); + when(system.envVariable("SOME_COMPLETELY_RANDOM_ENV_VAR")).thenReturn("999"); + + PropertyDefinitions underTest = new PropertyDefinitions(system, new PluginWithProperty(), new PluginWithProperties()); + + assertThat(underTest.getAllPropertiesSetInEnv()).containsExactlyInAnyOrderEntriesOf(ImmutableMap.of("foo", "777", "one", "888")); + } + @Property(key = "foo", name = "Foo") static final class PluginWithProperty { } |