diff options
Diffstat (limited to 'sonar-batch')
-rw-r--r-- | sonar-batch/src/main/java/org/sonar/batch/bootstrap/DryRunDatabase.java | 34 | ||||
-rw-r--r-- | sonar-batch/src/test/java/org/sonar/batch/bootstrap/DryRunDatabaseTest.java | 26 |
2 files changed, 31 insertions, 29 deletions
diff --git a/sonar-batch/src/main/java/org/sonar/batch/bootstrap/DryRunDatabase.java b/sonar-batch/src/main/java/org/sonar/batch/bootstrap/DryRunDatabase.java index 1f42d9e2375..0f73212e337 100644 --- a/sonar-batch/src/main/java/org/sonar/batch/bootstrap/DryRunDatabase.java +++ b/sonar-batch/src/main/java/org/sonar/batch/bootstrap/DryRunDatabase.java @@ -26,17 +26,13 @@ import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.sonar.api.BatchComponent; import org.sonar.api.CoreProperties; -import org.sonar.api.batch.bootstrap.ProjectReactor; import org.sonar.api.config.Settings; import org.sonar.api.database.DatabaseProperties; +import org.sonar.api.utils.HttpDownloader.HttpException; import org.sonar.api.utils.SonarException; -import javax.annotation.Nullable; - import java.io.File; -import static org.sonar.api.utils.HttpDownloader.HttpException; - /** * @since 3.4 */ @@ -52,17 +48,11 @@ public class DryRunDatabase implements BatchComponent { private final Settings settings; private final ServerClient server; private final TempDirectories tempDirectories; - private ProjectReactor reactor; - public DryRunDatabase(Settings settings, ServerClient server, TempDirectories tempDirectories, @Nullable ProjectReactor reactor) { + public DryRunDatabase(Settings settings, ServerClient server, TempDirectories tempDirectories) { this.settings = settings; this.server = server; this.tempDirectories = tempDirectories; - this.reactor = reactor; - } - - public DryRunDatabase(Settings settings, ServerClient server, TempDirectories tempDirectories) { - this(settings, server, tempDirectories, null); } public void start() { @@ -79,10 +69,14 @@ public class DryRunDatabase implements BatchComponent { private void downloadDatabase(File toFile) { String projectKey = null; try { - if (reactor == null) { + projectKey = settings.getString(CoreProperties.PROJECT_KEY_PROPERTY); + String branch = settings.getString(CoreProperties.PROJECT_BRANCH_PROPERTY); + if (StringUtils.isNotBlank(branch)) { + projectKey = String.format("%s:%s", projectKey, branch); + } + if (StringUtils.isBlank(projectKey)) { server.download("/batch_bootstrap/db", toFile); } else { - projectKey = StringUtils.defaultString(reactor.getRoot().getKey()); server.download("/batch_bootstrap/db?project=" + projectKey, toFile); } LOG.debug("Dry Run database size: {}", FileUtils.byteCountToDisplaySize(FileUtils.sizeOf(toFile))); @@ -97,11 +91,11 @@ public class DryRunDatabase implements BatchComponent { private void replaceSettings(String databasePath) { settings - .removeProperty("sonar.jdbc.schema") - .setProperty(DatabaseProperties.PROP_DIALECT, DIALECT) - .setProperty(DatabaseProperties.PROP_DRIVER, DRIVER) - .setProperty(DatabaseProperties.PROP_USER, USER) - .setProperty(DatabaseProperties.PROP_PASSWORD, PASSWORD) - .setProperty(DatabaseProperties.PROP_URL, URL + databasePath); + .removeProperty("sonar.jdbc.schema") + .setProperty(DatabaseProperties.PROP_DIALECT, DIALECT) + .setProperty(DatabaseProperties.PROP_DRIVER, DRIVER) + .setProperty(DatabaseProperties.PROP_USER, USER) + .setProperty(DatabaseProperties.PROP_PASSWORD, PASSWORD) + .setProperty(DatabaseProperties.PROP_URL, URL + databasePath); } } diff --git a/sonar-batch/src/test/java/org/sonar/batch/bootstrap/DryRunDatabaseTest.java b/sonar-batch/src/test/java/org/sonar/batch/bootstrap/DryRunDatabaseTest.java index 62135edc925..f19dbc663af 100644 --- a/sonar-batch/src/test/java/org/sonar/batch/bootstrap/DryRunDatabaseTest.java +++ b/sonar-batch/src/test/java/org/sonar/batch/bootstrap/DryRunDatabaseTest.java @@ -26,8 +26,6 @@ import org.junit.Test; import org.junit.rules.ExpectedException; import org.junit.rules.TemporaryFolder; import org.sonar.api.CoreProperties; -import org.sonar.api.batch.bootstrap.ProjectDefinition; -import org.sonar.api.batch.bootstrap.ProjectReactor; import org.sonar.api.config.Settings; import org.sonar.api.database.DatabaseProperties; import org.sonar.api.utils.HttpDownloader; @@ -43,10 +41,9 @@ import static org.mockito.Mockito.verifyZeroInteractions; import static org.mockito.Mockito.when; public class DryRunDatabaseTest { - Settings settings = new Settings(); + Settings settings; ServerClient server = mock(ServerClient.class); TempDirectories tempDirectories = mock(TempDirectories.class); - ProjectReactor projectReactor = new ProjectReactor(ProjectDefinition.create().setKey("group:project")); File databaseFile; @Rule @@ -59,27 +56,37 @@ public class DryRunDatabaseTest { public void setUp() throws Exception { databaseFile = temp.newFile("dryrun.h2.db"); when(tempDirectories.getFile("", "dryrun.h2.db")).thenReturn(databaseFile); + settings = new Settings(); settings.setProperty(CoreProperties.DRY_RUN, true); + settings.setProperty(CoreProperties.PROJECT_KEY_PROPERTY, "group:project"); } @Test public void should_be_disabled_if_not_dry_run() { settings.setProperty(CoreProperties.DRY_RUN, false); - new DryRunDatabase(settings, server, tempDirectories, projectReactor).start(); + new DryRunDatabase(settings, server, tempDirectories).start(); verifyZeroInteractions(tempDirectories, server); } @Test public void should_download_database() { - new DryRunDatabase(settings, server, tempDirectories, projectReactor).start(); + new DryRunDatabase(settings, server, tempDirectories).start(); verify(server).download("/batch_bootstrap/db?project=group:project", databaseFile); } @Test + public void should_download_database_on_branch() { + settings.setProperty(CoreProperties.PROJECT_BRANCH_PROPERTY, "mybranch"); + new DryRunDatabase(settings, server, tempDirectories).start(); + + verify(server).download("/batch_bootstrap/db?project=group:project:mybranch", databaseFile); + } + + @Test public void should_replace_database_settings() { - new DryRunDatabase(settings, server, tempDirectories, projectReactor).start(); + new DryRunDatabase(settings, server, tempDirectories).start(); assertThat(settings.getString(DatabaseProperties.PROP_DIALECT)).isEqualTo("h2"); assertThat(settings.getString(DatabaseProperties.PROP_DRIVER)).isEqualTo("org.h2.Driver"); @@ -95,7 +102,7 @@ public class DryRunDatabaseTest { thrown.expect(SonarException.class); thrown.expectMessage("You don't have access rights to project [group:project]"); - new DryRunDatabase(settings, server, tempDirectories, projectReactor).start(); + new DryRunDatabase(settings, server, tempDirectories).start(); } @Test @@ -105,12 +112,13 @@ public class DryRunDatabaseTest { thrown.expect(SonarException.class); thrown.expectMessage("BUG"); - new DryRunDatabase(settings, server, tempDirectories, projectReactor).start(); + new DryRunDatabase(settings, server, tempDirectories).start(); } @Test public void project_should_be_optional() { // on non-scan tasks + settings.removeProperty(CoreProperties.PROJECT_KEY_PROPERTY); new DryRunDatabase(settings, server, tempDirectories).start(); verify(server).download("/batch_bootstrap/db", databaseFile); } |