diff options
author | Fabrice Bellingard <fabrice.bellingard@sonarsource.com> | 2012-09-07 10:21:17 +0200 |
---|---|---|
committer | Fabrice Bellingard <fabrice.bellingard@sonarsource.com> | 2012-09-07 10:21:17 +0200 |
commit | 9eb116afd392b896d1c68ddacb0330eeb207cfa1 (patch) | |
tree | afe53124be9e1d25e773954363c3ceb91bc6542a /src | |
parent | 84cf7f1fb4491a955dcd6b4e10a9510f06666db8 (diff) | |
download | sonar-scanner-cli-9eb116afd392b896d1c68ddacb0330eeb207cfa1.tar.gz sonar-scanner-cli-9eb116afd392b896d1c68ddacb0330eeb207cfa1.zip |
Allows to overwrite environment information on the Runner
Diffstat (limited to 'src')
-rw-r--r-- | src/main/java/org/sonar/runner/Runner.java | 22 | ||||
-rw-r--r-- | src/main/java/org/sonar/runner/model/Launcher.java | 5 | ||||
-rw-r--r-- | src/test/java/org/sonar/runner/RunnerTest.java | 16 |
3 files changed, 37 insertions, 6 deletions
diff --git a/src/main/java/org/sonar/runner/Runner.java b/src/main/java/org/sonar/runner/Runner.java index a24ae84..dc75115 100644 --- a/src/main/java/org/sonar/runner/Runner.java +++ b/src/main/java/org/sonar/runner/Runner.java @@ -37,7 +37,8 @@ import java.util.Properties; public final class Runner { public static final String PROPERTY_PROJECT_DIR = "sonar.runner.projectDir"; - public static final String PROPERTY_RUNNER_VERSION = "sonar.runner.version"; + public static final String PROPERTY_ENVIRONMENT_INFORMATION_KEY = "sonar.environment.information.key"; + public static final String PROPERTY_ENVIRONMENT_INFORMATION_VERSION = "sonar.environment.information.version"; /** * @deprecated Replaced by sonar.verbose since 1.2 @@ -67,6 +68,10 @@ public final class Runner { private Runner(Properties props) { this.properties = props; + // set the default values for the Sonar Runner - they can be overriden with #setEnvironmentInformation + this.properties.put(PROPERTY_ENVIRONMENT_INFORMATION_KEY, "Runner"); + this.properties.put(PROPERTY_ENVIRONMENT_INFORMATION_VERSION, SonarRunnerVersion.getVersion()); + // and init the directories initDirs(); } @@ -75,9 +80,7 @@ public final class Runner { } public void execute() { - String sonarRunnerVersion = SonarRunnerVersion.getVersion(); - properties.put(PROPERTY_RUNNER_VERSION, sonarRunnerVersion); - Bootstrapper bootstrapper = new Bootstrapper("SonarRunner/" + sonarRunnerVersion, getSonarServerURL(), getWorkDir()); + Bootstrapper bootstrapper = new Bootstrapper("SonarRunner/" + SonarRunnerVersion.getVersion(), getSonarServerURL(), getWorkDir()); checkSonarVersion(bootstrapper); delegateExecution(createClassLoader(bootstrapper)); } @@ -185,4 +188,15 @@ public final class Runner { Thread.currentThread().setContextClassLoader(oldContextClassLoader); } } + + /** + * Allows to overwrite the environment information when Sonar Runner is embedded in a specific tool (for instance, with the Sonar Ant Task). + * + * @param key the key of the tool that embeds Sonar Runner + * @param version the version of this tool + */ + public void setEnvironmentInformation(String key, String version) { + this.properties.put(PROPERTY_ENVIRONMENT_INFORMATION_KEY, key); + this.properties.put(PROPERTY_ENVIRONMENT_INFORMATION_VERSION, version); + } } diff --git a/src/main/java/org/sonar/runner/model/Launcher.java b/src/main/java/org/sonar/runner/model/Launcher.java index 24202a3..cfa14b3 100644 --- a/src/main/java/org/sonar/runner/model/Launcher.java +++ b/src/main/java/org/sonar/runner/model/Launcher.java @@ -68,8 +68,9 @@ public class Launcher { private void executeBatch(ProjectDefinition project, Configuration initialConfiguration) { ProjectReactor reactor = new ProjectReactor(project); - String runnerVersion = propertiesFromRunner.getProperty(Runner.PROPERTY_RUNNER_VERSION); - Batch batch = Batch.create(reactor, initialConfiguration, new EnvironmentInformation("Runner", runnerVersion)); + String envKey = propertiesFromRunner.getProperty(Runner.PROPERTY_ENVIRONMENT_INFORMATION_KEY); + String envVersion = propertiesFromRunner.getProperty(Runner.PROPERTY_ENVIRONMENT_INFORMATION_VERSION); + Batch batch = Batch.create(reactor, initialConfiguration, new EnvironmentInformation(envKey, envVersion)); batch.execute(); } diff --git a/src/test/java/org/sonar/runner/RunnerTest.java b/src/test/java/org/sonar/runner/RunnerTest.java index abcd46d..c5b1b7b 100644 --- a/src/test/java/org/sonar/runner/RunnerTest.java +++ b/src/test/java/org/sonar/runner/RunnerTest.java @@ -38,6 +38,22 @@ public class RunnerTest { public ExpectedException thrown = ExpectedException.none(); @Test + public void shouldHaveDefaultEnvironmentInformationValues() { + Runner runner = Runner.create(new Properties()); + assertThat(runner.getProperties().getProperty(Runner.PROPERTY_ENVIRONMENT_INFORMATION_KEY)).isEqualTo("Runner"); + assertThat(runner.getProperties().getProperty(Runner.PROPERTY_ENVIRONMENT_INFORMATION_VERSION)).contains("."); + assertThat(runner.getProperties().getProperty(Runner.PROPERTY_ENVIRONMENT_INFORMATION_VERSION)).doesNotContain("$"); + } + + @Test + public void shouldOverwriteDefaultEnvironmentInformationValues() { + Runner runner = Runner.create(new Properties()); + runner.setEnvironmentInformation("Ant", "1.2.3"); + assertThat(runner.getProperties().getProperty(Runner.PROPERTY_ENVIRONMENT_INFORMATION_KEY)).isEqualTo("Ant"); + assertThat(runner.getProperties().getProperty(Runner.PROPERTY_ENVIRONMENT_INFORMATION_VERSION)).isEqualTo("1.2.3"); + } + + @Test public void shouldCheckVersion() { assertThat(Runner.isUnsupportedVersion("1.0")).isTrue(); assertThat(Runner.isUnsupportedVersion("2.0")).isTrue(); |