aboutsummaryrefslogtreecommitdiffstats
path: root/src/test
diff options
context:
space:
mode:
authorDuarte Meneses <duarte.meneses@sonarsource.com>2017-02-23 09:55:29 +0100
committerDuarte Meneses <duarte.meneses@sonarsource.com>2017-02-23 16:01:57 +0100
commitdf0aa9bad95dd1dc3181f5ab59bb9746123cd679 (patch)
treed55634390ed9117534377c35f1e7b73e4a4542d0 /src/test
parent4a2bdf64e5717608eb1a997e356932278896f051 (diff)
downloadsonar-scanner-cli-df0aa9bad95dd1dc3181f5ab59bb9746123cd679.tar.gz
sonar-scanner-cli-df0aa9bad95dd1dc3181f5ab59bb9746123cd679.zip
SQSCANNER-9 Allow to use variables in the configuration file
Diffstat (limited to 'src/test')
-rw-r--r--src/test/java/org/sonarsource/scanner/cli/MainTest.java2
-rw-r--r--src/test/java/org/sonarsource/scanner/cli/PropertyResolverTest.java123
2 files changed, 124 insertions, 1 deletions
diff --git a/src/test/java/org/sonarsource/scanner/cli/MainTest.java b/src/test/java/org/sonarsource/scanner/cli/MainTest.java
index 59606b2..59da205 100644
--- a/src/test/java/org/sonarsource/scanner/cli/MainTest.java
+++ b/src/test/java/org/sonarsource/scanner/cli/MainTest.java
@@ -64,7 +64,7 @@ public class MainTest {
when(runnerFactory.create(any(Properties.class))).thenReturn(runner);
when(conf.properties()).thenReturn(properties);
}
-
+
@Test
public void should_execute_runner() {
Main main = new Main(exit, cli, conf, runnerFactory, logs);
diff --git a/src/test/java/org/sonarsource/scanner/cli/PropertyResolverTest.java b/src/test/java/org/sonarsource/scanner/cli/PropertyResolverTest.java
new file mode 100644
index 0000000..659d4a8
--- /dev/null
+++ b/src/test/java/org/sonarsource/scanner/cli/PropertyResolverTest.java
@@ -0,0 +1,123 @@
+/*
+ * SonarQube Scanner
+ * Copyright (C) 2011-2017 SonarSource SA
+ * mailto:info AT sonarsource DOT com
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+package org.sonarsource.scanner.cli;
+
+import static org.fest.assertions.Assertions.assertThat;
+
+import java.util.HashMap;
+import java.util.Map;
+import java.util.Properties;
+
+import org.junit.Rule;
+import org.junit.Test;
+import org.junit.rules.ExpectedException;
+
+public class PropertyResolverTest {
+ @Rule
+ public ExpectedException exception = ExpectedException.none();
+
+ @Test
+ public void resolve_properties() {
+ Properties map = new Properties();
+ Map<String, String> env = new HashMap<>();
+
+ // resolve
+ map.put("A", "value a");
+ map.put("B", "value b");
+ map.put("C", "${A} ${B} ${nonexisting}");
+
+ PropertyResolver resolver = new PropertyResolver(map, env);
+ Properties resolved = resolver.resolve();
+ assertThat(resolved.get("A")).isEqualTo("value a");
+ assertThat(resolved.get("B")).isEqualTo("value b");
+ assertThat(resolved.get("C")).isEqualTo("value a value b ");
+
+ map.clear();
+ map.put("sonar.login", "admin");
+ map.put("sonar.password", "${sonar.login}");
+
+ resolver = new PropertyResolver(map, env);
+ resolved = resolver.resolve();
+ assertThat(resolved.get("sonar.password")).isEqualTo("admin");
+ }
+
+ @Test
+ public void use_env() {
+ Properties map = new Properties();
+ Map<String, String> env = new HashMap<>();
+
+ // resolve
+ map.put("A", "invalid");
+ map.put("B", "value b");
+ map.put("C", "${env.A} ${B} ${nonexisting}");
+ env.put("A", "value a");
+
+ PropertyResolver resolver = new PropertyResolver(map, env);
+ Properties resolved = resolver.resolve();
+ assertThat(resolved.get("A")).isEqualTo("invalid");
+ assertThat(resolved.get("B")).isEqualTo("value b");
+ assertThat(resolved.get("C")).isEqualTo("value a value b ");
+ }
+
+ @Test
+ public void resolve_recursively() {
+ Properties map = new Properties();
+ Map<String, String> env = new HashMap<>();
+ map.put("A", "value a");
+ map.put("B", "${A}");
+ map.put("C", "${A} ${B}");
+
+ PropertyResolver resolver = new PropertyResolver(map, env);
+ Properties resolved = resolver.resolve();
+ assertThat(resolved.get("A")).isEqualTo("value a");
+ assertThat(resolved.get("B")).isEqualTo("value a");
+ assertThat(resolved.get("C")).isEqualTo("value a value a");
+ }
+
+ @Test
+ public void dont_resolve_nested() {
+ Properties map = new Properties();
+ Map<String, String> env = new HashMap<>();
+ map.put("A", "value a");
+ map.put("B", "value b");
+ map.put("C", "${A ${B}}");
+
+ PropertyResolver resolver = new PropertyResolver(map, env);
+ Properties resolved = resolver.resolve();
+ assertThat(resolved.get("A")).isEqualTo("value a");
+ assertThat(resolved.get("B")).isEqualTo("value b");
+ assertThat(resolved.get("C")).isEqualTo("${A value b}");
+ }
+
+ @Test
+ public void fail_loop_properties_resolution() {
+ Properties map = new Properties();
+ Map<String, String> env = new HashMap<>();
+
+ // resolve
+ map.put("A", "${B}");
+ map.put("B", "${A}");
+
+ exception.expect(IllegalArgumentException.class);
+ exception.expectMessage("variable: B");
+ PropertyResolver resolver = new PropertyResolver(map, env);
+ resolver.resolve();
+ }
+}