aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/batch/ProjectAction.java14
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/batch/ProjectDataLoader.java104
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/batch/ProjectDataQuery.java11
-rw-r--r--server/sonar-server/src/test/java/org/sonar/server/batch/ProjectActionTest.java10
-rw-r--r--server/sonar-server/src/test/java/org/sonar/server/batch/ProjectDataLoaderTest.java272
5 files changed, 290 insertions, 121 deletions
diff --git a/server/sonar-server/src/main/java/org/sonar/server/batch/ProjectAction.java b/server/sonar-server/src/main/java/org/sonar/server/batch/ProjectAction.java
index 9e27f6e6854..939b9a46935 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/batch/ProjectAction.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/batch/ProjectAction.java
@@ -31,6 +31,7 @@ import org.sonarqube.ws.WsBatch.WsProjectResponse;
import org.sonarqube.ws.WsBatch.WsProjectResponse.FileData.Builder;
import static org.sonar.core.util.Protobuf.setNullable;
+import static org.sonar.server.ws.KeyExamples.KEY_BRANCH_EXAMPLE_001;
import static org.sonar.server.ws.KeyExamples.KEY_PROJECT_EXAMPLE_001;
import static org.sonar.server.ws.WsUtils.writeProtobuf;
@@ -39,6 +40,7 @@ public class ProjectAction implements BatchWsAction {
private static final String PARAM_KEY = "key";
private static final String PARAM_PROFILE = "profile";
private static final String PARAM_ISSUES_MODE = "issues_mode";
+ private static final String PARAM_BRANCH = "branch";
private final ProjectDataLoader projectDataLoader;
@@ -71,6 +73,12 @@ public class ProjectAction implements BatchWsAction {
.setDescription("Issues mode or not")
.setDefaultValue(false)
.setBooleanPossibleValues();
+
+ action
+ .createParam(PARAM_BRANCH)
+ .setSince("6.6")
+ .setDescription("Branch key")
+ .setExampleValue(KEY_BRANCH_EXAMPLE_001);
}
@Override
@@ -78,7 +86,8 @@ public class ProjectAction implements BatchWsAction {
ProjectRepositories data = projectDataLoader.load(ProjectDataQuery.create()
.setModuleKey(wsRequest.mandatoryParam(PARAM_KEY))
.setProfileName(wsRequest.param(PARAM_PROFILE))
- .setIssuesMode(wsRequest.mandatoryParamAsBoolean(PARAM_ISSUES_MODE)));
+ .setIssuesMode(wsRequest.mandatoryParamAsBoolean(PARAM_ISSUES_MODE))
+ .setBranch(wsRequest.param(PARAM_BRANCH)));
WsProjectResponse projectResponse = buildResponse(data);
writeProtobuf(projectResponse, wsRequest, wsResponse);
@@ -125,8 +134,7 @@ public class ProjectAction implements BatchWsAction {
for (Map.Entry<String, Map<String, String>> moduleSettingsEntry : data.settings().entrySet()) {
settingsByModuleResponse.put(
moduleSettingsEntry.getKey(),
- toSettingsResponse(moduleSettingsEntry.getValue())
- );
+ toSettingsResponse(moduleSettingsEntry.getValue()));
}
return settingsByModuleResponse;
diff --git a/server/sonar-server/src/main/java/org/sonar/server/batch/ProjectDataLoader.java b/server/sonar-server/src/main/java/org/sonar/server/batch/ProjectDataLoader.java
index f48bb14fc86..b67083fda64 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/batch/ProjectDataLoader.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/batch/ProjectDataLoader.java
@@ -20,15 +20,20 @@
package org.sonar.server.batch;
import com.google.common.collect.ArrayListMultimap;
+import com.google.common.collect.ImmutableList;
import com.google.common.collect.Maps;
import com.google.common.collect.Multimap;
import java.util.Collections;
import java.util.Date;
import java.util.List;
import java.util.Map;
+import java.util.Optional;
+import java.util.Set;
+import javax.annotation.Nullable;
import org.sonar.api.resources.Qualifiers;
import org.sonar.api.resources.Scopes;
import org.sonar.api.server.ServerSide;
+import org.sonar.core.util.stream.MoreCollectors;
import org.sonar.db.DbClient;
import org.sonar.db.DbSession;
import org.sonar.db.component.ComponentDto;
@@ -37,6 +42,7 @@ import org.sonar.db.permission.OrganizationPermission;
import org.sonar.db.property.PropertyDto;
import org.sonar.scanner.protocol.input.FileData;
import org.sonar.scanner.protocol.input.ProjectRepositories;
+import org.sonar.server.component.ComponentFinder;
import org.sonar.server.exceptions.ForbiddenException;
import org.sonar.server.user.UserSession;
@@ -44,7 +50,8 @@ import static com.google.common.collect.Lists.newArrayList;
import static com.google.common.collect.Maps.newHashMap;
import static org.sonar.api.web.UserRole.USER;
import static org.sonar.core.permission.GlobalPermissions.SCAN_EXECUTION;
-import static org.sonar.server.ws.WsUtils.checkFoundWithOptional;
+import static org.sonar.core.util.stream.MoreCollectors.index;
+import static org.sonar.core.util.stream.MoreCollectors.uniqueIndex;
import static org.sonar.server.ws.WsUtils.checkRequest;
@ServerSide
@@ -52,17 +59,18 @@ public class ProjectDataLoader {
private final DbClient dbClient;
private final UserSession userSession;
+ private final ComponentFinder componentFinder;
- public ProjectDataLoader(DbClient dbClient, UserSession userSession) {
+ public ProjectDataLoader(DbClient dbClient, UserSession userSession, ComponentFinder componentFinder) {
this.dbClient = dbClient;
this.userSession = userSession;
+ this.componentFinder = componentFinder;
}
public ProjectRepositories load(ProjectDataQuery query) {
try (DbSession session = dbClient.openSession(false)) {
ProjectRepositories data = new ProjectRepositories();
- ComponentDto module = checkFoundWithOptional(dbClient.componentDao().selectByKey(session, query.getModuleKey()),
- "Project or module with key '%s' is not found", query.getModuleKey());
+ ComponentDto module = componentFinder.getByKey(session, query.getModuleKey());
checkRequest(isProjectOrModule(module), "Key '%s' belongs to a component which is not a Project", query.getModuleKey());
boolean hasScanPerm = userSession.hasComponentPermission(SCAN_EXECUTION, module) ||
@@ -70,20 +78,26 @@ public class ProjectDataLoader {
boolean hasBrowsePerm = userSession.hasComponentPermission(USER, module);
checkPermission(query.isIssuesMode(), hasScanPerm, hasBrowsePerm);
- ComponentDto project = getProject(module, session);
- if (!project.getDbKey().equals(module.getDbKey())) {
- addSettings(data, module.getDbKey(), getSettingsFromParents(module, hasScanPerm, session));
+ ComponentDto moduleToUseForSettings = module;
+ ComponentDto moduleToUseForFileData = module;
+ String branch = query.getBranch();
+ if (branch != null) {
+ Optional<ComponentDto> branchDto = dbClient.componentDao().selectByKeyAndBranch(session, query.getModuleKey(), branch);
+ moduleToUseForSettings = branchDto.orElse(module);
+ moduleToUseForFileData = branchDto.orElse(null);
}
- List<ComponentDto> modulesTree = dbClient.componentDao().selectEnabledDescendantModules(session, module.uuid());
- Map<String, String> moduleUuidsByKey = moduleUuidsByKey(modulesTree);
- Map<String, Long> moduleIdsByKey = moduleIdsByKey(modulesTree);
+ ComponentDto project = getProject(moduleToUseForSettings, session);
+ if (!project.getKey().equals(moduleToUseForSettings.getKey())) {
+ addSettings(data, moduleToUseForSettings.getKey(), getSettingsFromParents(moduleToUseForSettings, hasScanPerm, session));
+ }
+ List<ComponentDto> modulesTree = dbClient.componentDao().selectEnabledDescendantModules(session, moduleToUseForSettings.uuid());
List<PropertyDto> modulesTreeSettings = dbClient.propertiesDao().selectEnabledDescendantModuleProperties(module.uuid(), session);
- TreeModuleSettings treeModuleSettings = new TreeModuleSettings(moduleUuidsByKey, moduleIdsByKey, modulesTree, modulesTreeSettings);
+ TreeModuleSettings treeModuleSettings = new TreeModuleSettings(session, modulesTree, modulesTreeSettings);
- addSettingsToChildrenModules(data, query.getModuleKey(), Maps.<String, String>newHashMap(), treeModuleSettings, hasScanPerm);
- List<FilePathWithHashDto> files = searchFilesWithHashAndRevision(session, module);
+ addSettingsToChildrenModules(data, query.getModuleKey(), Maps.newHashMap(), treeModuleSettings, hasScanPerm);
+ List<FilePathWithHashDto> files = searchFilesWithHashAndRevision(session, moduleToUseForFileData);
addFileData(data, modulesTree, files);
// FIXME need real value but actually only used to know if there is a previous analysis in local issue tracking mode so any value is
@@ -101,7 +115,10 @@ public class ProjectDataLoader {
return Qualifiers.PROJECT.equals(module.qualifier()) || Qualifiers.MODULE.equals(module.qualifier());
}
- private List<FilePathWithHashDto> searchFilesWithHashAndRevision(DbSession session, ComponentDto module) {
+ private List<FilePathWithHashDto> searchFilesWithHashAndRevision(DbSession session, @Nullable ComponentDto module) {
+ if (module == null) {
+ return Collections.emptyList();
+ }
return module.isRootProject() ? dbClient.componentDao().selectEnabledFilesFromProject(session, module.uuid())
: dbClient.componentDao().selectEnabledDescendantFiles(session, module.uuid());
}
@@ -121,7 +138,7 @@ public class ProjectDataLoader {
Map<String, String> parentProperties = newHashMap();
for (ComponentDto parent : parents) {
- parentProperties.putAll(getPropertiesMap(dbClient.propertiesDao().selectProjectProperties(session, parent.getDbKey()), hasScanPerm));
+ parentProperties.putAll(getPropertiesMap(dbClient.propertiesDao().selectProjectProperties(session, parent.getKey()), hasScanPerm));
}
return parentProperties;
}
@@ -145,8 +162,8 @@ public class ProjectDataLoader {
addSettings(ref, moduleKey, currentParentProperties);
for (ComponentDto childModule : treeModuleSettings.findChildrenModule(moduleKey)) {
- addSettings(ref, childModule.getDbKey(), currentParentProperties);
- addSettingsToChildrenModules(ref, childModule.getDbKey(), currentParentProperties, treeModuleSettings, hasScanPerm);
+ addSettings(ref, childModule.getKey(), currentParentProperties);
+ addSettingsToChildrenModules(ref, childModule.getKey(), currentParentProperties, treeModuleSettings, hasScanPerm);
}
}
@@ -175,7 +192,7 @@ public class ProjectDataLoader {
private static void addFileData(ProjectRepositories data, List<ComponentDto> moduleChildren, List<FilePathWithHashDto> files) {
Map<String, String> moduleKeysByUuid = newHashMap();
for (ComponentDto module : moduleChildren) {
- moduleKeysByUuid.put(module.uuid(), module.getDbKey());
+ moduleKeysByUuid.put(module.uuid(), module.getKey());
}
for (FilePathWithHashDto file : files) {
@@ -197,56 +214,29 @@ public class ProjectDataLoader {
}
}
- private static Map<String, String> moduleUuidsByKey(List<ComponentDto> moduleChildren) {
- Map<String, String> moduleUuidsByKey = newHashMap();
- for (ComponentDto componentDto : moduleChildren) {
- moduleUuidsByKey.put(componentDto.getDbKey(), componentDto.uuid());
- }
- return moduleUuidsByKey;
- }
+ private class TreeModuleSettings {
- private static Map<String, Long> moduleIdsByKey(List<ComponentDto> moduleChildren) {
- Map<String, Long> moduleIdsByKey = newHashMap();
- for (ComponentDto componentDto : moduleChildren) {
- moduleIdsByKey.put(componentDto.getDbKey(), componentDto.getId());
- }
- return moduleIdsByKey;
- }
-
- private static class TreeModuleSettings {
-
- private Map<String, Long> moduleIdsByKey;
- private Map<String, String> moduleUuidsByKey;
- private Multimap<Long, PropertyDto> propertiesByModuleId;
+ private Map<String, ComponentDto> modulesByKey;
+ private Multimap<String, PropertyDto> propertiesByModuleKey;
private Multimap<String, ComponentDto> moduleChildrenByModuleUuid;
- private TreeModuleSettings(Map<String, String> moduleUuidsByKey, Map<String, Long> moduleIdsByKey, List<ComponentDto> moduleChildren,
- List<PropertyDto> moduleChildrenSettings) {
- this.moduleIdsByKey = moduleIdsByKey;
- this.moduleUuidsByKey = moduleUuidsByKey;
- propertiesByModuleId = ArrayListMultimap.create();
+ private TreeModuleSettings(DbSession session, List<ComponentDto> moduleChildren, List<PropertyDto> moduleChildrenSettings) {
+ modulesByKey = moduleChildren.stream().collect(uniqueIndex(ComponentDto::getKey));
moduleChildrenByModuleUuid = ArrayListMultimap.create();
- for (PropertyDto settings : moduleChildrenSettings) {
- propertiesByModuleId.put(settings.getResourceId(), settings);
- }
-
- for (ComponentDto componentDto : moduleChildren) {
- String moduleUuid = componentDto.moduleUuid();
- if (moduleUuid != null) {
- moduleChildrenByModuleUuid.put(moduleUuid, componentDto);
- }
- }
+ Set<Long> propertiesByComponentId = moduleChildrenSettings.stream().map(PropertyDto::getResourceId).collect(MoreCollectors.toSet());
+ Map<Long, ComponentDto> componentsById = dbClient.componentDao().selectByIds(session, propertiesByComponentId).stream().collect(uniqueIndex(ComponentDto::getId));
+ propertiesByModuleKey = moduleChildrenSettings.stream().collect(index(s -> componentsById.get(s.getResourceId()).getKey()));
+ moduleChildrenByModuleUuid = moduleChildren.stream().filter(c -> c.moduleUuid() != null).collect(index(ComponentDto::moduleUuid));
}
List<PropertyDto> findModuleSettings(String moduleKey) {
- Long moduleId = moduleIdsByKey.get(moduleKey);
- return newArrayList(propertiesByModuleId.get(moduleId));
+ return ImmutableList.copyOf(propertiesByModuleKey.get(moduleKey));
}
List<ComponentDto> findChildrenModule(String moduleKey) {
- String moduleUuid = moduleUuidsByKey.get(moduleKey);
- return newArrayList(moduleChildrenByModuleUuid.get(moduleUuid));
+ String moduleUuid = modulesByKey.get(moduleKey).uuid();
+ return ImmutableList.copyOf(moduleChildrenByModuleUuid.get(moduleUuid));
}
}
}
diff --git a/server/sonar-server/src/main/java/org/sonar/server/batch/ProjectDataQuery.java b/server/sonar-server/src/main/java/org/sonar/server/batch/ProjectDataQuery.java
index 1581441b068..d25b02215f0 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/batch/ProjectDataQuery.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/batch/ProjectDataQuery.java
@@ -27,6 +27,7 @@ public class ProjectDataQuery {
private String projectOrModuleKey;
private String profileName;
private boolean issuesMode;
+ private String branch;
private ProjectDataQuery() {
// No direct call
@@ -60,6 +61,16 @@ public class ProjectDataQuery {
return this;
}
+ @CheckForNull
+ public String getBranch() {
+ return branch;
+ }
+
+ public ProjectDataQuery setBranch(@Nullable String branch) {
+ this.branch = branch;
+ return this;
+ }
+
public static ProjectDataQuery create() {
return new ProjectDataQuery();
}
diff --git a/server/sonar-server/src/test/java/org/sonar/server/batch/ProjectActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/batch/ProjectActionTest.java
index 685ecc062d0..b14f30b70a0 100644
--- a/server/sonar-server/src/test/java/org/sonar/server/batch/ProjectActionTest.java
+++ b/server/sonar-server/src/test/java/org/sonar/server/batch/ProjectActionTest.java
@@ -19,7 +19,6 @@
*/
package org.sonar.server.batch;
-import org.junit.Before;
import org.junit.Test;
import org.mockito.ArgumentCaptor;
import org.sonar.scanner.protocol.input.FileData;
@@ -37,12 +36,7 @@ import static org.sonar.test.JsonAssert.assertJson;
public class ProjectActionTest {
private ProjectDataLoader projectDataLoader = mock(ProjectDataLoader.class);
- private WsActionTester ws;
-
- @Before
- public void setUp() {
- ws = new WsActionTester(new ProjectAction(projectDataLoader));
- }
+ private WsActionTester ws = new WsActionTester(new ProjectAction(projectDataLoader));
@Test
public void project_referentials() throws Exception {
@@ -56,6 +50,7 @@ public class ProjectActionTest {
TestResponse response = ws.newRequest()
.setParam("key", projectKey)
+ .setParam("branch", "my_branch")
.setParam("profile", "Default")
.setParam("preview", "false")
.execute();
@@ -64,6 +59,7 @@ public class ProjectActionTest {
assertThat(queryArgumentCaptor.getValue().getModuleKey()).isEqualTo(projectKey);
assertThat(queryArgumentCaptor.getValue().getProfileName()).isEqualTo("Default");
assertThat(queryArgumentCaptor.getValue().isIssuesMode()).isFalse();
+ assertThat(queryArgumentCaptor.getValue().getBranch()).isEqualTo("my_branch");
}
/**
diff --git a/server/sonar-server/src/test/java/org/sonar/server/batch/ProjectDataLoaderTest.java b/server/sonar-server/src/test/java/org/sonar/server/batch/ProjectDataLoaderTest.java
index fef0b41434e..7383857a08c 100644
--- a/server/sonar-server/src/test/java/org/sonar/server/batch/ProjectDataLoaderTest.java
+++ b/server/sonar-server/src/test/java/org/sonar/server/batch/ProjectDataLoaderTest.java
@@ -45,8 +45,10 @@ import org.sonar.server.tester.UserSessionRule;
import static java.lang.String.format;
import static org.assertj.core.api.Assertions.assertThat;
+import static org.assertj.core.api.Assertions.entry;
import static org.junit.Assert.fail;
import static org.sonar.core.permission.GlobalPermissions.SCAN_EXECUTION;
+import static org.sonar.db.component.ComponentDto.generateBranchKey;
import static org.sonar.db.component.ComponentTesting.newFileDto;
import static org.sonar.db.component.ComponentTesting.newModuleDto;
import static org.sonar.db.permission.OrganizationPermission.SCAN;
@@ -77,9 +79,9 @@ public class ProjectDataLoaderTest {
dbSession, new PropertyDto().setKey("sonar.jira.login.secured").setValue("john").setResourceId(project.getId()));
dbSession.commit();
- ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getDbKey()));
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getKey()));
- Map<String, String> projectSettings = ref.settings(project.getDbKey());
+ Map<String, String> projectSettings = ref.settings(project.getKey());
assertThat(projectSettings).isEqualTo(ImmutableMap.of(
"sonar.jira.project.key", "SONAR",
"sonar.jira.login.secured", "john"));
@@ -98,16 +100,16 @@ public class ProjectDataLoaderTest {
dbSession, new PropertyDto().setKey("sonar.jira.login.secured").setValue("john").setResourceId(project.getId()));
dbSession.commit();
- ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getDbKey()));
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getKey()));
- Map<String, String> projectSettings = ref.settings(project.getDbKey());
+ Map<String, String> projectSettings = ref.settings(project.getKey());
assertThat(projectSettings).isEqualTo(ImmutableMap.of(
"sonar.jira.project.key", "SONAR",
"sonar.jira.login.secured", "john"));
}
@Test
- public void not_returned_secured_settings_when_lgged_but_no_scan_permission() {
+ public void not_returned_secured_settings_when_logged_but_no_scan_permission() {
OrganizationDto organizationDto = db.organizations().insert();
ComponentDto project = db.components().insertPrivateProject(organizationDto);
userSession.logIn("john").addProjectPermission(UserRole.USER, project);
@@ -119,8 +121,8 @@ public class ProjectDataLoaderTest {
dbSession, new PropertyDto().setKey("sonar.jira.login.secured").setValue("john").setResourceId(project.getId()));
dbSession.commit();
- ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getDbKey()).setIssuesMode(true));
- Map<String, String> projectSettings = ref.settings(project.getDbKey());
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getKey()).setIssuesMode(true));
+ Map<String, String> projectSettings = ref.settings(project.getKey());
assertThat(projectSettings).isEqualTo(ImmutableMap.of(
"sonar.jira.project.key", "SONAR"));
}
@@ -148,11 +150,11 @@ public class ProjectDataLoaderTest {
dbSession.commit();
- ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getDbKey()));
- assertThat(ref.settings(project.getDbKey())).isEqualTo(ImmutableMap.of(
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getKey()));
+ assertThat(ref.settings(project.getKey())).isEqualTo(ImmutableMap.of(
"sonar.jira.project.key", "SONAR",
"sonar.jira.login.secured", "john"));
- assertThat(ref.settings(module.getDbKey())).isEqualTo(ImmutableMap.of(
+ assertThat(ref.settings(module.getKey())).isEqualTo(ImmutableMap.of(
"sonar.jira.project.key", "SONAR-SERVER",
"sonar.jira.login.secured", "john",
"sonar.coverage.exclusions", "**/*.java"));
@@ -177,11 +179,11 @@ public class ProjectDataLoaderTest {
dbSession.commit();
- ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getDbKey()));
- assertThat(ref.settings(project.getDbKey())).isEqualTo(ImmutableMap.of(
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getKey()));
+ assertThat(ref.settings(project.getKey())).isEqualTo(ImmutableMap.of(
"sonar.jira.project.key", "SONAR",
"sonar.jira.login.secured", "john"));
- assertThat(ref.settings(module.getDbKey())).isEqualTo(ImmutableMap.of(
+ assertThat(ref.settings(module.getKey())).isEqualTo(ImmutableMap.of(
"sonar.jira.project.key", "SONAR",
"sonar.jira.login.secured", "john"));
}
@@ -216,15 +218,15 @@ public class ProjectDataLoaderTest {
dbSession.commit();
- ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getDbKey()));
- assertThat(ref.settings(project.getDbKey())).isEqualTo(ImmutableMap.of(
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getKey()));
+ assertThat(ref.settings(project.getKey())).isEqualTo(ImmutableMap.of(
"sonar.jira.project.key", "SONAR",
"sonar.jira.login.secured", "john"));
- assertThat(ref.settings(module.getDbKey())).isEqualTo(ImmutableMap.of(
+ assertThat(ref.settings(module.getKey())).isEqualTo(ImmutableMap.of(
"sonar.jira.project.key", "SONAR-SERVER",
"sonar.jira.login.secured", "john",
"sonar.coverage.exclusions", "**/*.java"));
- assertThat(ref.settings(subModule.getDbKey())).isEqualTo(ImmutableMap.of(
+ assertThat(ref.settings(subModule.getKey())).isEqualTo(ImmutableMap.of(
"sonar.jira.project.key", "SONAR-SERVER-DAO",
"sonar.jira.login.secured", "john",
"sonar.coverage.exclusions", "**/*.java"));
@@ -259,15 +261,15 @@ public class ProjectDataLoaderTest {
dbSession.commit();
- ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getDbKey()));
- assertThat(ref.settings(project.getDbKey())).isEqualTo(ImmutableMap.of(
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getKey()));
+ assertThat(ref.settings(project.getKey())).isEqualTo(ImmutableMap.of(
"sonar.jira.project.key", "SONAR",
"sonar.jira.login.secured", "john"));
- assertThat(ref.settings(module1.getDbKey())).isEqualTo(ImmutableMap.of(
+ assertThat(ref.settings(module1.getKey())).isEqualTo(ImmutableMap.of(
"sonar.jira.project.key", "SONAR-SERVER",
"sonar.jira.login.secured", "john",
"sonar.coverage.exclusions", "**/*.java"));
- assertThat(ref.settings(module2.getDbKey())).isEqualTo(ImmutableMap.of(
+ assertThat(ref.settings(module2.getKey())).isEqualTo(ImmutableMap.of(
"sonar.jira.project.key", "SONAR-APPLICATION",
"sonar.jira.login.secured", "john"));
}
@@ -284,8 +286,8 @@ public class ProjectDataLoaderTest {
dbSession.commit();
- ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getDbKey()));
- assertThat(ref.settings(project.getDbKey())).isEqualTo(ImmutableMap.of(
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getKey()));
+ assertThat(ref.settings(project.getKey())).isEqualTo(ImmutableMap.of(
"sonar.jira.project.key", "SONAR",
"sonar.jira.login.secured", "john"));
}
@@ -308,10 +310,10 @@ public class ProjectDataLoaderTest {
dbSession.commit();
- ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(subModule.getDbKey()));
- assertThat(ref.settings(project.getDbKey())).isEmpty();
- assertThat(ref.settings(module.getDbKey())).isEmpty();
- assertThat(ref.settings(subModule.getDbKey())).isEqualTo(ImmutableMap.of(
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(subModule.getKey()));
+ assertThat(ref.settings(project.getKey())).isEmpty();
+ assertThat(ref.settings(module.getKey())).isEmpty();
+ assertThat(ref.settings(subModule.getKey())).isEqualTo(ImmutableMap.of(
"sonar.jira.project.key", "SONAR",
"sonar.jira.login.secured", "john",
"sonar.coverage.exclusions", "**/*.java"));
@@ -341,10 +343,10 @@ public class ProjectDataLoaderTest {
dbSession.commit();
- ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(subModule.getDbKey()));
- assertThat(ref.settings(project.getDbKey())).isEmpty();
- assertThat(ref.settings(module.getDbKey())).isEmpty();
- assertThat(ref.settings(subModule.getDbKey())).isEqualTo(ImmutableMap.of(
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(subModule.getKey()));
+ assertThat(ref.settings(project.getKey())).isEmpty();
+ assertThat(ref.settings(module.getKey())).isEmpty();
+ assertThat(ref.settings(subModule.getKey())).isEqualTo(ImmutableMap.of(
"sonar.jira.project.key", "SONAR",
"sonar.jira.login.secured", "john",
"sonar.coverage.exclusions", "**/*.java"));
@@ -372,10 +374,10 @@ public class ProjectDataLoaderTest {
dbSession.commit();
- ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(subModule.getDbKey()));
- assertThat(ref.settings(project.getDbKey())).isEmpty();
- assertThat(ref.settings(module.getDbKey())).isEmpty();
- assertThat(ref.settings(subModule.getDbKey())).isEqualTo(ImmutableMap.of(
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(subModule.getKey()));
+ assertThat(ref.settings(project.getKey())).isEmpty();
+ assertThat(ref.settings(module.getKey())).isEmpty();
+ assertThat(ref.settings(subModule.getKey())).isEqualTo(ImmutableMap.of(
"sonar.jira.project.key", "SONAR",
"sonar.jira.login.secured", "john",
"sonar.coverage.exclusions", "**/*.java"));
@@ -404,16 +406,138 @@ public class ProjectDataLoaderTest {
dbSession.commit();
- ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(subModule.getDbKey()));
- assertThat(ref.settings(project.getDbKey())).isEmpty();
- assertThat(ref.settings(module.getDbKey())).isEmpty();
- assertThat(ref.settings(subModule.getDbKey())).isEqualTo(ImmutableMap.of(
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(subModule.getKey()));
+ assertThat(ref.settings(project.getKey())).isEmpty();
+ assertThat(ref.settings(module.getKey())).isEmpty();
+ assertThat(ref.settings(subModule.getKey())).isEqualTo(ImmutableMap.of(
"sonar.jira.project.key", "SONAR-SERVER",
"sonar.jira.login.secured", "john",
"sonar.coverage.exclusions", "**/*.java"));
}
@Test
+ public void return_project_settings_from_project_when_using_branch_parameter() {
+ OrganizationDto organizationDto = db.organizations().insert();
+ ComponentDto project = db.components().insertPrivateProject(organizationDto);
+ userSession.logIn().addProjectPermission(SCAN_EXECUTION, project);
+ db.properties().insertProperties(new PropertyDto().setKey("sonar.jira.project.key").setValue("SONAR").setResourceId(project.getId()));
+ ComponentDto branch = db.components().insertProjectBranch(project, b -> b.setKey("my_branch"));
+
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create()
+ .setModuleKey(project.getKey())
+ .setBranch("my_branch"));
+
+ assertThat(project.getKey()).isEqualTo(branch.getKey());
+ assertThat(ref.settings(project.getKey())).containsExactly(entry("sonar.jira.project.key", "SONAR"));
+ }
+
+ @Test
+ public void return_project_with_module_settings_when_using_branch_parameter() {
+ OrganizationDto organizationDto = db.organizations().insert();
+ ComponentDto project = db.components().insertPrivateProject(organizationDto);
+ userSession.logIn().addProjectPermission(SCAN_EXECUTION, project);
+ ComponentDto module = db.components().insertComponent(newModuleDto(project));
+ ComponentDto branch = db.components().insertProjectBranch(project, b -> b.setKey("my_branch"));
+ ComponentDto moduleBranch = db.components().insertComponent(newModuleDto(branch).setDbKey(generateBranchKey(module.getKey(), "my_branch")));
+ // Project properties
+ db.properties().insertProperties(
+ new PropertyDto().setKey("sonar.jira.project.key").setValue("SONAR").setResourceId(project.getId()),
+ new PropertyDto().setKey("sonar.jira.login.secured").setValue("john").setResourceId(project.getId()));
+ // Module properties
+ db.properties().insertProperties(
+ new PropertyDto().setKey("sonar.jira.project.key").setValue("SONAR-SERVER").setResourceId(module.getId()),
+ new PropertyDto().setKey("sonar.coverage.exclusions").setValue("**/*.java").setResourceId(module.getId()));
+
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create()
+ .setModuleKey(project.getKey())
+ .setBranch("my_branch"));
+
+ assertThat(ref.settings(branch.getKey())).containsOnly(
+ entry("sonar.jira.project.key", "SONAR"),
+ entry("sonar.jira.login.secured", "john"));
+ assertThat(ref.settings(moduleBranch.getKey())).containsOnly(
+ entry("sonar.jira.project.key", "SONAR-SERVER"),
+ entry("sonar.jira.login.secured", "john"),
+ entry("sonar.coverage.exclusions", "**/*.java"));
+ }
+
+ @Test
+ public void return_settings_from_project_when_module_is_only_in_branch() {
+ OrganizationDto organizationDto = db.organizations().insert();
+ ComponentDto project = db.components().insertPrivateProject(organizationDto);
+ userSession.logIn().addProjectPermission(SCAN_EXECUTION, project);
+ ComponentDto branch = db.components().insertProjectBranch(project, b -> b.setKey("my_branch"));
+ // This module does not exist on master
+ ComponentDto moduleBranch = db.components().insertComponent(newModuleDto(branch));
+ db.properties().insertProperties(
+ new PropertyDto().setKey("sonar.jira.project.key").setValue("SONAR").setResourceId(project.getId()),
+ new PropertyDto().setKey("sonar.jira.login.secured").setValue("john").setResourceId(project.getId()));
+
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create()
+ .setModuleKey(project.getKey())
+ .setBranch("my_branch"));
+
+ assertThat(ref.settings(moduleBranch.getKey())).containsOnly(
+ entry("sonar.jira.project.key", "SONAR"),
+ entry("sonar.jira.login.secured", "john"));
+ }
+
+ @Test
+ public void return_sub_module_settings_when_using_branch_parameter() {
+ OrganizationDto organizationDto = db.organizations().insert();
+ ComponentDto project = db.components().insertPrivateProject(organizationDto);
+ ComponentDto module = db.components().insertComponent(newModuleDto(project));
+ ComponentDto subModule = db.components().insertComponent(newModuleDto(module));
+ userSession.logIn().addProjectPermission(SCAN_EXECUTION, project);
+ ComponentDto branch = db.components().insertProjectBranch(project, b -> b.setKey("my_branch"));
+ ComponentDto moduleBranch = db.components().insertComponent(newModuleDto(branch).setDbKey(generateBranchKey(module.getKey(), "my_branch")));
+ ComponentDto subModuleBranch = db.components().insertComponent(newModuleDto(moduleBranch).setDbKey(generateBranchKey(subModule.getKey(), "my_branch")));
+ // Sub module properties
+ dbClient.propertiesDao().saveProperty(dbSession, new PropertyDto().setKey("sonar.jira.project.key").setValue("SONAR").setResourceId(subModule.getId()));
+ dbClient.propertiesDao().saveProperty(dbSession, new PropertyDto().setKey("sonar.jira.login.secured").setValue("john").setResourceId(subModule.getId()));
+ dbClient.propertiesDao()
+ .saveProperty(dbSession, new PropertyDto().setKey("sonar.coverage.exclusions").setValue("**/*.java").setResourceId(subModule.getId()));
+ dbSession.commit();
+
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(subModuleBranch.getKey()));
+
+ assertThat(ref.settings(branch.getKey())).isEmpty();
+ assertThat(ref.settings(moduleBranch.getKey())).isEmpty();
+ assertThat(ref.settings(subModuleBranch.getKey())).containsOnly(
+ entry("sonar.jira.project.key", "SONAR"),
+ entry("sonar.jira.login.secured", "john"),
+ entry("sonar.coverage.exclusions", "**/*.java"));
+ }
+
+ @Test
+ public void return_settings_from_project_when_branch_does_not_exist() {
+ OrganizationDto organizationDto = db.organizations().insert();
+ ComponentDto project = db.components().insertPrivateProject(organizationDto);
+ userSession.logIn().addProjectPermission(SCAN_EXECUTION, project);
+ ComponentDto module = db.components().insertComponent(newModuleDto(project));
+ // Project properties
+ db.properties().insertProperties(
+ new PropertyDto().setKey("sonar.jira.project.key").setValue("SONAR").setResourceId(project.getId()),
+ new PropertyDto().setKey("sonar.jira.login.secured").setValue("john").setResourceId(project.getId()));
+ // Module properties
+ db.properties().insertProperties(
+ new PropertyDto().setKey("sonar.jira.project.key").setValue("SONAR-SERVER").setResourceId(module.getId()),
+ new PropertyDto().setKey("sonar.coverage.exclusions").setValue("**/*.java").setResourceId(module.getId()));
+
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create()
+ .setModuleKey(project.getKey())
+ .setBranch("my_branch"));
+
+ assertThat(ref.settings(project.getKey())).containsOnly(
+ entry("sonar.jira.project.key", "SONAR"),
+ entry("sonar.jira.login.secured", "john"));
+ assertThat(ref.settings(module.getKey())).containsOnly(
+ entry("sonar.jira.project.key", "SONAR-SERVER"),
+ entry("sonar.jira.login.secured", "john"),
+ entry("sonar.coverage.exclusions", "**/*.java"));
+ }
+
+ @Test
public void return_file_data_from_single_project() {
OrganizationDto organizationDto = db.organizations().insert();
ComponentDto project = db.components().insertPrivateProject(organizationDto);
@@ -422,10 +546,10 @@ public class ProjectDataLoaderTest {
dbClient.fileSourceDao().insert(dbSession, newFileSourceDto(file).setSrcHash("123456"));
db.commit();
- ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getDbKey()));
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getKey()));
- assertThat(ref.fileDataByPath(project.getDbKey())).hasSize(1);
- FileData fileData = ref.fileData(project.getDbKey(), file.path());
+ assertThat(ref.fileDataByPath(project.getKey())).hasSize(1);
+ FileData fileData = ref.fileData(project.getKey(), file.path());
assertThat(fileData.hash()).isEqualTo("123456");
}
@@ -443,10 +567,10 @@ public class ProjectDataLoaderTest {
dbClient.fileSourceDao().insert(dbSession, newFileSourceDto(moduleFile).setSrcHash("789456"));
dbSession.commit();
- ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getDbKey()));
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(project.getKey()));
- assertThat(ref.fileData(project.getDbKey(), projectFile.path()).hash()).isEqualTo("123456");
- assertThat(ref.fileData(module.getDbKey(), moduleFile.path()).hash()).isEqualTo("789456");
+ assertThat(ref.fileData(project.getKey(), projectFile.path()).hash()).isEqualTo("123456");
+ assertThat(ref.fileData(module.getKey(), moduleFile.path()).hash()).isEqualTo("789456");
}
@Test
@@ -463,11 +587,51 @@ public class ProjectDataLoaderTest {
dbClient.fileSourceDao().insert(dbSession, newFileSourceDto(moduleFile).setSrcHash("789456"));
dbSession.commit();
- ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(module.getDbKey()));
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create().setModuleKey(module.getKey()));
+
+ assertThat(ref.fileData(module.getKey(), moduleFile.path()).hash()).isEqualTo("789456");
+ assertThat(ref.fileData(module.getKey(), moduleFile.path()).revision()).isEqualTo("123456789");
+ assertThat(ref.fileData(project.getKey(), projectFile.path())).isNull();
+ }
+
+ @Test
+ public void return_file_data_from_branch() {
+ OrganizationDto organizationDto = db.organizations().insert();
+ ComponentDto project = db.components().insertPrivateProject(organizationDto);
+ ComponentDto branch = db.components().insertProjectBranch(project, b -> b.setKey("my_branch"));
+ userSession.logIn().addProjectPermission(SCAN_EXECUTION, project);
+ ComponentDto moduleBranch = db.components().insertComponent(newModuleDto(branch));
+ // File on branch
+ ComponentDto projectFile = db.components().insertComponent(newFileDto(branch));
+ dbClient.fileSourceDao().insert(dbSession, newFileSourceDto(projectFile).setSrcHash("123456"));
+ // File on moduleBranch branch
+ ComponentDto moduleFile = db.components().insertComponent(newFileDto(moduleBranch));
+ dbClient.fileSourceDao().insert(dbSession, newFileSourceDto(moduleFile).setSrcHash("789456"));
+ dbSession.commit();
+
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create()
+ .setModuleKey(project.getKey())
+ .setBranch("my_branch"));
+
+ assertThat(ref.fileData(branch.getKey(), projectFile.path()).hash()).isEqualTo("123456");
+ assertThat(ref.fileData(moduleBranch.getKey(), moduleFile.path()).hash()).isEqualTo("789456");
+ }
+
+ @Test
+ public void return_no_file_data_when_branch_does_not_exist() {
+ OrganizationDto organizationDto = db.organizations().insert();
+ ComponentDto project = db.components().insertPrivateProject(organizationDto);
+ ComponentDto branch = db.components().insertProjectBranch(project, b -> b.setKey("my_branch"));
+ userSession.logIn().addProjectPermission(SCAN_EXECUTION, project);
+ ComponentDto projectFile = db.components().insertComponent(newFileDto(branch));
+ dbClient.fileSourceDao().insert(dbSession, newFileSourceDto(projectFile).setSrcHash("123456"));
+ dbSession.commit();
+
+ ProjectRepositories ref = underTest.load(ProjectDataQuery.create()
+ .setModuleKey(project.getKey())
+ .setBranch("new_branch"));
- assertThat(ref.fileData(module.getDbKey(), moduleFile.path()).hash()).isEqualTo("789456");
- assertThat(ref.fileData(module.getDbKey(), moduleFile.path()).revision()).isEqualTo("123456789");
- assertThat(ref.fileData(project.getDbKey(), projectFile.path())).isNull();
+ assertThat(ref.fileDataByPath(project.getKey())).isEmpty();
}
@Test
@@ -542,7 +706,7 @@ public class ProjectDataLoaderTest {
expectedException.expect(ForbiddenException.class);
expectedException.expectMessage("You're not authorized to execute any SonarQube analysis");
- underTest.load(ProjectDataQuery.create().setModuleKey(project.getDbKey()));
+ underTest.load(ProjectDataQuery.create().setModuleKey(project.getKey()));
}
@Test
@@ -553,7 +717,7 @@ public class ProjectDataLoaderTest {
expectedException.expect(ForbiddenException.class);
expectedException.expectMessage("You're only authorized to execute a local (preview) SonarQube analysis without pushing the results to the SonarQube server");
- underTest.load(ProjectDataQuery.create().setModuleKey(project.getDbKey()));
+ underTest.load(ProjectDataQuery.create().setModuleKey(project.getKey()));
}
@Test
@@ -561,7 +725,7 @@ public class ProjectDataLoaderTest {
ComponentDto project = db.components().insertPrivateProject();
userSession.logIn().addProjectPermission(UserRole.USER, project);
- ProjectRepositories repositories = underTest.load(ProjectDataQuery.create().setModuleKey(project.getDbKey()).setIssuesMode(true));
+ ProjectRepositories repositories = underTest.load(ProjectDataQuery.create().setModuleKey(project.getKey()).setIssuesMode(true));
assertThat(repositories).isNotNull();
}
@@ -574,7 +738,7 @@ public class ProjectDataLoaderTest {
expectedException.expect(ForbiddenException.class);
expectedException.expectMessage("You don't have the required permissions to access this project");
- underTest.load(ProjectDataQuery.create().setModuleKey(project.getDbKey()).setIssuesMode(true));
+ underTest.load(ProjectDataQuery.create().setModuleKey(project.getKey()).setIssuesMode(true));
}
@Test
@@ -583,7 +747,7 @@ public class ProjectDataLoaderTest {
userSession.logIn().addPermission(SCAN, project.getOrganizationUuid());
userSession.logIn().addProjectPermission(UserRole.USER, project);
- ProjectRepositories repositories = underTest.load(ProjectDataQuery.create().setModuleKey(project.getDbKey()).setIssuesMode(true));
+ ProjectRepositories repositories = underTest.load(ProjectDataQuery.create().setModuleKey(project.getKey()).setIssuesMode(true));
assertThat(repositories).isNotNull();
}